diff options
author | Mariano Lopez <mariano.lopez@linux.intel.com> | 2016-06-06 10:28:04 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-06-07 21:36:20 +0100 |
commit | 4a842cc95226621326f391705dae7a39bd9e32f7 (patch) | |
tree | 0da49969d4003d5c1dec7425b2828b3fe53022f9 /meta | |
parent | 2228b16bef534e337bc0f7c988b9f96dea7a3271 (diff) | |
download | poky-4a842cc95226621326f391705dae7a39bd9e32f7.tar.gz |
selftest/testexport.py: Add test test_testexport_basic
Exported tests is not been tested right now and it get
broken very easily with import errors from bitbake.
This adds a new test in order to verify in the CI if
the testexport gets broken.
[YOCTO #8384]
(From OE-Core rev: b6e0a762f8a17ee323cef02934f9a624faf706ed)
Signed-off-by: Mariano Lopez <mariano.lopez@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/lib/oeqa/selftest/testexport.py | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/meta/lib/oeqa/selftest/testexport.py b/meta/lib/oeqa/selftest/testexport.py new file mode 100644 index 0000000000..5823b1303c --- /dev/null +++ b/meta/lib/oeqa/selftest/testexport.py | |||
@@ -0,0 +1,44 @@ | |||
1 | from oeqa.selftest.base import oeSelfTest | ||
2 | from oeqa.utils.commands import runCmd, bitbake, get_bb_var, runqemu | ||
3 | from oeqa.utils.decorators import testcase | ||
4 | import os | ||
5 | |||
6 | class TestExport(oeSelfTest): | ||
7 | |||
8 | def test_testexport_basic(self): | ||
9 | """ | ||
10 | Summary: Check basic testexport functionality with only ping test enabled. | ||
11 | Expected: 1. testexport directory must be created. | ||
12 | 2. runexported.py must run without any error/exception. | ||
13 | 3. ping test must succeed. | ||
14 | Product: oe-core | ||
15 | Author: Mariano Lopez <mariano.lopez@intel.com> | ||
16 | """ | ||
17 | |||
18 | features = 'INHERIT += "testexport"\n' | ||
19 | # These aren't the actual IP addresses but testexport class needs something defined | ||
20 | features += 'TEST_SERVER_IP = "192.168.7.1"\n' | ||
21 | features += 'TEST_TARGET_IP = "192.168.7.1"\n' | ||
22 | features += 'TEST_SUITES = "ping"\n' | ||
23 | self.write_config(features) | ||
24 | |||
25 | # Build tesexport for core-image-minimal | ||
26 | bitbake('core-image-minimal') | ||
27 | bitbake('-c testexport core-image-minimal') | ||
28 | |||
29 | # Verify if TEST_EXPORT_DIR was created | ||
30 | testexport_dir = get_bb_var('TEST_EXPORT_DIR', 'core-image-minimal') | ||
31 | isdir = os.path.isdir(testexport_dir) | ||
32 | self.assertEqual(True, isdir, 'Failed to create testexport dir: %s' % testexport_dir) | ||
33 | |||
34 | with runqemu('core-image-minimal') as qemu: | ||
35 | # Attempt to run runexported.py to perform ping test | ||
36 | runexported_path = os.path.join(testexport_dir, "runexported.py") | ||
37 | testdata_path = os.path.join(testexport_dir, "testdata.json") | ||
38 | cmd = "%s -t %s -s %s %s" % (runexported_path, qemu.ip, qemu.server_ip, testdata_path) | ||
39 | result = runCmd(cmd) | ||
40 | self.assertEqual(0, result.status, 'runexported.py returned a non 0 status') | ||
41 | |||
42 | # Verify ping test was succesful | ||
43 | failure = True if 'FAIL' in result.output else False | ||
44 | self.assertNotEqual(True, failure, 'ping test failed') | ||