check_initial_pose.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 
3 # Copyright (c) 2020 Kei Okada
4 # All rights reserved.
5 #
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions are met:
8 #
9 # 1. Redistributions of source code must retain the above copyright notice,
10 # this list of conditions and the following disclaimer.
11 # 2. Redistributions in binary form must reproduce the above copyright
12 # notice, this list of conditions and the following disclaimer in the
13 # documentation and/or other materials provided with the distribution.
14 # 3. Neither the name of the Rethink Robotics nor the names of its
15 # contributors may be used to endorse or promote products derived from
16 # this software without specific prior written permission.
17 #
18 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19 # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
22 # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 # POSSIBILITY OF SUCH DAMAGE.
29 
30 import unittest
31 import rospy
32 import time
33 from nav_msgs.msg import Odometry
34 from std_srvs.srv import Empty
35 from tf.transformations import euler_from_quaternion
36 
37 
38 class TestInitialPose(unittest.TestCase):
39 
40  @classmethod
41  def setUpClass(self):
42  rospy.init_node('test_initial_pose', anonymous=True)
43  self.base_success = False
44 
45  def base_link_cb(self, msg):
46  p = msg.pose.pose.position
47  r = msg.pose.pose.orientation
48  pos = [p.x, p.y, p.z]
49  rot = euler_from_quaternion([r.x, r.y, r.z, r.w])
50 
51  rospy.loginfo("pos: {:6.3f} {:6.3f} {:6.3f} - ".format(pos[0], pos[1], pos[2]) +
52  "rot: {:6.3f} {:6.3f} {:6.3f}".format(rot[0], rot[1], rot[2]))
53 
54  # check position
55  if (abs(pos[0]) < 1.0 and abs(pos[1]) < 1.0 and abs(pos[2]) < 1.0 and
56  abs(rot[0]) < 0.5 and abs(rot[1]) < 0.5 and abs(rot[2]) < 0.5):
57  self.base_success = True
58 
59  def test_initial_pose(self):
60  rospy.Subscriber("/base_link_ground_truth", Odometry, self.base_link_cb)
61  timeout_t = time.time() + 15
62  while not rospy.is_shutdown() and not self.base_success and time.time() < timeout_t:
63  time.sleep(1.0)
64  self.assertTrue(self.base_success)
65 
66 
67 if __name__ == '__main__':
68  import rostest
69  rostest.rosrun('gundam_rx78_gazebo', 'test_initial_pose', TestInitialPose)


gundam_rx78_gazebo
Author(s): Kei Okada
autogenerated on Wed Sep 2 2020 03:33:39