4 # Copyright (c) 2013, Jouni Malinen <j@w1.fi>
6 # This software may be distributed under the terms of the BSD license.
7 # See README for more details.
14 from datetime import datetime
17 logger = logging.getLogger(__name__)
19 sys.path.append('../../wpaspy')
21 from wpasupplicant import WpaSupplicant
22 from hostapd import HostapdGlobal
24 def reset_devs(dev, apdev):
25 hapd = HostapdGlobal()
30 logger.info("Failed to reset device " + d.ifname)
33 hapd.remove(ap['ifname'])
35 def report(conn, build, commit, run, test, result, diff):
41 sql = "INSERT INTO results(test,result,run,time,duration,build,commitid) VALUES('" + test.replace('test_', '', 1) + "', '" + result + "', " + str(run) + ", " + str(time.time()) + ", " + str(diff.total_seconds()) + ", '" + build + "', '" + commit + "')"
46 print "sqlite: " + str(e)
60 if len(sys.argv) > 1 and sys.argv[1] == '-d':
61 logging.basicConfig(level=logging.DEBUG)
63 elif len(sys.argv) > 1 and sys.argv[1] == '-q':
64 logging.basicConfig(level=logging.WARNING)
67 elif len(sys.argv) > 2 and sys.argv[1] == '-l':
68 log_file = sys.argv[2]
69 logging.basicConfig(filename=log_file,level=logging.DEBUG)
72 logging.basicConfig(level=logging.INFO)
74 while len(sys.argv) > idx:
75 if len(sys.argv) > idx + 1 and sys.argv[idx] == '-e':
76 error_file = sys.argv[idx + 1]
78 elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-r':
79 results_file = sys.argv[idx + 1]
81 elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-f':
82 test_file = sys.argv[idx + 1]
84 elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-S':
85 conn = sqlite3.connect(sys.argv[idx + 1])
87 elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-b':
88 build = sys.argv[idx + 1]
94 run = str(int(time.time()))
96 with open("commit") as f:
99 commit = val[0].rstrip()
104 for t in os.listdir("."):
105 m = re.match(r'(test_.*)\.py$', t)
107 if test_file and test_file not in t:
109 logger.debug("Import test cases from " + t)
110 mod = __import__(m.group(1))
112 if s.startswith("test_"):
113 func = mod.__dict__.get(s)
116 if len(sys.argv) > idx and sys.argv[idx] == '-L':
118 print t.__name__ + " - " + t.__doc__
120 sql = 'INSERT OR REPLACE INTO tests(test,description) VALUES ("' + t.__name__.replace('test_', '', 1) + '", "' + t.__doc__ + '")';
124 print "sqlite: " + str(e)
131 if len(sys.argv) > idx:
132 test_filter = sys.argv[idx]
136 dev0 = WpaSupplicant('wlan0', '/tmp/wpas-wlan0')
137 dev1 = WpaSupplicant('wlan1', '/tmp/wpas-wlan1')
138 dev2 = WpaSupplicant('wlan2', '/tmp/wpas-wlan2')
139 dev = [ dev0, dev1, dev2 ]
141 apdev.append({"ifname": 'wlan3', "bssid": "02:00:00:00:03:00"})
142 apdev.append({"ifname": 'wlan4', "bssid": "02:00:00:00:04:00"})
146 logger.info(d.ifname + ": No response from wpa_supplicant")
148 logger.info("DEV: " + d.ifname + ": " + d.p2p_dev_addr())
150 logger.info("APDEV: " + ap['ifname'])
158 if test_filter != t.__name__:
160 reset_devs(dev, apdev)
161 logger.info("START " + t.__name__)
163 print "START " + t.__name__
166 logger.info("Test: " + t.__doc__)
167 start = datetime.now()
170 d.request("NOTE TEST-START " + t.__name__)
172 logger.info("Failed to issue TEST-START before " + t.__name__ + " for " + d.ifname)
174 print "FAIL " + t.__name__ + " - could not start test"
180 if t.func_code.co_argcount > 1:
187 skipped.append(t.__name__)
190 passed.append(t.__name__)
192 report(conn, build, commit, run, t.__name__, result, diff)
193 result = result + " " + t.__name__ + " "
194 result = result + str(diff.total_seconds()) + " " + str(end)
196 if log_file or print_res:
200 f = open(results_file, 'a')
201 f.write(result + "\n")
207 failed.append(t.__name__)
208 report(conn, build, commit, run, t.__name__, "FAIL", diff)
209 result = "FAIL " + t.__name__ + " " + str(diff.total_seconds()) + " " + str(end)
215 f = open(results_file, 'a')
216 f.write(result + "\n")
220 d.request("NOTE TEST-STOP " + t.__name__)
222 logger.info("Failed to issue TEST-STOP after " + t.__name__ + " for " + d.ifname)
226 reset_devs(dev, apdev)
232 logger.info("passed " + str(len(passed)) + " test case(s)")
233 logger.info("skipped " + str(len(skipped)) + " test case(s)")
234 logger.info("failed tests: " + str(failed))
236 f = open(error_file, 'w')
237 f.write(str(failed) + '\n')
240 logger.info("passed all " + str(len(passed)) + " test case(s)")
242 logger.info("skipped " + str(len(skipped)) + " test case(s)")
244 print "passed all " + str(len(passed)) + " test case(s)"
246 print "skipped " + str(len(skipped)) + " test case(s)"
248 if __name__ == "__main__":