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 base controller vw 00036 00037 PKG = 'pr2_gazebo' 00038 NAME = 'test_base_odomx_gt' 00039 00040 import math 00041 import roslib 00042 roslib.load_manifest(PKG) 00043 00044 import sys, unittest 00045 import os, time 00046 import rospy, rostest 00047 00048 from geometry_msgs.msg import Twist,Vector3 00049 from nav_msgs.msg import Odometry 00050 00051 TEST_DURATION = 10.0 00052 00053 TARGET_VX = 0.5 00054 TARGET_VY = 0.0 00055 TARGET_VW = 0.0 00056 TARGET_DURATION = 2.0 00057 TARGET_TOL = 0.2 00058 00059 from test_base import BaseTest, E, Q 00060 class X_GT(BaseTest): 00061 def __init__(self, *args): 00062 super(X_GT, self).__init__(*args) 00063 00064 def test_base(self): 00065 self.init_ros(NAME) 00066 timeout_t = time.time() + TEST_DURATION 00067 while not rospy.is_shutdown() and not self.success and time.time() < timeout_t: 00068 #do not start commanding base until p3d and odom are initialized 00069 if self.p3d_initialized == True and self.odom_initialized == True: 00070 self.pub.publish(Twist(Vector3(TARGET_VX,TARGET_VY, 0), Vector3(0,0,TARGET_VW))) 00071 time.sleep(0.1) 00072 #self.debug_pos() 00073 # display what the odom error is 00074 print " error " + " x: " + str(self.odom_x - self.p3d_x) + " y: " + str(self.odom_y - self.p3d_y) + " t: " + str(self.odom_t - self.p3d_t) 00075 00076 # check total error 00077 total_error = abs(self.odom_x - self.p3d_x) + abs(self.odom_y - self.p3d_y) + abs(self.odom_t - self.p3d_t) 00078 if total_error < TARGET_TOL: 00079 self.success = True 00080 00081 self.assert_(self.success) 00082 00083 if __name__ == '__main__': 00084 rostest.run(PKG, sys.argv[0], X_GT, sys.argv) #, text_mode=True) 00085 00086