run-tests.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. #!/usr/bin/python
  2. #
  3. # AP tests
  4. # Copyright (c) 2013, Jouni Malinen <j@w1.fi>
  5. #
  6. # This software may be distributed under the terms of the BSD license.
  7. # See README for more details.
  8. import os
  9. import re
  10. import sys
  11. import time
  12. from datetime import datetime
  13. import logging
  14. logger = logging.getLogger(__name__)
  15. from wpasupplicant import WpaSupplicant
  16. from hostapd import HostapdGlobal
  17. def reset_devs(dev, apdev):
  18. hapd = HostapdGlobal()
  19. for d in dev:
  20. try:
  21. d.reset()
  22. except Exception, e:
  23. logger.info("Failed to reset device " + d.ifname)
  24. print str(e)
  25. for ap in apdev:
  26. hapd.remove(ap['ifname'])
  27. def main():
  28. test_file = None
  29. error_file = None
  30. log_file = None
  31. results_file = None
  32. idx = 1
  33. print_res = False
  34. if len(sys.argv) > 1 and sys.argv[1] == '-d':
  35. logging.basicConfig(level=logging.DEBUG)
  36. idx = idx + 1
  37. elif len(sys.argv) > 1 and sys.argv[1] == '-q':
  38. logging.basicConfig(level=logging.WARNING)
  39. print_res = True
  40. idx = idx + 1
  41. elif len(sys.argv) > 2 and sys.argv[1] == '-l':
  42. log_file = sys.argv[2]
  43. logging.basicConfig(filename=log_file,level=logging.DEBUG)
  44. idx = idx + 2
  45. else:
  46. logging.basicConfig(level=logging.INFO)
  47. while len(sys.argv) > idx:
  48. if len(sys.argv) > idx + 1 and sys.argv[idx] == '-e':
  49. error_file = sys.argv[idx + 1]
  50. idx = idx + 2
  51. elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-r':
  52. results_file = sys.argv[idx + 1]
  53. idx = idx + 2
  54. elif len(sys.argv) > idx + 1 and sys.argv[idx] == '-f':
  55. test_file = sys.argv[idx + 1]
  56. idx = idx + 2
  57. else:
  58. break
  59. tests = []
  60. for t in os.listdir("."):
  61. m = re.match(r'(test_.*)\.py$', t)
  62. if m:
  63. if test_file and test_file not in t:
  64. continue
  65. logger.debug("Import test cases from " + t)
  66. mod = __import__(m.group(1))
  67. for s in dir(mod):
  68. if s.startswith("test_"):
  69. func = mod.__dict__.get(s)
  70. tests.append(func)
  71. if len(sys.argv) > 1 and sys.argv[1] == '-L':
  72. for t in tests:
  73. print t.__name__ + " - " + t.__doc__
  74. sys.exit(0)
  75. if len(sys.argv) > idx:
  76. test_filter = sys.argv[idx]
  77. else:
  78. test_filter = None
  79. dev0 = WpaSupplicant('wlan0', '/tmp/wpas-wlan0')
  80. dev1 = WpaSupplicant('wlan1', '/tmp/wpas-wlan1')
  81. dev2 = WpaSupplicant('wlan2', '/tmp/wpas-wlan2')
  82. dev = [ dev0, dev1, dev2 ]
  83. apdev = [ ]
  84. apdev.append({"ifname": 'wlan3', "bssid": "02:00:00:00:03:00"})
  85. apdev.append({"ifname": 'wlan4', "bssid": "02:00:00:00:04:00"})
  86. for d in dev:
  87. if not d.ping():
  88. logger.info(d.ifname + ": No response from wpa_supplicant")
  89. return
  90. logger.info("DEV: " + d.ifname + ": " + d.p2p_dev_addr())
  91. for ap in apdev:
  92. logger.info("APDEV: " + ap['ifname'])
  93. passed = []
  94. skipped = []
  95. failed = []
  96. for t in tests:
  97. if test_filter:
  98. if test_filter != t.__name__:
  99. continue
  100. reset_devs(dev, apdev)
  101. logger.info("START " + t.__name__)
  102. if log_file:
  103. print "START " + t.__name__
  104. if t.__doc__:
  105. logger.info("Test: " + t.__doc__)
  106. start = datetime.now()
  107. for d in dev:
  108. try:
  109. d.request("NOTE TEST-START " + t.__name__)
  110. except Exception, e:
  111. logger.info("Failed to issue TEST-START before " + t.__name__ + " for " + d.ifname)
  112. logger.info(e)
  113. try:
  114. if t.func_code.co_argcount > 1:
  115. res = t(dev, apdev)
  116. else:
  117. res = t(dev)
  118. end = datetime.now()
  119. diff = end - start
  120. if res == "skip":
  121. skipped.append(t.__name__)
  122. result = "SKIP "
  123. else:
  124. passed.append(t.__name__)
  125. result = "PASS "
  126. result = result + t.__name__ + " "
  127. result = result + str(diff.total_seconds()) + " " + str(end)
  128. logger.info(result)
  129. if log_file or print_res:
  130. print result
  131. if results_file:
  132. f = open(results_file, 'a')
  133. f.write(result + "\n")
  134. f.close()
  135. except Exception, e:
  136. end = datetime.now()
  137. diff = end - start
  138. logger.info(e)
  139. failed.append(t.__name__)
  140. result = "FAIL " + t.__name__ + " " + str(diff.total_seconds()) + " " + str(end)
  141. logger.info(result)
  142. if log_file:
  143. print result
  144. if results_file:
  145. f = open(results_file, 'a')
  146. f.write(result + "\n")
  147. f.close()
  148. for d in dev:
  149. try:
  150. d.request("NOTE TEST-STOP " + t.__name__)
  151. except Exception, e:
  152. logger.info("Failed to issue TEST-STOP after " + t.__name__ + " for " + d.ifname)
  153. logger.info(e)
  154. if not test_filter:
  155. reset_devs(dev, apdev)
  156. if len(failed):
  157. logger.info("passed " + str(len(passed)) + " test case(s)")
  158. logger.info("skipped " + str(len(skipped)) + " test case(s)")
  159. logger.info("failed tests: " + str(failed))
  160. if error_file:
  161. f = open(error_file, 'w')
  162. f.write(str(failed) + '\n')
  163. f.close()
  164. sys.exit(1)
  165. logger.info("passed all " + str(len(passed)) + " test case(s)")
  166. if len(skipped):
  167. logger.info("skipped " + str(len(skipped)) + " test case(s)")
  168. if log_file:
  169. print "passed all " + str(len(passed)) + " test case(s)"
  170. if len(skipped):
  171. print "skipped " + str(len(skipped)) + " test case(s)"
  172. if __name__ == "__main__":
  173. main()