<div dir="ltr"><div>We are going to make integration testing gate scheme for Ironic and we've investigated several cases which are actual for TripleO.</div><div><br></div><div><div>1) <a href="https://etherpad.openstack.org/p/tripleo-test-cluster">https://etherpad.openstack.org/p/tripleo-test-cluster</a></div>
<div>This is the newest and most advanced initiative. It is something like "test environment on demand". It is still not ready to use.</div></div><div><br></div><div>2) <a href="https://github.com/openstack-infra/tripleo-ci">https://github.com/openstack-infra/tripleo-ci</a><br>
</div><div>This project seems not to be actively used at the moment. It contains toci_gate_test.sh, but this script is empty and is used as a gate hook. It is supposed that it will then implement the whole gate testing logic using "test env on demand" (see previous point). </div>
<div>This project also has some shell code which is used to manage emulated bare metal environments. It is something like prepare libvirt VM xml and launch VM using virsh (nothing special).<br></div><div><br></div><div>3) <a href="https://github.com/openstack/tripleo-incubator/blob/master/scripts">https://github.com/openstack/tripleo-incubator/blob/master/scripts</a> (aka devtest)</div>
<div>This is a set of shell scripts which are intended to reproduce the whole TripleO flow (seed, undercloud, overcloud). It is supposed to be used to perform testing actions (including gate tests).</div><div>Documentation is available <a href="http://docs.openstack.org/developer/tripleo-incubator/devtest.html">http://docs.openstack.org/developer/tripleo-incubator/devtest.html</a><br>
</div><div><br></div><div>So, the situation looks like there is no fully working and mature scheme at the moment. <br></div><div><br></div><div>My suggestion is to start from creating empty gate test flow (like in tripleo-ci). Then we can write some code implementing some testing logic. It is possible even before conductor manager is ready. We can just directly import driver modules and test them in a functional (aka integration) manner. As for managing emulated bare metal environments, here we can write (or copy from tripleo) some scripts for that (shell or python). What we actually need to be able to do is to launch one VM, then to install ironic on it, and then launch another VM and boot it via PXE from the first one. In the future we can use "environment on demand" scheme, when it is ready. So we can follow the same scenario as they use in TripleO. </div>
<div><br></div><div>Besides, there is an idea about how to manage test environment using openstack itself. Right now nova can make VMs and it has advanced functionality for that. What it can NOT do is to boot them via PXE. There is a blueprint for that <a href="https://blueprints.launchpad.net/nova/+spec/libvirt-empty-vm-boot-pxe">https://blueprints.launchpad.net/nova/+spec/libvirt-empty-vm-boot-pxe</a>.<br>
</div><div><br></div><div><br></div>-- <br><div>Vladimir Kozhukalov</div>
</div>