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 + """ + + 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