Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 """
00031 RSDK Smoke Test Execution
00032 """
00033 import sys
00034 import time
00035 import argparse
00036 import re
00037 import socket
00038 import traceback
00039
00040 import rospy
00041
00042 from baxter_tools import smoketests
00043
00044
00045 def run_test(tname, fname, proceed):
00046 """
00047 Execution of the tests where starting, finishing and error handeling
00048 occurs.
00049 """
00050 try:
00051 cur_test = getattr(smoketests, tname)(tname)
00052 except AttributeError:
00053 print("Exiting: %s is not a valid smoke test." % tname)
00054 sys.exit(1)
00055 except:
00056 print("Exiting: failed during intialization.")
00057 traceback.print_exc()
00058 sys.exit(1)
00059
00060 cur_test.start_test()
00061 cur_test.finish_test(fname)
00062 if (not proceed and cur_test.result[0] == False or
00063 'KeyboardInterrupt' in cur_test.result[1]):
00064 print("Exiting: Failed Test %s" % tname)
00065 sys.exit(1)
00066
00067
00068 def test_help():
00069 """
00070 Help text for argparse describing available sdk tests.
00071 """
00072 return """Specify an individual test for execution
00073 TESTS:
00074 Enable - Verify ability to enable, check state and disable baxter
00075 Messages - Verify messages being published and ability to subscribe
00076 Services - Verify services available and ability to make calls as client
00077 Head - Move the head pan and tilt, display image to screen
00078 MoveArms - Move both arms through entire joint range
00079 Grippers - Calibrate and move grippers using position and velocity control
00080 BlinkLEDs - Blink Navigator LEDs
00081 Cameras - Verify camera publishing and visualization
00082 """
00083
00084
00085 def get_version():
00086 """
00087 Get current software version number from param server.
00088 """
00089 try:
00090 version = rospy.get_param('/rethink/software_version').split('_')[0]
00091 except socket.error:
00092 print("Exiting: Could not communicate with ROS Master to determine " +
00093 "Software version")
00094 sys.exit(1)
00095 except:
00096 print("Exiting: Could not determine SW version from param " +
00097 "'/rethink/software_version'")
00098 sys.exit(1)
00099 return version
00100
00101
00102 def ros_init():
00103 """
00104 Initialize rsdk_smoke_test ros node.
00105 """
00106 print("Initializing node 'rsdk_smoke_test'\n")
00107 rospy.init_node('rsdk_smoke_test', disable_signals=True)
00108
00109
00110 def main():
00111 format = argparse.RawTextHelpFormatter
00112 parser = argparse.ArgumentParser(formatter_class=format)
00113 parser.add_argument('-p', '--proceed', action='store_true',
00114 help="Continue testing after a failed test until all tests complete")
00115 parser.add_argument('-t', '--test', help=test_help())
00116 args = parser.parse_args(rospy.myargv()[1:])
00117
00118 test_dict = {
00119 'version': None,
00120 'valid_tests': {
00121 '0.7.0': ['Enable', 'Messages', 'Services', 'Head', 'BlinkLEDs',
00122 'Cameras'],
00123 '1.0.0': ['Enable', 'Messages', 'Services', 'Head', 'MoveArms',
00124 'Grippers', 'BlinkLEDs', 'Cameras'],
00125 }
00126 }
00127
00128 test_dict['version'] = get_version()
00129 if not test_dict['version'] in test_dict['valid_tests'].keys():
00130 print("Exiting: No tests specified for your software version: %s" %
00131 (test_dict['version']))
00132 return 1
00133
00134 try:
00135 raw_input("Press <Enter> to Begin Smoke Test\n")
00136 except Exception:
00137 print("\nExiting.")
00138 return 1
00139
00140 serial = rospy.get_param("manifest/robot_serial")
00141 cur_time = time.localtime()
00142 filename = ("%s-%s.%s.%s-rsdk-%s.smoketest" %
00143 (serial, cur_time.tm_mon, cur_time.tm_mday,
00144 cur_time.tm_year, test_dict['version'],)
00145 )
00146 if args.test == None:
00147 print 'Performing All Tests'
00148 ros_init()
00149 for t in test_dict['valid_tests'][test_dict['version']]:
00150 run_test(t, filename, args.proceed)
00151 elif args.test in test_dict['valid_tests'][test_dict['version']]:
00152 ros_init()
00153 run_test(args.test, filename, args.proceed)
00154 else:
00155 print("Exiting: Invalid test provided: %s for %s version software" %
00156 (args.test, test_dict['version']))
00157 parser.print_help()
00158
00159 return 0
00160
00161 if __name__ == '__main__':
00162 sys.exit(main())