test_latch.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 # Software License Agreement (BSD License)
3 #
4 # Copyright (c) 2008, Willow Garage, Inc.
5 # All rights reserved.
6 #
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions
9 # are met:
10 #
11 # * Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # * Redistributions in binary form must reproduce the above
14 # copyright notice, this list of conditions and the following
15 # disclaimer in the documentation and/or other materials provided
16 # with the distribution.
17 # * Neither the name of Willow Garage, Inc. nor the names of its
18 # contributors may be used to endorse or promote products derived
19 # from this software without specific prior written permission.
20 #
21 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 # POSSIBILITY OF SUCH DAMAGE.
33 
34 PKG = 'test_rospy'
35 NAME = 'test_latch'
36 
37 import sys
38 import time
39 import unittest
40 
41 from std_msgs.msg import String
42 
43 class TestLatch(unittest.TestCase):
44 
45  def setUp(self):
46  self.callback_invoked = {}
47  for i in range(0, 6):
48  self.callback_invoked[i] = False
49 
50  def callback_args(self, msg, i):
51  self.assertEquals('foo', msg.data)
52  self.callback_invoked[i] = True
53 
54  def callback(self, msg):
55  self.assertEquals('foo', msg.data)
56  self.callback_invoked[0] = True
57 
58  def test_latch(self):
59  import rospy
60 
61  # multi-part test. First check that we get latched message, then check
62  # that subscribers to same topic also receive latched message
63  # #1852
64  rospy.init_node(NAME)
65  s0 = rospy.Subscriber('s', String, self.callback)
66  # 20 seconds to receive first latched message
67  timeout_t = time.time() + 20.
68  print("waiting for 20 seconds")
69  while not self.callback_invoked[0] and \
70  not rospy.is_shutdown() and \
71  timeout_t > time.time():
72  time.sleep(0.2)
73 
74  self.failIf(timeout_t < time.time(), "timeout exceeded")
75  self.failIf(rospy.is_shutdown(), "node shutdown")
76  self.assert_(self.callback_invoked[0], "callback not invoked")
77 
78  # register three more callbacks, make sure they get invoked with message
79  # - callbacks are actually called inline, but in spirit of test, async callback is allowed
80  for i in range(1, 5):
81  self.failIf(self.callback_invoked[i])
82  s = rospy.Subscriber('s', String, self.callback_args, i)
83  timeout_t = time.time() + 0.5
84  while not self.callback_invoked[i] and \
85  not rospy.is_shutdown() and \
86  timeout_t > time.time():
87  time.sleep(0.1)
88  self.assert_(self.callback_invoked[i])
89 
90 if __name__ == '__main__':
91  import rostest
92  rostest.run(PKG, NAME, TestLatch, sys.argv)
def callback(self, msg)
Definition: test_latch.py:54
def test_latch(self)
Definition: test_latch.py:58
def callback_args(self, msg, i)
Definition: test_latch.py:50


test_rospy
Author(s): Ken Conley
autogenerated on Sun Feb 3 2019 03:30:22