Add fault-injection unit tests (coverage part 2/3) (#766)
* Fault injection tests for rcl_yaml Signed-off-by: Stephen Brawner <brawner@gmail.com> * PR Feedback Signed-off-by: Stephen Brawner <brawner@gmail.com> * Pause fault injection Signed-off-by: Stephen Brawner <brawner@gmail.com> * variant_copy Signed-off-by: Stephen Brawner <brawner@gmail.com>
This commit is contained in:
		
							parent
							
								
									79e2e044d3
								
							
						
					
					
						commit
						08bbdde860
					
				
					 4 changed files with 133 additions and 35 deletions
				
			
		| 
						 | 
				
			
			@ -104,3 +104,57 @@ TEST(TestNamespace, replace_ns) {
 | 
			
		|||
  EXPECT_STREQ(expected_param_ns, ns_tracker.parameter_ns);
 | 
			
		||||
  EXPECT_EQ(3u, ns_tracker.num_parameter_ns);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
TEST(TestNamespace, replace_ns_maybe_fail) {
 | 
			
		||||
  rcutils_allocator_t allocator = rcutils_get_default_allocator();
 | 
			
		||||
  namespace_tracker_t ns_tracker;
 | 
			
		||||
  ns_tracker.node_ns = rcutils_strdup("node1/node2", allocator);
 | 
			
		||||
  ASSERT_STREQ("node1/node2", ns_tracker.node_ns);
 | 
			
		||||
  ns_tracker.parameter_ns = rcutils_strdup("param1.param2", allocator);
 | 
			
		||||
  ASSERT_STREQ("param1.param2", ns_tracker.parameter_ns);
 | 
			
		||||
  ns_tracker.num_node_ns = 2;
 | 
			
		||||
  ns_tracker.num_parameter_ns = 2;
 | 
			
		||||
  OSRF_TESTING_TOOLS_CPP_SCOPE_EXIT(
 | 
			
		||||
  {
 | 
			
		||||
    allocator.deallocate(ns_tracker.node_ns, allocator.state);
 | 
			
		||||
    allocator.deallocate(ns_tracker.parameter_ns, allocator.state);
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  char * expected_ns = rcutils_strdup("new_ns1/new_ns2/new_ns3", allocator);
 | 
			
		||||
  ASSERT_STREQ("new_ns1/new_ns2/new_ns3", expected_ns);
 | 
			
		||||
  OSRF_TESTING_TOOLS_CPP_SCOPE_EXIT(
 | 
			
		||||
  {
 | 
			
		||||
    allocator.deallocate(expected_ns, allocator.state);
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  char * expected_param_ns =
 | 
			
		||||
    rcutils_strdup("new_param1.new_param2.new_param3", allocator);
 | 
			
		||||
  ASSERT_STREQ("new_param1.new_param2.new_param3", expected_param_ns);
 | 
			
		||||
  OSRF_TESTING_TOOLS_CPP_SCOPE_EXIT(
 | 
			
		||||
  {
 | 
			
		||||
    allocator.deallocate(expected_param_ns, allocator.state);
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  RCUTILS_FAULT_INJECTION_TEST(
 | 
			
		||||
  {
 | 
			
		||||
    rcutils_ret_t ret =
 | 
			
		||||
    replace_ns(&ns_tracker, expected_ns, 3, NS_TYPE_NODE, allocator);
 | 
			
		||||
    if (RCUTILS_RET_OK != ret) {
 | 
			
		||||
      EXPECT_EQ(nullptr, ns_tracker.node_ns);
 | 
			
		||||
      rcutils_reset_error();
 | 
			
		||||
    } else {
 | 
			
		||||
      EXPECT_EQ(RCUTILS_RET_OK, ret) << rcutils_get_error_string().str;
 | 
			
		||||
      EXPECT_STREQ(expected_ns, ns_tracker.node_ns);
 | 
			
		||||
      EXPECT_EQ(3u, ns_tracker.num_node_ns);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    ret = replace_ns(&ns_tracker, expected_param_ns, 3, NS_TYPE_PARAM, allocator);
 | 
			
		||||
    if (RCUTILS_RET_OK != ret) {
 | 
			
		||||
      EXPECT_EQ(nullptr, ns_tracker.parameter_ns);
 | 
			
		||||
      rcutils_reset_error();
 | 
			
		||||
    } else {
 | 
			
		||||
      EXPECT_STREQ(expected_param_ns, ns_tracker.parameter_ns);
 | 
			
		||||
      EXPECT_EQ(3u, ns_tracker.num_parameter_ns);
 | 
			
		||||
    }
 | 
			
		||||
  });
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue