My focus over the last year or so lay on bringing test automation to oVirt Node.
It was challenging because oVirt Node is based on a LiveCD - at boot and post-installtion. (The whole LiveCD is used as a r/o rootfs.)
To allow an automated testing of oVirt Node, I've been working on igor. It allows us to test oVirt Node on real hardware an in VMs.
When you throw all the new features (see below - libvirt-only, new igorc, new igor events service, junit-reports for jobs) together you can do a complete testsuite run on an oVirt Node ISO with one command.
And this is how it looks (view it in fullscreen to see all the nifty details, but this will leave you without the subtitles explaining what's happening):
0
00:00:00,000 --> 00:00:00,100
1
00:00:00,100 --> 00:00:03,000
Launching igorc
2
00:00:03,000 --> 00:00:12,000
igorc (left) extracts LiveCD, creates a profile and submits a new job
3
00:00:27,000 --> 00:00:32,000
igord created a VM (right) and boots it up (from a CD derived from the igord profile)
4
00:00:40,000 --> 00:01:00,000
VM (right) boots and the autoinstall is performed
5
00:01:36,000 --> 00:01:45,000
Installation finished (Ctrl-Alt-Del is sent to the VM to reboot [that's a known bug])
6
00:01:58,000 --> 00:02:05,000
The VM now boots from HD
7
00:02:20,000 --> 00:02:27,000
An igor-service is now started in the background (within the VM) to communicate with igord
8
00:02:34,000 --> 00:02:39,000
The igor-service tells igord about the ocmpletion of the first testcase, which is then picked up by igorc (left).
9
00:02:39,000 --> 00:02:45,000
A couple of more testcases were completed (left) and a reboot is initiated (by the igor-service within the VM)
10
00:02:48,000 --> 00:03:10,000
The VM (right) reboots
11
00:03:46,000 --> 00:03:59,000
All testcases passed and the VM is torn down by igord
This is a big step forward - even if there are still some issues outstanding to achieve the goal to make testcase development fun.
Now that we've seen the fancy part some background and open issues.
One pitfall - up to this week - was the hurdle to get igor up an running. Igor used to require Cobbler - and cobbler is not easy to setup on Fedora 18 (which I use to build an test oVirt Node - which itself is based on Fedora 18 packages).
Anyhow - long story short - Igor has a "feature complete" "backend" for libvirt now, that means, igor doesn't need cobbler anymore. Furthermore I've added a brand new igor client (called igorc) which communicates with igord (the daemon doing all the coordination work).
This client has some "advanced" features like pretty printing of junit results (Igor offers the result of the testruns in junit's XML format).
Some open issues:
- ovirt-node needs a target to build a testable ISO
- igor needs a feature to upload testsuites from the client side
That's it for now - thanks for watching.
No comments:
Post a Comment