add test for moving away with lidar

This commit is contained in:
Sem van der Hoeven
2023-06-12 11:31:22 +02:00
parent bcc14c9e0d
commit e706a38ea4

View File

@@ -18,15 +18,15 @@ from drone_services.msg import LidarReading
@pytest.mark.rostest @pytest.mark.rostest
def generate_test_description(): def generate_test_description():
file_path = os.path.dirname(__file__) file_path = os.path.dirname(__file__)
#device under test # device under test
positionchanger_node = launch_ros.actions.Node( positionchanger_node = launch_ros.actions.Node(
package='drone_controls', executable='position_changer') package='drone_controls', executable='position_changer')
failsafe_node = launch_ros.actions.Node( failsafe_node = launch_ros.actions.Node(
package='failsafe',executable='failsafe') package='failsafe', executable='failsafe')
px4_controller_node = launch_ros.actions.Node( px4_controller_node = launch_ros.actions.Node(
package='px4_connection',executable='px4_controller') package='px4_connection', executable='px4_controller')
heartbeat_node = launch_ros.actions.Node( heartbeat_node = launch_ros.actions.Node(
package='px4_connection',executable='heartbeat') package='px4_connection', executable='heartbeat')
return ( return (
launch.LaunchDescription([ launch.LaunchDescription([
@@ -44,6 +44,7 @@ def generate_test_description():
} }
) )
class TestPositionChanger(unittest.TestCase): class TestPositionChanger(unittest.TestCase):
@classmethod @classmethod
@@ -57,25 +58,27 @@ class TestPositionChanger(unittest.TestCase):
def setUp(self): def setUp(self):
self.node = rclpy.create_node('test_positionchanger') self.node = rclpy.create_node('test_positionchanger')
self.called_positionchanger_service = False self.called_positionchanger_service = False
self.received_failsafe_callback = False self.received_failsafe_callback = False
def tearDown(self): def tearDown(self):
self.node.destroy_node() self.node.destroy_node()
def failsafe_callback(self,msg): def failsafe_callback(self, msg):
self.assertTrue(msg.enabled, "Failsafe was not enabled!") self.assertTrue(msg.enabled, "Failsafe was not enabled!")
self.received_failsafe_callback = True self.received_failsafe_callback = True
def move_position_callback(self,future): def move_position_callback(self, future):
self.assertFalse(future.result().success, "MovePosition service call was successful, but should have failed!") self.assertFalse(future.result(
).success, "MovePosition service call was successful, but should have failed!")
self.called_positionchanger_service = True self.called_positionchanger_service = True
def test_positionchanger_no_lidar_data(self,positionchanger_node,proc_output): def test_positionchanger_no_lidar_data(self, positionchanger_node, proc_output):
self.received_failsafe_callback = False self.received_failsafe_callback = False
self.called_positionchanger_service = False self.called_positionchanger_service = False
failsafe_subscriber = self.node.create_subscription(FailsafeMsg,'/drone/failsafe',self.failsafe_callback,10) failsafe_subscriber = self.node.create_subscription(
move_position_client = self.node.create_client(MovePosition,'/drone/move_position') FailsafeMsg, '/drone/failsafe', self.failsafe_callback, 10)
move_position_client = self.node.create_client(
MovePosition, '/drone/move_position')
while not move_position_client.wait_for_service(timeout_sec=1.0): while not move_position_client.wait_for_service(timeout_sec=1.0):
self.node.get_logger().info('move_position service not available, waiting again...') self.node.get_logger().info('move_position service not available, waiting again...')
@@ -96,22 +99,25 @@ class TestPositionChanger(unittest.TestCase):
continue continue
else: else:
break break
self.assertTrue(self.received_failsafe_callback, "Failsafe callback was not received!") self.assertTrue(self.received_failsafe_callback,
self.assertTrue(self.called_positionchanger_service, "MovePosition service was not called!") "Failsafe callback was not received!")
self.assertTrue(self.called_positionchanger_service,
"MovePosition service was not called!")
finally: finally:
self.node.destroy_client(move_position_client) self.node.destroy_client(move_position_client)
self.node.destroy_subscription(failsafe_subscriber) self.node.destroy_subscription(failsafe_subscriber)
def test_positionchanger_lidar_stops(self, positionchanger_node, proc_output):
def test_positionchanger_lidar_stops(self,positionchanger_node,proc_output):
self.node.get_logger().info("STARTING TEST test_positionchanger_lidar_stops") self.node.get_logger().info("STARTING TEST test_positionchanger_lidar_stops")
self.received_failsafe_callback = False self.received_failsafe_callback = False
self.called_positionchanger_service = False self.called_positionchanger_service = False
failsafe_subscriber = self.node.create_subscription(FailsafeMsg,'/drone/failsafe',self.failsafe_callback,10) failsafe_subscriber = self.node.create_subscription(
lidar_publisher = self.node.create_publisher(LidarReading,'/drone/object_detection',10) FailsafeMsg, '/drone/failsafe', self.failsafe_callback, 10)
move_position_client = self.node.create_client(MovePosition,'/drone/move_position') lidar_publisher = self.node.create_publisher(
LidarReading, '/drone/object_detection', 10)
move_position_client = self.node.create_client(
MovePosition, '/drone/move_position')
while not move_position_client.wait_for_service(timeout_sec=1.0): while not move_position_client.wait_for_service(timeout_sec=1.0):
self.node.get_logger().info('move_position service not available, waiting again...') self.node.get_logger().info('move_position service not available, waiting again...')
@@ -126,19 +132,19 @@ class TestPositionChanger(unittest.TestCase):
lidar_msg.sensor_2 = 2.0 lidar_msg.sensor_2 = 2.0
lidar_msg.sensor_3 = 2.0 lidar_msg.sensor_3 = 2.0
lidar_msg.sensor_4 = 2.0 lidar_msg.sensor_4 = 2.0
lidar_msg.imu_data = [1.0,1.0,1.0,1.0] lidar_msg.imu_data = [1.0, 1.0, 1.0, 1.0]
sent_lidar_msg = False sent_lidar_msg = False
# wait for nodes to become active # wait for nodes to become active
time.sleep(3) time.sleep(3)
# wait 5 seconds for the failsafe to trigger # wait 5 seconds for the failsafe to trigger
wait_time = time.time() + 5.0 wait_time = time.time() + 5.0
end_time = time.time() + 10.0 end_time = time.time() + 10.0
try: try:
self.node.get_logger().info('STARTING WHILE LOOP') self.node.get_logger().info('STARTING WHILE LOOP')
while time.time() < end_time: while time.time() < end_time:
rclpy.spin_once(self.node,timeout_sec=0.1) rclpy.spin_once(self.node, timeout_sec=0.1)
if not sent_lidar_msg: if not sent_lidar_msg:
lidar_publisher.publish(lidar_msg) lidar_publisher.publish(lidar_msg)
sent_lidar_msg = True sent_lidar_msg = True
@@ -150,11 +156,47 @@ class TestPositionChanger(unittest.TestCase):
elif not self.received_failsafe_callback: elif not self.received_failsafe_callback:
continue continue
self.node.get_logger().info('END OF WHILE LOOP') self.node.get_logger().info('END OF WHILE LOOP')
self.assertTrue(self.called_positionchanger_service, "MovePosition service was not called!") self.assertTrue(self.called_positionchanger_service,
self.assertTrue(self.received_failsafe_callback, "Failsafe was not activated!") "MovePosition service was not called!")
self.assertTrue(self.received_failsafe_callback,
"Failsafe was not activated!")
finally: finally:
self.node.get_logger().info('Cleaning up') self.node.get_logger().info('Cleaning up')
self.node.destroy_client(move_position_client) self.node.destroy_client(move_position_client)
self.node.destroy_subscription(failsafe_subscriber) self.node.destroy_subscription(failsafe_subscriber)
self.node.destroy_publisher(lidar_publisher) self.node.destroy_publisher(lidar_publisher)
def test_positionchanger_lidar_moves_away(self, positionchanger_node, px4_controller_node, proc_output):
self.node.get_logger().info("STARTING TEST test_positionchanger_lidar_moves_away")
lidar_publisher = self.node.create_publisher(
LidarReading, '/drone/object_detection', 10)
move_position_client = self.node.create_client(
MovePosition, '/drone/move_position')
while not move_position_client.wait_for_service(timeout_sec=1.0):
self.node.get_logger().info('move_position service not available, waiting again...')
request = MovePosition.Request()
request.front_back = 1.0
request.left_right = 0.0
request.up_down = 0.0
request.angle = 0.0
lidar_msg = LidarReading()
lidar_msg.sensor_1 = 0.5
lidar_msg.sensor_2 = 2.0
lidar_msg.sensor_3 = 2.0
lidar_msg.sensor_4 = 2.0
lidar_msg.imu_data = [1.0, 1.0, 1.0, 1.0]
end_time = time.time() + 10.0
try:
while time.time() < end_time:
rclpy.spin_once(self.node, timeout_sec=0.1)
lidar_publisher.publish(lidar_msg)
if not self.called_positionchanger_service:
future = move_position_client.call_async(request)
future.add_done_callback(self.move_position_callback)
proc_output.assertWaitFor(expected_output='0.5',process=px4_controller_node)
finally:
self.node.destroy_client(move_position_client)
self.node.destroy_publisher(lidar_publisher)