18 #include <gtest/gtest.h> 19 #include <gmock/gmock.h> 26 #include <condition_variable> 31 #include <std_srvs/SetBool.h> 32 #include <std_srvs/Trigger.h> 33 #include <std_msgs/Bool.h> 35 #include <modbus/modbus.h> 37 #include <pilz_msgs/IsBrakeTestRequired.h> 38 #include <pilz_msgs/IsBrakeTestRequiredResult.h> 40 #include <prbt_hardware_support/ModbusMsgInStamped.h> 44 #include <prbt_hardware_support/WriteModbusRegister.h> 50 #include <pilz_testutils/async_test.h> 54 using namespace modbus_api::v3;
57 using ::testing::InSequence;
58 using ::testing::Invoke;
59 using ::testing::InvokeWithoutArgs;
75 MOCK_METHOD2(modbusWrite,
bool(WriteModbusRegister::Request&, WriteModbusRegister::Response&));
82 &BrakeTestRequiredIntegrationTest::modbusWrite,
this) };
85 ::testing::AssertionResult
87 pilz_msgs::IsBrakeTestRequiredResult::_value_type expectation,
90 pilz_msgs::IsBrakeTestRequired srv;
91 for (
int i = 0; i <= retries; i++)
93 auto res = brake_test_required_client.
call(srv);
96 return ::testing::AssertionFailure() <<
"Could not call service";
98 if (srv.response.result.value == expectation)
100 return ::testing::AssertionSuccess() <<
"It took " << i + 1 <<
" tries for the service call.";
104 return ::testing::AssertionFailure() <<
"Did not get expected brake test result via service";
139 ASSERT_TRUE(nh_priv_.getParam(
"modbus_server_ip", ip));
140 ASSERT_TRUE(nh_priv_.getParam(
"modbus_server_port", port));
151 std::thread modbus_server_thread(&initalizeAndRun<prbt_hardware_support::PilzModbusServerMock>,
152 std::ref(modbus_server), ip.c_str(),
static_cast<unsigned int>(port));
173 pilz_msgs::IsBrakeTestRequiredResult::REQUIRED));
184 pilz_msgs::IsBrakeTestRequiredResult::REQUIRED));
192 pilz_msgs::IsBrakeTestRequiredResult::NOT_REQUIRED));
198 modbus_server_thread.join();
203 int main(
int argc,
char* argv[])
205 ros::init(argc, argv,
"integrationtest_brake_test_required");
208 testing::InitGoogleTest(&argc, argv);
209 return RUN_ALL_TESTS();
::testing::AssertionResult expectBrakeTestRequiredServiceCallResult(ros::ServiceClient &brake_test_required_client, pilz_msgs::IsBrakeTestRequiredResult::_value_type expectation, uint16_t retries=DEFAULT_RETRIES)
static const std::string BRAKETEST_REQUEST
Offers a modbus server and read/write functionality via subscription/publication. ...
TEST_F(BrakeTestRequiredIntegrationTest, testBrakeTestAnnouncement)
int main(int argc, char *argv[])
void setHoldingRegister(std::initializer_list< std::pair< unsigned int, uint16_t > > reg_list)
ROSCPP_DECL void init(int &argc, char **argv, const std::string &name, uint32_t options=0)
bool call(MReq &req, MRes &res)
unsigned short getMaxRegisterDefinition() const
static const std::string MODBUS_SERVICE_NAME
ServiceServer advertiseService(const std::string &service, bool(T::*srv_func)(MReq &, MRes &), T *obj)
static constexpr uint16_t MODBUS_API_VERSION_REQUIRED
static const std::string SERVICE_BRAKETEST_REQUIRED
static const std::string RUN_PERMITTED
bool waitForExistence(ros::Duration timeout=ros::Duration(-1))
BrakeTestRequiredIntegrationTest checks if the chain ModbusServerMock -> ModbusReadClient -> ModbusAd...
void terminate()
Terminate the Server. Reading or connecting to it will fail.
inline ::testing::AssertionResult waitForNode(const std::string node_name, const double loop_frequency=10.0, const ros::Duration timeout=ros::Duration(10.0))
Blocks until a node defined by node_name comes up.
static constexpr unsigned int DEFAULT_RETRIES
Specifies the meaning of the holding registers.
static const std::string VERSION