All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] oe-selftest: crosstap: add tests for crosstap script
@ 2018-03-19 23:59 Yeoh Ee Peng
  2018-03-20  9:58 ` Alexander Kanavin
  2018-03-21 13:45 ` Alexander Kanavin
  0 siblings, 2 replies; 10+ messages in thread
From: Yeoh Ee Peng @ 2018-03-19 23:59 UTC (permalink / raw)
  To: openembedded-core

QA team were testing crosstap script  manually. Add automated
tests and systemtap file to test that crosstap script will
instructs SystemTap to print hello world in qemu. This test
will first built core-image-minimal image with tools-profile
& ssh-server-openssh features and build systemtap-native on
the host machine. Finally this test will boot the image with qemu
and then execute crosstap script to print hello world on qemu.

Signed-off-by: Yeoh Ee Peng <ee.peng.yeoh@intel.com>
---
 meta/lib/oeqa/files/trace_begin_hello.stp |  5 +++
 meta/lib/oeqa/selftest/cases/crosstap.py  | 65 +++++++++++++++++++++++++++++++
 2 files changed, 70 insertions(+)
 create mode 100644 meta/lib/oeqa/files/trace_begin_hello.stp
 create mode 100644 meta/lib/oeqa/selftest/cases/crosstap.py

diff --git a/meta/lib/oeqa/files/trace_begin_hello.stp b/meta/lib/oeqa/files/trace_begin_hello.stp
new file mode 100644
index 0000000..5ad5f15
--- /dev/null
+++ b/meta/lib/oeqa/files/trace_begin_hello.stp
@@ -0,0 +1,5 @@
+probe begin
+{
+  printf ("hello world\n")
+  exit ()
+}
\ No newline at end of file
diff --git a/meta/lib/oeqa/selftest/cases/crosstap.py b/meta/lib/oeqa/selftest/cases/crosstap.py
new file mode 100644
index 0000000..41c1d2f
--- /dev/null
+++ b/meta/lib/oeqa/selftest/cases/crosstap.py
@@ -0,0 +1,65 @@
+from oeqa.selftest.case import OESelftestTestCase
+from oeqa.utils.commands import bitbake, get_bb_var, runCmd
+import os
+import sys
+import logging
+import bb.tinfoil
+import bb.build
+import oeqa.targetcontrol
+
+class CrossTapTest(OESelftestTestCase):
+
+    def start_qemu_with_image(self, recipe, fstypes, cmd, targetlogger):
+        tinfoil = bb.tinfoil.Tinfoil()
+        tinfoil.prepare(config_only=False, quiet=True)
+        try:
+            tinfoil.logger.setLevel(logging.WARNING)
+            tinfoil.config_data.setVar("TEST_LOG_DIR", "${WORKDIR}/testimage")
+            tinfoil.config_data.setVar("TEST_QEMUBOOT_TIMEOUT", "1000")
+            # Tell QemuTarget() whether need find rootfs/kernel or not
+            #tinfoil.config_data.setVar("FIND_ROOTFS", '0')
+            recipedata = tinfoil.parse_recipe(recipe)
+            logdir = recipedata.getVar("TEST_LOG_DIR")
+            qemu = oeqa.targetcontrol.QemuTarget(recipedata, targetlogger, fstypes)
+        finally:
+            # We need to shut down tinfoil early here in case we actually want
+            # to run tinfoil-using utilities with the running QEMU instance.
+            # Luckily QemuTarget doesn't need it after the constructor.
+            tinfoil.shutdown()
+        print('DEBUG: qemu.deploy')
+        qemu.deploy()
+        try:
+            print('DEBUG: qemu.start')
+            qemu.start(ssh=True, launch_cmd=cmd, discard_writes=True)
+        except bb.build.FuncFailed:
+            raise Exception('Failed to start QEMU - see the logs in %s' % logdir)
+
+        return qemu
+
+    def test_crosstap_can_use_systemtap_on_qemu(self):
+        self.write_config('EXTRA_IMAGE_FEATURES += "tools-profile ssh-server-openssh"')
+        result = bitbake('core-image-minimal')
+        self.assertEqual(result.status, 0, msg="Bitbake core-image-minimal failed. Bitbake output: %s" % result.output)
+        result = bitbake('systemtap-native')
+        self.assertEqual(result.status, 0, msg="Bitbake systemtap-native failed. Bitbake output: %s" % result.output)
+
+        recipe = 'core-image-minimal'
+        fstypes = "ext4 iso hddimg wic.vmdk wic.qcow2 wic.vdi"
+        machine =  'qemux86'
+        deploy_dir_image = get_bb_var('DEPLOY_DIR_IMAGE')
+        qemuboot_conf = "%s-%s.qemuboot.conf" % (recipe, machine)
+        qemuboot_conf = os.path.join(deploy_dir_image, qemuboot_conf)
+        cmd_common = "runqemu nographic"
+        cmd = "%s %s" % (cmd_common, qemuboot_conf)
+        # Need a non-'BitBake' logger to capture the runner output
+        targetlogger = logging.getLogger('TargetRunner')
+        targetlogger.setLevel(logging.DEBUG)
+        handler = logging.StreamHandler(sys.stdout)
+        targetlogger.addHandler(handler)
+        qemu = self.start_qemu_with_image(recipe, fstypes, cmd, targetlogger)
+        systap_file = os.path.join(self.tc.files_dir, 'trace_begin_hello.stp')
+        result = runCmd("crosstap root@%s %s" % (qemu.ip, systap_file))
+        qemu.stop()
+        targetlogger.removeHandler(handler)
+        print(result.output)
+        self.assertTrue('hello world' in result.output, 'Crosstap failed.')
-- 
2.7.4



