diff options
| author | Mariano Lopez <mariano.lopez@linux.intel.com> | 2017-01-18 13:23:59 +0000 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2017-01-23 12:05:21 +0000 |
| commit | 46ce0b5ef3ee623cc9d366f83030363b470ed11e (patch) | |
| tree | 9138b6eab333f439ddaa413eb335c399caf0018c | |
| parent | 1cc2bac7ecb5108096eb72710d2ca183b6cfe785 (diff) | |
| download | poky-46ce0b5ef3ee623cc9d366f83030363b470ed11e.tar.gz | |
testexport.bbclass: Migrate testexport to use new framework
This migrates current testexport implmentation to use the
new OEQA framework.
[YOCTO #10686]
(From OE-Core rev: 92cb884c989460563a063b29d2be8b7acd20577e)
Signed-off-by: Mariano Lopez <mariano.lopez@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | meta/classes/testexport.bbclass | 215 | ||||
| -rwxr-xr-x | scripts/oe-test | 10 |
2 files changed, 99 insertions, 126 deletions
diff --git a/meta/classes/testexport.bbclass b/meta/classes/testexport.bbclass index 5398b3c767..56edda9943 100644 --- a/meta/classes/testexport.bbclass +++ b/meta/classes/testexport.bbclass | |||
| @@ -33,113 +33,111 @@ TEST_EXPORT_DEPENDS += "${@bb.utils.contains('IMAGE_PKGTYPE', 'rpm', 'cpio-nativ | |||
| 33 | TEST_EXPORT_DEPENDS += "${@bb.utils.contains('TEST_EXPORT_SDK_ENABLED', '1', 'testexport-tarball:do_populate_sdk', '', d)}" | 33 | TEST_EXPORT_DEPENDS += "${@bb.utils.contains('TEST_EXPORT_SDK_ENABLED', '1', 'testexport-tarball:do_populate_sdk', '', d)}" |
| 34 | TEST_EXPORT_LOCK = "${TMPDIR}/testimage.lock" | 34 | TEST_EXPORT_LOCK = "${TMPDIR}/testimage.lock" |
| 35 | 35 | ||
| 36 | python do_testexport() { | ||
| 37 | testexport_main(d) | ||
| 38 | } | ||
| 39 | |||
| 40 | addtask testexport | 36 | addtask testexport |
| 41 | do_testexport[nostamp] = "1" | 37 | do_testexport[nostamp] = "1" |
| 42 | do_testexport[depends] += "${TEST_EXPORT_DEPENDS} ${TESTIMAGEDEPENDS}" | 38 | do_testexport[depends] += "${TEST_EXPORT_DEPENDS} ${TESTIMAGEDEPENDS}" |
| 43 | do_testexport[lockfiles] += "${TEST_EXPORT_LOCK}" | 39 | do_testexport[lockfiles] += "${TEST_EXPORT_LOCK}" |
| 44 | 40 | ||
| 45 | def exportTests(d,tc): | 41 | python do_testexport() { |
| 42 | testexport_main(d) | ||
| 43 | } | ||
| 44 | |||
| 45 | def testexport_main(d): | ||
| 46 | import json | 46 | import json |
| 47 | import logging | ||
| 48 | |||
| 49 | from oeqa.runtime.context import OERuntimeTestContext | ||
| 50 | from oeqa.runtime.context import OERuntimeTestContextExecutor | ||
| 51 | |||
| 52 | image_name = ("%s/%s" % (d.getVar('DEPLOY_DIR_IMAGE'), | ||
| 53 | d.getVar('IMAGE_LINK_NAME'))) | ||
| 54 | |||
| 55 | tdname = "%s.testdata.json" % image_name | ||
| 56 | td = json.load(open(tdname, "r")) | ||
| 57 | |||
| 58 | logger = logging.getLogger("BitBake") | ||
| 59 | |||
| 60 | target = OERuntimeTestContextExecutor.getTarget( | ||
| 61 | d.getVar("TEST_TARGET"), None, d.getVar("TEST_TARGET_IP"), | ||
| 62 | d.getVar("TEST_SERVER_IP")) | ||
| 63 | |||
| 64 | host_dumper = OERuntimeTestContextExecutor.getHostDumper( | ||
| 65 | d.getVar("testimage_dump_host"), d.getVar("TESTIMAGE_DUMP_DIR")) | ||
| 66 | |||
| 67 | image_manifest = "%s.manifest" % image_name | ||
| 68 | image_packages = OERuntimeTestContextExecutor.readPackagesManifest(image_manifest) | ||
| 69 | |||
| 70 | extract_dir = d.getVar("TEST_EXTRACTED_DIR") | ||
| 71 | |||
| 72 | tc = OERuntimeTestContext(td, logger, target, host_dumper, | ||
| 73 | image_packages, extract_dir) | ||
| 74 | |||
| 75 | copy_needed_files(d, tc) | ||
| 76 | |||
| 77 | def copy_needed_files(d, tc): | ||
| 47 | import shutil | 78 | import shutil |
| 48 | import pkgutil | ||
| 49 | import re | ||
| 50 | import oe.path | 79 | import oe.path |
| 51 | 80 | ||
| 52 | exportpath = d.getVar("TEST_EXPORT_DIR") | 81 | from oeqa.utils.package_manager import _get_json_file |
| 53 | 82 | from oeqa.core.utils.test import getSuiteCasesFiles | |
| 54 | savedata = {} | 83 | |
| 55 | savedata["d"] = {} | 84 | export_path = d.getVar('TEST_EXPORT_DIR') |
| 56 | savedata["target"] = {} | 85 | corebase_path = d.getVar('COREBASE') |
| 57 | savedata["target"]["ip"] = tc.target.ip or d.getVar("TEST_TARGET_IP") | 86 | |
| 58 | savedata["target"]["server_ip"] = tc.target.server_ip or d.getVar("TEST_SERVER_IP") | 87 | # Clean everything before starting |
| 59 | 88 | oe.path.remove(export_path) | |
| 60 | keys = [ key for key in d.keys() if not key.startswith("_") and not key.startswith("BB") \ | 89 | bb.utils.mkdirhier(os.path.join(export_path, 'lib', 'oeqa')) |
| 61 | and not key.startswith("B_pn") and not key.startswith("do_") and not d.getVarFlag(key, "func")] | 90 | |
| 62 | for key in keys: | 91 | # The source of files to copy are relative to 'COREBASE' directory |
| 63 | try: | 92 | # The destination is relative to 'TEST_EXPORT_DIR' |
| 64 | savedata["d"][key] = d.getVar(key) | 93 | # Because we are squashing the libraries, we need to remove |
| 65 | except bb.data_smart.ExpansionError: | 94 | # the layer/script directory |
| 66 | # we don't care about those anyway | 95 | files_to_copy = [ os.path.join('meta', 'lib', 'oeqa', 'core'), |
| 67 | pass | 96 | os.path.join('meta', 'lib', 'oeqa', 'runtime'), |
| 68 | 97 | os.path.join('meta', 'lib', 'oeqa', 'files'), | |
| 69 | json_file = os.path.join(exportpath, "testdata.json") | 98 | os.path.join('meta', 'lib', 'oeqa', 'utils'), |
| 70 | with open(json_file, "w") as f: | 99 | os.path.join('scripts', 'oe-test'), |
| 71 | json.dump(savedata, f, skipkeys=True, indent=4, sort_keys=True) | 100 | os.path.join('scripts', 'lib', 'argparse_oe.py'), |
| 72 | 101 | os.path.join('scripts', 'lib', 'scriptutils.py'), ] | |
| 73 | # Replace absolute path with relative in the file | 102 | |
| 74 | exclude_path = os.path.join(d.getVar("COREBASE"),'meta','lib','oeqa') | 103 | for f in files_to_copy: |
| 75 | f1 = open(json_file,'r').read() | 104 | src = os.path.join(corebase_path, f) |
| 76 | f2 = open(json_file,'w') | 105 | dst = os.path.join(export_path, f.split('/', 1)[-1]) |
| 77 | m = f1.replace(exclude_path,'oeqa') | 106 | if os.path.isdir(src): |
| 78 | f2.write(m) | 107 | oe.path.copytree(src, dst) |
| 79 | f2.close() | 108 | else: |
| 80 | 109 | shutil.copy2(src, dst) | |
| 81 | # now start copying files | 110 | |
| 82 | # we'll basically copy everything under meta/lib/oeqa, with these exceptions | 111 | # Remove cases and just copy the ones specified |
| 83 | # - oeqa/targetcontrol.py - not needed | 112 | cases_path = os.path.join(export_path, 'lib', 'oeqa', 'runtime', 'cases') |
| 84 | # - oeqa/selftest - something else | 113 | oe.path.remove(cases_path) |
| 85 | # That means: | 114 | bb.utils.mkdirhier(cases_path) |
| 86 | # - all tests from oeqa/runtime defined in TEST_SUITES (including from other layers) | 115 | test_paths = get_runtime_paths(d) |
| 87 | # - the contents of oeqa/utils and oeqa/runtime/files | 116 | test_modules = d.getVar('TEST_SUITES') |
| 88 | # - oeqa/oetest.py and oeqa/runexport.py (this will get copied to exportpath not exportpath/oeqa) | 117 | tc.loadTests(test_paths, modules=test_modules) |
| 89 | # - __init__.py files | 118 | for f in getSuiteCasesFiles(tc.suites): |
| 90 | bb.utils.mkdirhier(os.path.join(exportpath, "oeqa/files")) | 119 | shutil.copy2(f, cases_path) |
| 91 | bb.utils.mkdirhier(os.path.join(exportpath, "oeqa/runtime/files")) | 120 | json_file = _get_json_file(f) |
| 92 | bb.utils.mkdirhier(os.path.join(exportpath, "oeqa/utils")) | 121 | if json_file: |
| 93 | # copy test modules, this should cover tests in other layers too | 122 | shutil.copy2(json_file, cases_path) |
| 94 | bbpath = d.getVar("BBPATH").split(':') | 123 | |
| 95 | for t in tc.testslist: | 124 | # Copy test data |
| 96 | isfolder = False | 125 | image_name = ("%s/%s" % (d.getVar('DEPLOY_DIR_IMAGE'), |
| 97 | if re.search("\w+\.\w+\.test_\S+", t): | 126 | d.getVar('IMAGE_LINK_NAME'))) |
| 98 | t = '.'.join(t.split('.')[:3]) | 127 | image_manifest = "%s.manifest" % image_name |
| 99 | mod = pkgutil.get_loader(t) | 128 | tdname = "%s.testdata.json" % image_name |
| 100 | # More depth than usual? | 129 | test_data_path = os.path.join(export_path, 'data') |
| 101 | if (t.count('.') > 2): | 130 | bb.utils.mkdirhier(test_data_path) |
| 102 | for p in bbpath: | 131 | shutil.copy2(image_manifest, os.path.join(test_data_path, 'manifest')) |
| 103 | foldername = os.path.join(p, 'lib', os.sep.join(t.split('.')).rsplit(os.sep, 1)[0]) | 132 | shutil.copy2(tdname, os.path.join(test_data_path, 'testdata.json')) |
| 104 | if os.path.isdir(foldername): | ||
| 105 | isfolder = True | ||
| 106 | target_folder = os.path.join(exportpath, "oeqa", "runtime", os.path.basename(foldername)) | ||
| 107 | if not os.path.exists(target_folder): | ||
| 108 | oe.path.copytree(foldername, target_folder) | ||
| 109 | if not isfolder: | ||
| 110 | shutil.copy2(mod.path, os.path.join(exportpath, "oeqa/runtime")) | ||
| 111 | json_file = "%s.json" % mod.path.rsplit(".", 1)[0] | ||
| 112 | if os.path.isfile(json_file): | ||
| 113 | shutil.copy2(json_file, os.path.join(exportpath, "oeqa/runtime")) | ||
| 114 | # Get meta layer | ||
| 115 | for layer in d.getVar("BBLAYERS").split(): | ||
| 116 | if os.path.basename(layer) == "meta": | ||
| 117 | meta_layer = layer | ||
| 118 | break | ||
| 119 | # copy oeqa/oetest.py and oeqa/runexported.py | ||
| 120 | oeqadir = os.path.join(meta_layer, "lib/oeqa") | ||
| 121 | shutil.copy2(os.path.join(oeqadir, "oetest.py"), os.path.join(exportpath, "oeqa")) | ||
| 122 | shutil.copy2(os.path.join(oeqadir, "runexported.py"), exportpath) | ||
| 123 | # copy oeqa/utils/*.py | ||
| 124 | for root, dirs, files in os.walk(os.path.join(oeqadir, "utils")): | ||
| 125 | for f in files: | ||
| 126 | if f.endswith(".py"): | ||
| 127 | shutil.copy2(os.path.join(root, f), os.path.join(exportpath, "oeqa/utils")) | ||
| 128 | # copy oeqa/files/* | ||
| 129 | for root, dirs, files in os.walk(os.path.join(oeqadir, "files")): | ||
| 130 | for f in files: | ||
| 131 | shutil.copy2(os.path.join(root, f), os.path.join(exportpath, "oeqa/files")) | ||
| 132 | # copy oeqa/runtime/files/* | ||
| 133 | for root, dirs, files in os.walk(os.path.join(oeqadir, "runtime/files")): | ||
| 134 | for f in files: | ||
| 135 | shutil.copy2(os.path.join(root, f), os.path.join(exportpath, "oeqa/runtime/files")) | ||
| 136 | 133 | ||
| 137 | # Create tar file for common parts of testexport | 134 | # Create tar file for common parts of testexport |
| 138 | create_tarball(d, "testexport.tar.gz", d.getVar("TEST_EXPORT_DIR")) | 135 | create_tarball(d, "testexport.tar.gz", d.getVar("TEST_EXPORT_DIR")) |
| 139 | 136 | ||
| 140 | # Copy packages needed for runtime testing | 137 | # Copy packages needed for runtime testing |
| 138 | package_extraction(d, tc.suites) | ||
| 141 | test_pkg_dir = d.getVar("TEST_NEEDED_PACKAGES_DIR") | 139 | test_pkg_dir = d.getVar("TEST_NEEDED_PACKAGES_DIR") |
| 142 | if os.listdir(test_pkg_dir): | 140 | if os.path.isdir(test_pkg_dir) and os.listdir(test_pkg_dir): |
| 143 | export_pkg_dir = os.path.join(d.getVar("TEST_EXPORT_DIR"), "packages") | 141 | export_pkg_dir = os.path.join(d.getVar("TEST_EXPORT_DIR"), "packages") |
| 144 | oe.path.copytree(test_pkg_dir, export_pkg_dir) | 142 | oe.path.copytree(test_pkg_dir, export_pkg_dir) |
| 145 | # Create tar file for packages needed by the DUT | 143 | # Create tar file for packages needed by the DUT |
| @@ -158,35 +156,7 @@ def exportTests(d,tc): | |||
| 158 | # Create tar file for the sdk | 156 | # Create tar file for the sdk |
| 159 | create_tarball(d, "testexport_sdk_%s.tar.gz" % d.getVar("SDK_ARCH"), export_sdk_dir) | 157 | create_tarball(d, "testexport_sdk_%s.tar.gz" % d.getVar("SDK_ARCH"), export_sdk_dir) |
| 160 | 158 | ||
| 161 | bb.plain("Exported tests to: %s" % exportpath) | 159 | bb.plain("Exported tests to: %s" % export_path) |
| 162 | |||
| 163 | def testexport_main(d): | ||
| 164 | from oeqa.oetest import ExportTestContext | ||
| 165 | from oeqa.targetcontrol import get_target_controller | ||
| 166 | |||
| 167 | test_create_extract_dirs(d) | ||
| 168 | export_dir = d.getVar("TEST_EXPORT_DIR") | ||
| 169 | bb.utils.mkdirhier(d.getVar("TEST_LOG_DIR")) | ||
| 170 | bb.utils.remove(export_dir, recurse=True) | ||
| 171 | bb.utils.mkdirhier(export_dir) | ||
| 172 | |||
| 173 | # the robot dance | ||
| 174 | target = get_target_controller(d) | ||
| 175 | |||
| 176 | # test context | ||
| 177 | tc = ExportTestContext(d, target) | ||
| 178 | |||
| 179 | # this is a dummy load of tests | ||
| 180 | # we are doing that to find compile errors in the tests themselves | ||
| 181 | # before booting the image | ||
| 182 | try: | ||
| 183 | tc.loadTests() | ||
| 184 | except Exception as e: | ||
| 185 | import traceback | ||
| 186 | bb.fatal("Loading tests failed:\n%s" % traceback.format_exc()) | ||
| 187 | |||
| 188 | tc.extract_packages() | ||
| 189 | exportTests(d,tc) | ||
| 190 | 160 | ||
| 191 | def create_tarball(d, tar_name, src_dir): | 161 | def create_tarball(d, tar_name, src_dir): |
| 192 | 162 | ||
| @@ -204,7 +174,4 @@ def create_tarball(d, tar_name, src_dir): | |||
| 204 | tar.close() | 174 | tar.close() |
| 205 | os.chdir(current_dir) | 175 | os.chdir(current_dir) |
| 206 | 176 | ||
| 207 | |||
| 208 | testexport_main[vardepsexclude] =+ "BB_ORIGENV" | ||
| 209 | |||
| 210 | inherit testimage | 177 | inherit testimage |
diff --git a/scripts/oe-test b/scripts/oe-test index 5731dff485..a1d282db33 100755 --- a/scripts/oe-test +++ b/scripts/oe-test | |||
| @@ -16,8 +16,14 @@ lib_path = scripts_path + '/lib' | |||
| 16 | sys.path = sys.path + [lib_path] | 16 | sys.path = sys.path + [lib_path] |
| 17 | import argparse_oe | 17 | import argparse_oe |
| 18 | import scriptutils | 18 | import scriptutils |
| 19 | import scriptpath | 19 | |
| 20 | scriptpath.add_oe_lib_path() | 20 | # oe-test is used for testexport and it doesn't have oe lib |
| 21 | # so we just skip adding these libraries (not used in testexport) | ||
| 22 | try: | ||
| 23 | import scriptpath | ||
| 24 | scriptpath.add_oe_lib_path() | ||
| 25 | except ImportError: | ||
| 26 | pass | ||
| 21 | 27 | ||
| 22 | from oeqa.core.context import OETestContextExecutor | 28 | from oeqa.core.context import OETestContextExecutor |
| 23 | 29 | ||
