subscribe_resubscribe.cpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2008, Willow Garage, Inc.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * * Neither the name of Willow Garage, Inc. nor the names of its
14  * contributors may be used to endorse or promote products derived from
15  * this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 /* Author: Brian Gerkey */
31 
32 /*
33  * Subscribe to a topic, expecting to get a single message.
34  */
35 
36 #include <string>
37 
38 #include <gtest/gtest.h>
39 
40 #include <time.h>
41 #include <stdlib.h>
42 
43 #include "ros/ros.h"
44 #include <test_roscpp/TestArray.h>
45 
46 int g_argc;
47 char** g_argv;
48 
49 class Subscriptions : public testing::Test
50 {
51  public:
52  bool success;
53  bool failure;
54  int msg_count;
55  int msg_i;
57 
58  void messageCallback(const test_roscpp::TestArrayConstPtr& msg)
59  {
60  if(failure || success)
61  return;
62 
63  ROS_INFO("received message %d", msg->counter);
64  msg_i++;
65  if(msg_i != msg->counter)
66  {
67  failure = true;
68  ROS_INFO("failed");
69  }
70  if(msg_i == (msg_count-1))
71  {
72  success = true;
73  ROS_INFO("success");
74  }
75  }
76 
77  protected:
79  void SetUp()
80  {
81  success = false;
82  failure = false;
83 
84  msg_i = -1;
85  ASSERT_TRUE(g_argc == 3);
86  msg_count = atoi(g_argv[1]);
87  dt.fromSec(atof(g_argv[2]));
88  }
89  void TearDown()
90  {
91  }
92 };
93 
94 TEST_F(Subscriptions, resubscribe)
95 {
96  ros::NodeHandle nh;
97 
98  {
99  ros::Subscriber sub = nh.subscribe("roscpp/pubsub_test", 0, &Subscriptions::messageCallback, (Subscriptions*)this);
100  ASSERT_TRUE(sub);
101  ros::Time t1(ros::Time::now()+dt);
102 
103  while(ros::Time::now() < t1 && !success)
104  {
105  ros::WallDuration(0.01).sleep();
106  ros::spinOnce();
107  }
108  }
109 
110  if(!success)
111  FAIL();
112  else
113  {
114  success = false;
115  failure = false;
116  msg_i = -1;
117 
118  {
119  ros::Subscriber sub = nh.subscribe("roscpp/pubsub_test2", 0, &Subscriptions::messageCallback, (Subscriptions*)this);
120  ASSERT_TRUE(sub);
121  ros::Time t1(ros::Time::now()+dt);
122 
123  while(ros::Time::now() < t1 && !success)
124  {
125  ros::WallDuration(0.01).sleep();
126  ros::spinOnce();
127  }
128  }
129 
130  if(success)
131  SUCCEED();
132  else
133  FAIL();
134  }
135 }
136 
137 int
138 main(int argc, char** argv)
139 {
140  ros::init(argc, argv, "subscribe_resubscribe");
141  ros::NodeHandle nh;
142 
143  testing::InitGoogleTest(&argc, argv);
144  g_argc = argc;
145  g_argv = argv;
146  return RUN_ALL_TESTS();
147 }
ros::WallDuration::sleep
bool sleep() const
Subscriptions::dt
ros::Duration dt
Definition: subscribe_empty.cpp:57
DurationBase< Duration >::fromSec
Duration & fromSec(double t)
Subscriptions::messageCallback
void messageCallback(const test_roscpp::TestArrayConstPtr &msg)
Definition: subscribe_resubscribe.cpp:58
Subscriptions::Subscriptions
Subscriptions()
Definition: subscribe_resubscribe.cpp:78
TEST_F
TEST_F(Subscriptions, resubscribe)
Definition: subscribe_resubscribe.cpp:94
ros::init
ROSCPP_DECL void init(const M_string &remappings, const std::string &name, uint32_t options=0)
ros.h
time.h
Subscriptions::msg_i
int msg_i
Definition: sub_pub.cpp:56
ros::spinOnce
ROSCPP_DECL void spinOnce()
g_argc
int g_argc
Definition: subscribe_resubscribe.cpp:46
Subscriptions::TearDown
void TearDown()
Definition: subscribe_resubscribe.cpp:89
Subscriptions::success
bool success
Definition: sub_pub.cpp:54
failure
bool failure
Definition: publish_unadvertise.cpp:45
Subscriptions
Definition: multiple_subscriptions.cpp:45
Subscriptions::failure
bool failure
Definition: sub_pub.cpp:55
Subscriptions::SetUp
void SetUp()
Definition: subscribe_resubscribe.cpp:79
ros::NodeHandle::subscribe
Subscriber subscribe(const std::string &topic, uint32_t queue_size, const boost::function< void(C)> &callback, const VoidConstPtr &tracked_object=VoidConstPtr(), const TransportHints &transport_hints=TransportHints())
g_argv
char ** g_argv
Definition: subscribe_resubscribe.cpp:47
ros::Time
main
int main(int argc, char **argv)
Definition: subscribe_resubscribe.cpp:138
Subscriptions::msg
test_roscpp::TestEmpty msg
Definition: subscribe_empty.cpp:52
ros::WallDuration
ROS_INFO
#define ROS_INFO(...)
Subscriptions::msg_count
int msg_count
Definition: subscribe_empty.cpp:55
ros::Duration
ros::NodeHandle
ros::Subscriber
ros::Time::now
static Time now()


test_roscpp
Author(s): Morgan Quigley, Josh Faust, Brian Gerkey, Troy Straszheim, Dirk Thomas , Jacob Perron
autogenerated on Thu Nov 23 2023 04:02:02