diff_drive_nan_test.cpp
Go to the documentation of this file.
00001 
00002 // Copyright (C) 2014, PAL Robotics S.L.
00003 //
00004 // Redistribution and use in source and binary forms, with or without
00005 // modification, are permitted provided that the following conditions are met:
00006 //   * Redistributions of source code must retain the above copyright notice,
00007 //     this list of conditions and the following disclaimer.
00008 //   * Redistributions in binary form must reproduce the above copyright
00009 //     notice, this list of conditions and the following disclaimer in the
00010 //     documentation and/or other materials provided with the distribution.
00011 //   * Neither the name of PAL Robotics, Inc. nor the names of its
00012 //     contributors may be used to endorse or promote products derived from
00013 //     this software without specific prior written permission.
00014 //
00015 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00016 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00017 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00018 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00019 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00020 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00021 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00022 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00023 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00024 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00025 // POSSIBILITY OF SUCH DAMAGE.
00027 
00029 
00030 #include "test_common.h"
00031 
00032 // NaN
00033 #include <limits>
00034 
00035 // TEST CASES
00036 TEST_F(DiffDriveControllerTest, testNaN)
00037 {
00038   // wait for ROS
00039   while(!isControllerAlive())
00040   {
00041     ros::Duration(0.1).sleep();
00042   }
00043   // zero everything before test
00044   geometry_msgs::Twist cmd_vel;
00045   cmd_vel.linear.x = 0.0;
00046   cmd_vel.angular.z = 0.0;
00047   publish(cmd_vel);
00048   ros::Duration(2.0).sleep();
00049 
00050   // send a command
00051   cmd_vel.linear.x = 0.1;
00052   ros::Duration(2.0).sleep();
00053 
00054   // stop robot (will generate NaN)
00055   stop();
00056   ros::Duration(2.0).sleep();
00057 
00058   nav_msgs::Odometry odom = getLastOdom();
00059 
00060   EXPECT_NE(std::isnan(odom.twist.twist.linear.x), true);
00061   EXPECT_NE(std::isnan(odom.twist.twist.angular.z), true);
00062   EXPECT_NE(std::isnan(odom.pose.pose.position.x), true);
00063   EXPECT_NE(std::isnan(odom.pose.pose.position.y), true);
00064   EXPECT_NE(std::isnan(odom.pose.pose.orientation.z), true);
00065   EXPECT_NE(std::isnan(odom.pose.pose.orientation.w), true);
00066 
00067   // start robot
00068   start();
00069   ros::Duration(2.0).sleep();
00070 
00071   odom = getLastOdom();
00072 
00073   EXPECT_NE(std::isnan(odom.twist.twist.linear.x), true);
00074   EXPECT_NE(std::isnan(odom.twist.twist.angular.z), true);
00075   EXPECT_NE(std::isnan(odom.pose.pose.position.x), true);
00076   EXPECT_NE(std::isnan(odom.pose.pose.position.y), true);
00077   EXPECT_NE(std::isnan(odom.pose.pose.orientation.z), true);
00078   EXPECT_NE(std::isnan(odom.pose.pose.orientation.w), true);
00079 }
00080 
00081 int main(int argc, char** argv)
00082 {
00083   testing::InitGoogleTest(&argc, argv);
00084   ros::init(argc, argv, "diff_drive_nan_test");
00085 
00086   ros::AsyncSpinner spinner(1);
00087   spinner.start();
00088   int ret = RUN_ALL_TESTS();
00089   spinner.stop();
00090   ros::shutdown();
00091   return ret;
00092 }


diff_drive_controller
Author(s): Bence Magyar
autogenerated on Thu Jun 6 2019 18:58:48