00001 #!/usr/bin/env python 00002 # Software License Agreement (BSD License) 00003 # 00004 # Copyright (c) 2008, Willow Garage, Inc. 00005 # All rights reserved. 00006 # 00007 # Redistribution and use in source and binary forms, with or without 00008 # modification, are permitted provided that the following conditions 00009 # are met: 00010 # 00011 # * Redistributions of source code must retain the above copyright 00012 # notice, this list of conditions and the following disclaimer. 00013 # * Redistributions in binary form must reproduce the above 00014 # copyright notice, this list of conditions and the following 00015 # disclaimer in the documentation and/or other materials provided 00016 # with the distribution. 00017 # * Neither the name of the Willow Garage nor the names of its 00018 # contributors may be used to endorse or promote products derived 00019 # from this software without specific prior written permission. 00020 # 00021 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00022 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00023 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00024 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 00025 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00026 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00027 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00028 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00029 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00030 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 00031 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00032 # POSSIBILITY OF SUCH DAMAGE. 00033 # 00034 00035 ## Gazebo test arm controller 00036 ## sends posision 00037 ## checks to see if P3D returns corresponding ground truth within TARGET_TOL of TARGET_VW 00038 ## for a duration of TARGET_DURATION seconds 00039 00040 PKG = 'pr2_gazebo' 00041 NAME = 'my_hztest' 00042 00043 import math 00044 import roslib 00045 roslib.load_manifest(PKG) 00046 roslib.load_manifest('rostest') 00047 00048 import sys, unittest 00049 import os, os.path, threading, time 00050 import rospy, rostest 00051 from std_msgs.msg import * 00052 from tf.msg import tfMessage 00053 from pr2_mechanism_msgs.msg import MechanismState 00054 00055 MIN_MSGS = 100 00056 TEST_TIMEOUT = 100000000000.0 00057 00058 class MyHzTest(unittest.TestCase): 00059 def __init__(self, *args): 00060 super(MyHzTest, self).__init__(*args) 00061 self.success = False 00062 self.count = 0 00063 00064 #for time tracking 00065 self.started = False 00066 self.start_time = 0 00067 self.end_time = 0 00068 00069 def Input(self, msg): 00070 self.count += 1; 00071 00072 if not self.started: 00073 self.start_time = rospy.get_rostime().to_sec() 00074 print " got first message at: ",self.start_time, " sec" 00075 self.started = True 00076 00077 if self.count >= MIN_MSGS: 00078 self.end_time = rospy.get_rostime().to_sec() 00079 print " passed minimum ",self.count," messages at ",self.count / (self.end_time - self.start_time), " Hz" 00080 self.success = True 00081 #else: 00082 #print " got ",self.count," messages at ",self.count / (rospy.get_rostime().to_sec() - self.start_time), " Hz" 00083 00084 def test_hz(self): 00085 print "LNK\n" 00086 #rospy.Subscriber("/tf", tfMessage, self.Input) 00087 rospy.Subscriber("/mechanism_state", MechanismState, self.Input) 00088 rospy.init_node(NAME, anonymous=True) 00089 timeout_t = time.time() + TEST_TIMEOUT 00090 while not rospy.is_shutdown() and not self.success and time.time() < timeout_t: 00091 time.sleep(1.0) 00092 00093 self.assert_(self.success) 00094 00095 if __name__ == '__main__': 00096 rostest.run(PKG, sys.argv[0], MyHzTest, sys.argv) #, text_mode=True) 00097