Image tests: Difference between revisions
| No edit summary | |||
| Line 35: | Line 35: | ||
| Examples: | Examples: | ||
| * to run the default tests for core-image-sato you don't need to change TEST_SUITES. The default for core-image-sato is: "ping ssh connman df rpm smart xorg syslog dmesg" | |||
| * to add your own test to the list of the defaults add: TEST_SUITES_append = " mytest" | |||
| * to run a specific list of tests: TEST_SUITES = "ping ssh rpm" (remember order is important) | |||
Revision as of 13:21, 12 August 2013
About the the testimage class
The build system has the ability to run a series of automated tests for qemu images.
All the tests are actually commands run on the target system over ssh.
The tests themselves are written in Python, making use of the unittest module.
The class that enables this is testimage.bbclass (which handles loading the tests and starting the qemu image)
Enabling and running the tests
Requirements
You should be aware of the following:
- runqemu script needs sudo access for setting up the tap interface, so you need to make sure it can do that non-interactively. That means you need to one of the following:
- add NOPASSWD for your user either for ALL commands in /etc/sudoers, either just for runqemu-ifup (but you need to provide the full path and that can change if you have multiple poky clones)
- manually configure a tap interface for your system
- run as root the script in scripts/runqemu-gen-tapdev which should generate a list of tap devices (that's usually done in AutoBuilder-like setups)
 
- the DISPLAY variable needs to be set so that means you need to have an X server available (AutoBuilder starts a vncserver)
To use it add "testimage" to global inherit and call your target image with -c testimage, like this:
- for example build a qemu core-image-sato: bitbake core-image-sato
- add INHERIT += "testimage" in local.conf
- then call "bitbake core-image-sato -c testimage". That will run a standard suite of tests.
The name of tests is the name of the python modules in meta/lib/oeqa/runtime. (without the .py extension)
You can change the tests run by appending or overrding the TEST_SUITES variable in local.conf. Each name in TEST_SUITES represents a required test for the image. That means that no skipping is allowed (even if the test isn't suitable for the image, e.g running the rpm tests on a images with no rpm). Appending "auto" to TEST_SUITES means that it will try to run all tests that are suitable for the image (each test decides that on it's own).
Note that the order in TEST_SUITES is important (it's the order modules run) and it influences tests dependencies. That means that tests that depend on other tests (e.g ssh depends on the ping test) should be added last. Each module can have multiple classes with multiple test methods (and Python unittest rules apply here).
Examples:
- to run the default tests for core-image-sato you don't need to change TEST_SUITES. The default for core-image-sato is: "ping ssh connman df rpm smart xorg syslog dmesg"
- to add your own test to the list of the defaults add: TEST_SUITES_append = " mytest"
- to run a specific list of tests: TEST_SUITES = "ping ssh rpm" (remember order is important)
