On 06/28/2013 03:04 AM, Stefan Stanacar wrote:

Hello,

This is the proposed implementation of a new runtime tests framework based on 
python unittest.
It's mean to ease qemu image testing and encourage developers to add more tests 
similar to the example tests provided (all tests are basically commands ran 
over ssh)

You can try it out like this:
  - first build a qemu core-image-sato (a minimal wouldn't be interesting at 
all)
  - add INHERIT += "testimage" in local.conf
  - then bitbake core-image-sato -c testimage. That will run a standard suite 
of tests.

You can set TEST_SUITES = "ping ssh <test name>" in local.conf to force run only certain tests 
(order matters here, it's the order in which tests run). You can also append "auto" and it will also run 
whatever tests are suitable for the image (if that was a sato-sdk image and you set TEST_SUITE = "ping ssh rpm 
auto" you force run ping, ssh and rpm but you also get smart, connman and gcc tests).

Check the task log (log.do_testimage) in WORKDIR to see the results. Also a ssh 
log (what command is running, output and return codes) and qemu boot log are 
kept in WORKDIR/testimage/

There are some areas for improvement/limitations right now:
  - a better way of getting the list of installed packages in a image
  - qemu is started with the -snapshot option, we should create a copy of the 
original rootfs instead.
  - when using TEST_SUITES = "auto" there is no dependency at all between tests (rpm 
would run before ssh test), so better use TEST_SUITES = "ping ssh auto"
  - better logging and error reporting for qemu problems (runqemu erros, qemu 
doesn't start, etc)
  - more helper methods for tests
  - others I can't think of right now :)

I hope this is going in the right direction and we could improve from here.
Comments and feedback are most welcome!


Tired this out today and got the following:
ERROR: Function failed: Failed to start qemu. You should check the task log and 
the qemu boot log (qemu log is 
/srv/ssd/sgw/builds/world/tmp/work/qemux86_64-poky-linux/core-image-sato/1.0-r0/testimage/qemu_boot_log.20130704065001)
ERROR: Logfile of failure stored in: 
/srv/ssd/sgw/builds/world/tmp/work/qemux86_64-poky-linux/core-image-sato/1.0-r0/temp/log.do_testimage.18354
Log data follows:
| DEBUG: Executing python function do_testimage
| NOTE: Test modules  ['oeqa.runtime.ping', 'oeqa.runtime.ssh', 
'oeqa.runtime.connman', 'oeqa.runtime.rpm', 'oeqa.runtime.smart', 
'oeqa.runtime.xorg', 'oeqa.runtime.dmesg']
| NOTE: DISPLAY value: None
| NOTE: rootfs file: 
/srv/ssd/sgw/builds/world/tmp/deploy/images/core-image-sato-qemux86-64.ext3
| NOTE: Qemu logfile: 
/srv/ssd/sgw/builds/world/tmp/work/qemux86_64-poky-linux/core-image-sato/1.0-r0/testimage/qemu_boot_log.20130704065001
| NOTE: runqemu started, pid is 18389
| NOTE: waiting at most 30 seconds for qemu pid
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| No children found matching 18389
| NOTE: Qemu pid didn't appeared in 30 seconds
| NOTE: Output from runqemu: Please use simplified serial or kvm options instead
|
| Continuing with the following parameters:
| KERNEL: [/srv/ssd/sgw/builds/world/tmp/deploy/images/bzImage-qemux86-64.bin]
| ROOTFS: 
[/srv/ssd/sgw/builds/world/tmp/deploy/images/core-image-sato-qemux86-64.ext3]
| FSTYPE: [ext3]
| stty: standard input: Inappropriate ioctl for device
| Acquiring lockfile for tap0...
| Using preconfigured tap device 'tap0'
| Running qemu-system-x86_64...
| /srv/ssd/sgw/builds/world/tmp/sysroots/x86_64-linux/usr/bin/qemu-system-x86_64 -kernel 
/srv/ssd/sgw/builds/world/tmp/deploy/images/bzImage-qemux86-64.bin -net nic,vlan=0 -net 
tap,vlan=0,ifname=tap0,script=no,downscript=no -hda 
/srv/ssd/sgw/builds/world/tmp/deploy/images/core-image-sato-qemux86-64.ext3 -show-cursor 
-usb -usbdevice wacom-tablet -vga vmware -no-reboot -snapshot -serial 
unix:/tmp/qemuconnection.18354,server,nowait -m 128 --append "vga=0 
uvesafb.mode_option=640x480-32 root=/dev/hda rw mem=128M 
ip=192.168.7.2::192.168.7.1:255.255.255.0 oprofile.timer=1 console=ttyS0"
| Could not initialize SDL(No available video device) - exiting
| Releasing lockfile of preconfigured tap device 'tap0'
| stty: standard input: Inappropriate ioctl for device
| stty: standard input: Inappropriate ioctl for device
|
| DEBUG: Python function do_testimage finished
| ERROR: Function failed: Failed to start qemu. You should check the task log 
and the qemu boot log (qemu log is 
/srv/ssd/sgw/builds/world/tmp/work/qemux86_64-poky-linux/core-image-sato/1.0-r0/testimage/qemu_boot_log.20130704065001)
ERROR: Task 0 (/srv/ssd/sgw/poky/meta/recipes-sato/images/core-image-sato.bb, 
do_testimage) failed with exit code '1'
NOTE: Tasks Summary: Attempted 164 tasks of which 163 didn't need to be rerun 
and 1 failed.



Sau!


Regards,
Stefan



The following changes since commit 042203531b10b37ac9a8201b376f5dec403e51d8:

   sanity.bbclass: Fix COREBASE sanity tests (2013-06-27 12:48:56 +0100)

are available in the git repository at:

   git://mirror.rb.intel.com/git.yoctoproject.org/poky-contrib stefans/oeqa5

for you to fetch changes up to e6e567982f4b28822afdc8ea55401513df7c9466:

   lib/oeqa/runtime: add gcc test (2013-06-28 13:00:45 +0300)

----------------------------------------------------------------
Radu Moisan (2):
       lib/oeqa/utils/qemurunner.py: class to handle qemu instance
       lib/oeqa/utils/decorators.py: decorators for test methods

Stefan Stanacar (6):
       classes/testimage.bbclass: new class for image tests
       lib/oeqa/oetest.py: base module for all runtime unittests
       lib/oeqa/utils/sshcontrol.py: helper module for running remote commands
       lib/oeqa/utils/oetelnetlib.py: override Telnet class to use Unix domain 
sockets
       lib/oeqa/runtime: image sanity tests
       lib/oeqa/runtime: add gcc test

  meta/classes/testimage.bbclass           |  95 ++++++++++++++++++
  meta/lib/oeqa/__init__.py                |   0
  meta/lib/oeqa/oetest.py                  |  94 ++++++++++++++++++
  meta/lib/oeqa/runtime/__init__.py        |   0
  meta/lib/oeqa/runtime/connman.py         |  34 +++++++
  meta/lib/oeqa/runtime/dmesg.py           |  10 ++
  meta/lib/oeqa/runtime/files/test.c       |  26 +++++
  meta/lib/oeqa/runtime/files/testmakefile |   5 +
  meta/lib/oeqa/runtime/gcc.py             |  36 +++++++
  meta/lib/oeqa/runtime/multilib.py        |  14 +++
  meta/lib/oeqa/runtime/ping.py            |  11 +++
  meta/lib/oeqa/runtime/rpm.py             |  25 +++++
  meta/lib/oeqa/runtime/smart.py           |  23 +++++
  meta/lib/oeqa/runtime/ssh.py             |  16 ++++
  meta/lib/oeqa/utils/__init__.py          |   0
  meta/lib/oeqa/utils/decorators.py        |  40 ++++++++
  meta/lib/oeqa/utils/oetelnetlib.py       |  49 ++++++++++
  meta/lib/oeqa/utils/qemurunner.py        | 160 +++++++++++++++++++++++++++++++
  meta/lib/oeqa/utils/sshcontrol.py        | 100 +++++++++++++++++++
  scripts/runqemu                          |   2 +-
  20 files changed, 739 insertions(+), 1 deletion(-)
  create mode 100644 meta/classes/testimage.bbclass
  create mode 100644 meta/lib/oeqa/__init__.py
  create mode 100644 meta/lib/oeqa/oetest.py
  create mode 100644 meta/lib/oeqa/runtime/__init__.py
  create mode 100644 meta/lib/oeqa/runtime/connman.py
  create mode 100644 meta/lib/oeqa/runtime/dmesg.py
  create mode 100644 meta/lib/oeqa/runtime/files/test.c
  create mode 100644 meta/lib/oeqa/runtime/files/testmakefile
  create mode 100644 meta/lib/oeqa/runtime/gcc.py
  create mode 100644 meta/lib/oeqa/runtime/multilib.py
  create mode 100644 meta/lib/oeqa/runtime/ping.py
  create mode 100644 meta/lib/oeqa/runtime/rpm.py
  create mode 100644 meta/lib/oeqa/runtime/smart.py
  create mode 100644 meta/lib/oeqa/runtime/ssh.py
  create mode 100644 meta/lib/oeqa/utils/__init__.py
  create mode 100644 meta/lib/oeqa/utils/decorators.py
  create mode 100644 meta/lib/oeqa/utils/oetelnetlib.py
  create mode 100644 meta/lib/oeqa/utils/qemurunner.py
  create mode 100644 meta/lib/oeqa/utils/sshcontrol.py

Radu Moisan (2):
   lib/oeqa/utils/qemurunner.py: class to handle qemu instance
   lib/oeqa/utils/decorators.py: decorators for test methods

Stefan Stanacar (6):
   classes/testimage.bbclass: new class for image tests
   lib/oeqa/oetest.py: base module for all runtime unittests
   lib/oeqa/utils/sshcontrol.py: helper module for running remote
     commands
   lib/oeqa/utils/oetelnetlib.py: override Telnet class to use Unix
     domain sockets
   lib/oeqa/runtime: image sanity tests
   lib/oeqa/runtime: add gcc test

  meta/classes/testimage.bbclass           |  95 ++++++++++++++++++
  meta/lib/oeqa/__init__.py                |   0
  meta/lib/oeqa/oetest.py                  |  94 ++++++++++++++++++
  meta/lib/oeqa/runtime/__init__.py        |   0
  meta/lib/oeqa/runtime/connman.py         |  34 +++++++
  meta/lib/oeqa/runtime/dmesg.py           |  10 ++
  meta/lib/oeqa/runtime/files/test.c       |  26 +++++
  meta/lib/oeqa/runtime/files/testmakefile |   5 +
  meta/lib/oeqa/runtime/gcc.py             |  36 +++++++
  meta/lib/oeqa/runtime/multilib.py        |  14 +++
  meta/lib/oeqa/runtime/ping.py            |  11 +++
  meta/lib/oeqa/runtime/rpm.py             |  25 +++++
  meta/lib/oeqa/runtime/smart.py           |  23 +++++
  meta/lib/oeqa/runtime/ssh.py             |  16 ++++
  meta/lib/oeqa/utils/__init__.py          |   0
  meta/lib/oeqa/utils/decorators.py        |  40 ++++++++
  meta/lib/oeqa/utils/oetelnetlib.py       |  49 ++++++++++
  meta/lib/oeqa/utils/qemurunner.py        | 160 +++++++++++++++++++++++++++++++
  meta/lib/oeqa/utils/sshcontrol.py        | 100 +++++++++++++++++++
  scripts/runqemu                          |   2 +-
  20 files changed, 739 insertions(+), 1 deletion(-)
  create mode 100644 meta/classes/testimage.bbclass
  create mode 100644 meta/lib/oeqa/__init__.py
  create mode 100644 meta/lib/oeqa/oetest.py
  create mode 100644 meta/lib/oeqa/runtime/__init__.py
  create mode 100644 meta/lib/oeqa/runtime/connman.py
  create mode 100644 meta/lib/oeqa/runtime/dmesg.py
  create mode 100644 meta/lib/oeqa/runtime/files/test.c
  create mode 100644 meta/lib/oeqa/runtime/files/testmakefile
  create mode 100644 meta/lib/oeqa/runtime/gcc.py
  create mode 100644 meta/lib/oeqa/runtime/multilib.py
  create mode 100644 meta/lib/oeqa/runtime/ping.py
  create mode 100644 meta/lib/oeqa/runtime/rpm.py
  create mode 100644 meta/lib/oeqa/runtime/smart.py
  create mode 100644 meta/lib/oeqa/runtime/ssh.py
  create mode 100644 meta/lib/oeqa/utils/__init__.py
  create mode 100644 meta/lib/oeqa/utils/decorators.py
  create mode 100644 meta/lib/oeqa/utils/oetelnetlib.py
  create mode 100644 meta/lib/oeqa/utils/qemurunner.py
  create mode 100644 meta/lib/oeqa/utils/sshcontrol.py

_______________________________________________
Openembedded-core mailing list
Openembedded-core@lists.openembedded.org
http://lists.openembedded.org/mailman/listinfo/openembedded-core

Reply via email to