summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMariano Lopez <mariano.lopez@linux.intel.com>2016-08-01 08:16:33 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-08-04 15:05:47 +0100
commitbadec3d10fcdd2d000450ab533caadcff1df5e13 (patch)
treed72731843a5417f0e96172062d619b6ea70b106e
parentf0ee1778c99a8b40c0fefa5f846aa34bf9701008 (diff)
downloadopenembedded-core-contrib-badec3d10fcdd2d000450ab533caadcff1df5e13.tar.gz
openembedded-core-contrib-badec3d10fcdd2d000450ab533caadcff1df5e13.tar.bz2
openembedded-core-contrib-badec3d10fcdd2d000450ab533caadcff1df5e13.zip
selftest/runtime-test.py: Add test for testexport SDK feature
This adds test_testexport_sdk() to test the SDK feature of testexport in the CI in order to avoid breaking it. [YOCTO #9765] Signed-off-by: Mariano Lopez <mariano.lopez@linux.intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com>
-rw-r--r--meta-selftest/lib/oeqa/runtime/selftest.py24
-rw-r--r--meta/lib/oeqa/selftest/runtime-test.py41
2 files changed, 65 insertions, 0 deletions
diff --git a/meta-selftest/lib/oeqa/runtime/selftest.py b/meta-selftest/lib/oeqa/runtime/selftest.py
index b9c9b23bfc..a7e58ab3d5 100644
--- a/meta-selftest/lib/oeqa/runtime/selftest.py
+++ b/meta-selftest/lib/oeqa/runtime/selftest.py
@@ -1,9 +1,13 @@
+import os
+
from oeqa.oetest import oeRuntimeTest, skipModule
+from oeqa.utils.commands import runCmd
from oeqa.utils.decorators import *
class Selftest(oeRuntimeTest):
@skipUnlessPassed("test_ssh")
+ @tag("selftest_package_install")
def test_install_package(self):
"""
Summary: Check basic package installation functionality.
@@ -18,6 +22,7 @@ class Selftest(oeRuntimeTest):
self.assertEqual(status, 0, msg="socat is not installed")
@skipUnlessPassed("test_install_package")
+ @tag("selftest_package_install")
def test_verify_unistall(self):
"""
Summary: Check basic package installation functionality.
@@ -29,3 +34,22 @@ class Selftest(oeRuntimeTest):
(status, output) = self.target.run("socat -V")
self.assertNotEqual(status, 0, msg="socat is still installed")
+
+ @tag("selftest_sdk")
+ def test_sdk(self):
+
+ result = runCmd("env -0")
+ sdk_path = search_sdk_path(result.output)
+ self.assertTrue(sdk_path, msg="Can't find SDK path")
+
+ tar_cmd = os.path.join(sdk_path, "tar")
+ result = runCmd("%s --help" % tar_cmd)
+
+def search_sdk_path(env):
+ for line in env.split("\0"):
+ (key, _, value) = line.partition("=")
+ if key == "PATH":
+ for path in value.split(":"):
+ if "pokysdk" in path:
+ return path
+ return ""
diff --git a/meta/lib/oeqa/selftest/runtime-test.py b/meta/lib/oeqa/selftest/runtime-test.py
index b8e1be10f8..c2d5b45a4b 100644
--- a/meta/lib/oeqa/selftest/runtime-test.py
+++ b/meta/lib/oeqa/selftest/runtime-test.py
@@ -43,6 +43,46 @@ class TestExport(oeSelfTest):
failure = True if 'FAIL' in result.output else False
self.assertNotEqual(True, failure, 'ping test failed')
+ def test_testexport_sdk(self):
+ """
+ Summary: Check sdk functionality for testexport.
+ Expected: 1. testexport directory must be created.
+ 2. SDK tarball must exists.
+ 3. Uncompressing of tarball must succeed.
+ 4. Check if the SDK directory is added to PATH.
+ 5. Run tar from the SDK directory.
+ Product: oe-core
+ Author: Mariano Lopez <mariano.lopez@intel.com>
+ """
+
+ features = 'INHERIT += "testexport"\n'
+ # These aren't the actual IP addresses but testexport class needs something defined
+ features += 'TEST_SERVER_IP = "192.168.7.1"\n'
+ features += 'TEST_TARGET_IP = "192.168.7.1"\n'
+ features += 'TEST_SUITES = "ping"\n'
+ features += 'TEST_SUITES_TAGS = "selftest_sdk"\n'
+ features += 'TEST_EXPORT_SDK_ENABLED = "1"\n'
+ features += 'TEST_EXPORT_SDK_PACKAGES = "nativesdk-tar"\n'
+ self.write_config(features)
+
+ # Build tesexport for core-image-minimal
+ bitbake('core-image-minimal')
+ bitbake('-c testexport core-image-minimal')
+
+ # Check for SDK
+ testexport_dir = get_bb_var('TEST_EXPORT_DIR', 'core-image-minimal')
+ sdk_dir = get_bb_var('TEST_EXPORT_SDK_DIR', 'core-image-minimal')
+ tarball_name = "%s.sh" % get_bb_var('TEST_EXPORT_SDK_NAME', 'core-image-minimal')
+ tarball_path = os.path.join(testexport_dir, sdk_dir, tarball_name)
+ self.assertEqual(os.path.isfile(tarball_path), True, "Couldn't find SDK tarball: %s" % tarball_path)
+
+ # Run runexported.py
+ runexported_path = os.path.join(testexport_dir, "runexported.py")
+ testdata_path = os.path.join(testexport_dir, "testdata.json")
+ cmd = "%s %s" % (runexported_path, testdata_path)
+ result = runCmd(cmd)
+ self.assertEqual(0, result.status, 'runexported.py returned a non 0 status')
+
class TestImage(oeSelfTest):
@@ -57,6 +97,7 @@ class TestImage(oeSelfTest):
features = 'INHERIT += "testimage"\n'
features += 'TEST_SUITES = "ping ssh selftest"\n'
+ features += 'TEST_SUITES_TAGS = "selftest_package_install"\n'
self.write_config(features)
# Build core-image-sato and testimage