diff options
Diffstat (limited to 'meta/lib')
| -rwxr-xr-x | meta/lib/oeqa/runexported.py | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/meta/lib/oeqa/runexported.py b/meta/lib/oeqa/runexported.py new file mode 100755 index 0000000000..e1b6642ec2 --- /dev/null +++ b/meta/lib/oeqa/runexported.py | |||
| @@ -0,0 +1,140 @@ | |||
| 1 | #!/usr/bin/env python | ||
| 2 | |||
| 3 | |||
| 4 | # Copyright (C) 2013 Intel Corporation | ||
| 5 | # | ||
| 6 | # Released under the MIT license (see COPYING.MIT) | ||
| 7 | |||
| 8 | # This script should be used outside of the build system to run image tests. | ||
| 9 | # It needs a json file as input as exported by the build. | ||
| 10 | # E.g for an already built image: | ||
| 11 | #- export the tests: | ||
| 12 | # TEST_EXPORT_ONLY = "1" | ||
| 13 | # TEST_TARGET = "simpleremote" | ||
| 14 | # TEST_TARGET_IP = "192.168.7.2" | ||
| 15 | # TEST_SERVER_IP = "192.168.7.1" | ||
| 16 | # bitbake core-image-sato -c testimage | ||
| 17 | # Setup your target, e.g for qemu: runqemu core-image-sato | ||
| 18 | # cd build/tmp/testimage/core-image-sato | ||
| 19 | # ./runexported.py testdata.json | ||
| 20 | |||
| 21 | import sys | ||
| 22 | import os | ||
| 23 | import time | ||
| 24 | from optparse import OptionParser | ||
| 25 | |||
| 26 | try: | ||
| 27 | import simplejson as json | ||
| 28 | except ImportError: | ||
| 29 | import json | ||
| 30 | |||
| 31 | sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), "oeqa"))) | ||
| 32 | |||
| 33 | from oeqa.oetest import runTests | ||
| 34 | from oeqa.utils.sshcontrol import SSHControl | ||
| 35 | |||
| 36 | # this isn't pretty but we need a fake target object | ||
| 37 | # for running the tests externally as we don't care | ||
| 38 | # about deploy/start we only care about the connection methods (run, copy) | ||
| 39 | class FakeTarget(object): | ||
| 40 | def __init__(self, d): | ||
| 41 | self.connection = None | ||
| 42 | self.ip = None | ||
| 43 | self.server_ip = None | ||
| 44 | self.datetime = time.strftime('%Y%m%d%H%M%S',time.gmtime()) | ||
| 45 | self.testdir = d.getVar("TEST_LOG_DIR", True) | ||
| 46 | self.pn = d.getVar("PN", True) | ||
| 47 | |||
| 48 | def exportStart(self): | ||
| 49 | self.sshlog = os.path.join(self.testdir, "ssh_target_log.%s" % self.datetime) | ||
| 50 | sshloglink = os.path.join(self.testdir, "ssh_target_log") | ||
| 51 | if os.path.islink(sshloglink): | ||
| 52 | os.unlink(sshloglink) | ||
| 53 | os.symlink(self.sshlog, sshloglink) | ||
| 54 | print("SSH log file: %s" % self.sshlog) | ||
| 55 | self.connection = SSHControl(self.ip, logfile=self.sshlog) | ||
| 56 | |||
| 57 | def run(self, cmd, timeout=None): | ||
| 58 | return self.connection.run(cmd, timeout) | ||
| 59 | |||
| 60 | def copy_to(self, localpath, remotepath): | ||
| 61 | return self.connection.copy_to(localpath, remotepath) | ||
| 62 | |||
| 63 | def copy_from(self, remotepath, localpath): | ||
| 64 | return self.connection.copy_from(remotepath, localpath) | ||
| 65 | |||
| 66 | |||
| 67 | class MyDataDict(dict): | ||
| 68 | def getVar(self, key, unused = None): | ||
| 69 | return self.get(key, "") | ||
| 70 | |||
| 71 | class TestContext(object): | ||
| 72 | def __init__(self): | ||
| 73 | self.d = None | ||
| 74 | self.target = None | ||
| 75 | |||
| 76 | def main(): | ||
| 77 | |||
| 78 | usage = "usage: %prog [options] <json file>" | ||
| 79 | parser = OptionParser(usage=usage) | ||
| 80 | parser.add_option("-t", "--target-ip", dest="ip", help="The IP address of the target machine. Use this to \ | ||
| 81 | overwrite the value determined from TEST_TARGET_IP at build time") | ||
| 82 | parser.add_option("-s", "--server-ip", dest="server_ip", help="The IP address of this machine. Use this to \ | ||
| 83 | overwrite the value determined from TEST_SERVER_IP at build time.") | ||
| 84 | parser.add_option("-d", "--deploy-dir", dest="deploy_dir", help="Full path to the package feeds, that this \ | ||
| 85 | the contents of what used to be DEPLOY_DIR on the build machine. If not specified it will use the value \ | ||
| 86 | specified in the json if that directory actually exists or it will error out.") | ||
| 87 | parser.add_option("-l", "--log-dir", dest="log_dir", help="This sets the path for TEST_LOG_DIR. If not specified \ | ||
| 88 | the current dir is used. This is used for usually creating a ssh log file and a scp test file.") | ||
| 89 | |||
| 90 | (options, args) = parser.parse_args() | ||
| 91 | if len(args) != 1: | ||
| 92 | parser.error("Incorrect number of arguments. The one and only argument should be a json file exported by the build system") | ||
| 93 | |||
| 94 | with open(args[0], "r") as f: | ||
| 95 | loaded = json.load(f) | ||
| 96 | |||
| 97 | if options.ip: | ||
| 98 | loaded["target"]["ip"] = options.ip | ||
| 99 | if options.server_ip: | ||
| 100 | loaded["target"]["server_ip"] = options.server_ip | ||
| 101 | |||
| 102 | d = MyDataDict() | ||
| 103 | for key in loaded["d"].keys(): | ||
| 104 | d[key] = loaded["d"][key] | ||
| 105 | |||
| 106 | if options.log_dir: | ||
| 107 | d["TEST_LOG_DIR"] = options.log_dir | ||
| 108 | else: | ||
| 109 | d["TEST_LOG_DIR"] = os.path.abspath(os.path.dirname(__file__)) | ||
| 110 | if options.deploy_dir: | ||
| 111 | d["DEPLOY_DIR"] = options.deploy_dir | ||
| 112 | else: | ||
| 113 | if not os.path.isdir(d["DEPLOY_DIR"]): | ||
| 114 | raise Exception("The path to DEPLOY_DIR does not exists: %s" % d["DEPLOY_DIR"]) | ||
| 115 | |||
| 116 | |||
| 117 | target = FakeTarget(d) | ||
| 118 | for key in loaded["target"].keys(): | ||
| 119 | setattr(target, key, loaded["target"][key]) | ||
| 120 | |||
| 121 | tc = TestContext() | ||
| 122 | setattr(tc, "d", d) | ||
| 123 | setattr(tc, "target", target) | ||
| 124 | for key in loaded.keys(): | ||
| 125 | if key != "d" and key != "target": | ||
| 126 | setattr(tc, key, loaded[key]) | ||
| 127 | |||
| 128 | target.exportStart() | ||
| 129 | runTests(tc) | ||
| 130 | |||
| 131 | return 0 | ||
| 132 | |||
| 133 | if __name__ == "__main__": | ||
| 134 | try: | ||
| 135 | ret = main() | ||
| 136 | except Exception: | ||
| 137 | ret = 1 | ||
| 138 | import traceback | ||
| 139 | traceback.print_exc(5) | ||
| 140 | sys.exit(ret) | ||