^ permalink raw reply related	[flat|nested] 10+ messages in thread
* [PATCH] oe-selftest: crosstap: add tests for crosstap script
@ 2018-03-27  1:37 Yeoh Ee Peng
  2018-03-27 10:31 ` Alexander Kanavin
  0 siblings, 1 reply; 10+ messages in thread
From: Yeoh Ee Peng @ 2018-03-27  1:37 UTC (permalink / raw)
  To: openembedded-core

QA team were testing crosstap script manually. Add automated
tests and systemtap file to test that crosstap script will
instructs SystemTap to print hello world in qemu. This test
will first built core-image-minimal image with tools-profile
& ssh-server-openssh features and build systemtap-native on
the host machine. Finally this test will boot the image with qemu
and then execute crosstap script to print hello world on qemu.

Signed-off-by: Yeoh Ee Peng <ee.peng.yeoh@intel.com>
---
 meta/lib/oeqa/files/trace_begin_hello.stp |  5 +++++
 meta/lib/oeqa/selftest/cases/crosstap.py  | 25 +++++++++++++++++++++++++
 2 files changed, 30 insertions(+)
 create mode 100644 meta/lib/oeqa/files/trace_begin_hello.stp
 create mode 100644 meta/lib/oeqa/selftest/cases/crosstap.py

diff --git a/meta/lib/oeqa/files/trace_begin_hello.stp b/meta/lib/oeqa/files/trace_begin_hello.stp
new file mode 100644
index 0000000..5ad5f15
--- /dev/null
+++ b/meta/lib/oeqa/files/trace_begin_hello.stp
@@ -0,0 +1,5 @@
+probe begin
+{
+  printf ("hello world\n")
+  exit ()
+}
\ No newline at end of file
diff --git a/meta/lib/oeqa/selftest/cases/crosstap.py b/meta/lib/oeqa/selftest/cases/crosstap.py
new file mode 100644
index 0000000..57523cb
--- /dev/null
+++ b/meta/lib/oeqa/selftest/cases/crosstap.py
@@ -0,0 +1,25 @@
+from oeqa.selftest.case import OESelftestTestCase
+from oeqa.utils.commands import bitbake, get_bb_vars, runCmd, runqemu
+import os
+
+class CrossTapTest(OESelftestTestCase):
+
+    def test_crosstap_can_use_systemtap_on_qemu(self):
+        self.write_config('EXTRA_IMAGE_FEATURES += "tools-profile ssh-server-openssh"')
+        result = bitbake('core-image-minimal')
+        self.assertEqual(result.status, 0, msg="Bitbake core-image-minimal failed. Bitbake output: %s" % result.output)
+        result = bitbake('systemtap-native')
+        self.assertEqual(result.status, 0, msg="Bitbake systemtap-native failed. Bitbake output: %s" % result.output)
+
+        recipe = 'core-image-minimal'
+        bb_vars = get_bb_vars(['MACHINE', 'DEPLOY_DIR_IMAGE'])
+        machine =  bb_vars['MACHINE']
+        deploy_dir_image = bb_vars['DEPLOY_DIR_IMAGE']
+        qemuboot_conf = "%s-%s.qemuboot.conf" % (recipe, machine)
+        qemuboot_conf = os.path.join(deploy_dir_image, qemuboot_conf)
+        cmd_common = "runqemu nographic"
+        cmd = "%s %s" % (cmd_common, qemuboot_conf)
+        with runqemu(recipe, ssh=True, launch_cmd=cmd) as qemu:
+            systap_file = os.path.join(self.tc.files_dir, 'trace_begin_hello.stp')
+            result = runCmd("crosstap root@%s %s" % (qemu.ip, systap_file))
+        self.assertTrue('hello world' in result.output, 'Crosstap failed.')
-- 
2.7.4



^ permalink raw reply related	[flat|nested] 10+ messages in thread
* [PATCH] oe-selftest: crosstap: add tests for crosstap script
@ 2018-04-10 18:32 Yeoh Ee Peng
  0 siblings, 0 replies; 10+ messages in thread
From: Yeoh Ee Peng @ 2018-04-10 18:32 UTC (permalink / raw)
  To: openembedded-core

QA team were testing crosstap script manually. Add automated
tests and systemtap file to test that crosstap script will
instructs SystemTap to print hello world in qemu. This test
will first built core-image-minimal image with tools-profile
& ssh-server-openssh features and build systemtap-native on
the host machine. Finally this test will boot the image with qemu
and then execute crosstap script to print hello world on qemu.

Signed-off-by: Yeoh Ee Peng <ee.peng.yeoh@intel.com>
---
 meta/lib/oeqa/files/trace_begin_hello.stp |  5 +++++
 meta/lib/oeqa/selftest/cases/crosstap.py  | 25 +++++++++++++++++++++++++
 2 files changed, 30 insertions(+)
 create mode 100644 meta/lib/oeqa/files/trace_begin_hello.stp
 create mode 100644 meta/lib/oeqa/selftest/cases/crosstap.py

diff --git a/meta/lib/oeqa/files/trace_begin_hello.stp b/meta/lib/oeqa/files/trace_begin_hello.stp
new file mode 100644
index 0000000..5ad5f15
--- /dev/null
+++ b/meta/lib/oeqa/files/trace_begin_hello.stp
@@ -0,0 +1,5 @@
+probe begin
+{
+  printf ("hello world\n")
+  exit ()
+}
\ No newline at end of file
diff --git a/meta/lib/oeqa/selftest/cases/crosstap.py b/meta/lib/oeqa/selftest/cases/crosstap.py
new file mode 100644
index 0000000..57523cb
--- /dev/null
+++ b/meta/lib/oeqa/selftest/cases/crosstap.py
@@ -0,0 +1,25 @@
+from oeqa.selftest.case import OESelftestTestCase
+from oeqa.utils.commands import bitbake, get_bb_vars, runCmd, runqemu
+import os
+
+class CrossTapTest(OESelftestTestCase):
+
+    def test_crosstap_can_use_systemtap_on_qemu(self):
+        self.write_config('EXTRA_IMAGE_FEATURES += "tools-profile ssh-server-openssh"')
+        result = bitbake('core-image-minimal')
+        self.assertEqual(result.status, 0, msg="Bitbake core-image-minimal failed. Bitbake output: %s" % result.output)
+        result = bitbake('systemtap-native')
+        self.assertEqual(result.status, 0, msg="Bitbake systemtap-native failed. Bitbake output: %s" % result.output)
+
+        recipe = 'core-image-minimal'
+        bb_vars = get_bb_vars(['MACHINE', 'DEPLOY_DIR_IMAGE'])
+        machine =  bb_vars['MACHINE']
+        deploy_dir_image = bb_vars['DEPLOY_DIR_IMAGE']
+        qemuboot_conf = "%s-%s.qemuboot.conf" % (recipe, machine)
+        qemuboot_conf = os.path.join(deploy_dir_image, qemuboot_conf)
+        cmd_common = "runqemu nographic"
+        cmd = "%s %s" % (cmd_common, qemuboot_conf)
+        with runqemu(recipe, ssh=True, launch_cmd=cmd) as qemu:
+            systap_file = os.path.join(self.tc.files_dir, 'trace_begin_hello.stp')
+            result = runCmd("crosstap root@%s %s" % (qemu.ip, systap_file))
+        self.assertTrue('hello world' in result.output, 'Crosstap failed.')
-- 
2.7.4



^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2018-04-11  1:46 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-03-19 23:59 [PATCH] oe-selftest: crosstap: add tests for crosstap script Yeoh Ee Peng
2018-03-20  9:58 ` Alexander Kanavin
2018-03-21 13:45 ` Alexander Kanavin
2018-03-22  0:50   ` Yeoh, Ee Peng
2018-03-22 11:38     ` Alexander Kanavin
2018-03-23  1:32       ` Yeoh, Ee Peng
2018-03-27  1:37 Yeoh Ee Peng
2018-03-27 10:31 ` Alexander Kanavin
2018-03-28  0:41   ` Yeoh, Ee Peng
2018-04-10 18:32 Yeoh Ee Peng

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.