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.
13 from datetime import datetime
16 logger = logging.getLogger(__name__)
18 from wpasupplicant import WpaSupplicant
19 from hostapd import HostapdGlobal
21 def reset_devs(dev, apdev):
22 hapd = HostapdGlobal()
27 logger.info("Failed to reset device " + d.ifname)
30 hapd.remove(ap['ifname'])
39 if len(sys.argv) > 1 and sys.argv[1] == '-d':
40 logging.basicConfig(level=logging.DEBUG)
42 elif len(sys.argv) > 1 and sys.argv[1] == '-q':
43 logging.basicConfig(level=logging.WARNING)
46 elif len(sys.argv) > 2 and sys.argv[1] == '-l':
47 log_file = sys.argv[2]
48 logging.basicConfig(filename=log_file,level=logging.DEBUG)
51 logging.basicConfig(level=logging.INFO)
53 while len(sys.argv) > idx:
54 if len(sys.argv) > idx + 1 and sys.argv[idx] == '-e':
55 error_file = sys.argv[idx + 1]
57 elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-r':
58 results_file = sys.argv[idx + 1]
60 elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-f':
61 test_file = sys.argv[idx + 1]
67 for t in os.listdir("."):
68 m = re.match(r'(test_.*)\.py$', t)
70 if test_file and test_file not in t:
72 logger.debug("Import test cases from " + t)
73 mod = __import__(m.group(1))
75 if s.startswith("test_"):
76 func = mod.__dict__.get(s)
79 if len(sys.argv) > 1 and sys.argv[1] == '-L':
81 print t.__name__ + " - " + t.__doc__
84 if len(sys.argv) > idx:
85 test_filter = sys.argv[idx]
89 dev0 = WpaSupplicant('wlan0', '/tmp/wpas-wlan0')
90 dev1 = WpaSupplicant('wlan1', '/tmp/wpas-wlan1')
91 dev2 = WpaSupplicant('wlan2', '/tmp/wpas-wlan2')
92 dev = [ dev0, dev1, dev2 ]
94 apdev.append({"ifname": 'wlan3', "bssid": "02:00:00:00:03:00"})
95 apdev.append({"ifname": 'wlan4', "bssid": "02:00:00:00:04:00"})
99 logger.info(d.ifname + ": No response from wpa_supplicant")
101 logger.info("DEV: " + d.ifname + ": " + d.p2p_dev_addr())
103 logger.info("APDEV: " + ap['ifname'])
111 if test_filter != t.__name__:
113 reset_devs(dev, apdev)
114 logger.info("START " + t.__name__)
116 print "START " + t.__name__
119 logger.info("Test: " + t.__doc__)
120 start = datetime.now()
123 d.request("NOTE TEST-START " + t.__name__)
125 logger.info("Failed to issue TEST-START before " + t.__name__ + " for " + d.ifname)
127 print "FAIL " + t.__name__ + " - could not start test"
130 if t.func_code.co_argcount > 1:
137 skipped.append(t.__name__)
140 passed.append(t.__name__)
142 result = result + t.__name__ + " "
143 result = result + str(diff.total_seconds()) + " " + str(end)
145 if log_file or print_res:
149 f = open(results_file, 'a')
150 f.write(result + "\n")
156 failed.append(t.__name__)
157 result = "FAIL " + t.__name__ + " " + str(diff.total_seconds()) + " " + str(end)
163 f = open(results_file, 'a')
164 f.write(result + "\n")
168 d.request("NOTE TEST-STOP " + t.__name__)
170 logger.info("Failed to issue TEST-STOP after " + t.__name__ + " for " + d.ifname)
174 reset_devs(dev, apdev)
177 logger.info("passed " + str(len(passed)) + " test case(s)")
178 logger.info("skipped " + str(len(skipped)) + " test case(s)")
179 logger.info("failed tests: " + str(failed))
181 f = open(error_file, 'w')
182 f.write(str(failed) + '\n')
185 logger.info("passed all " + str(len(passed)) + " test case(s)")
187 logger.info("skipped " + str(len(skipped)) + " test case(s)")
189 print "passed all " + str(len(passed)) + " test case(s)"
191 print "skipped " + str(len(skipped)) + " test case(s)"
193 if __name__ == "__main__":