From b378d9a86b7bb6f0b143e9a4b7647f7418f845d1 Mon Sep 17 00:00:00 2001
From: Dominic Reber <71256590+domire8@users.noreply.github.com>
Date: Mon, 9 Dec 2024 09:08:09 +0100
Subject: [PATCH] fix(components): add missing test case (#181)
---
CHANGELOG.md | 1 +
.../modulo_components/test/python/conftest.py | 3 ++-
.../test_lifecycle_component_communication.py | 23 +++++++++++++++++++
source/modulo_controllers/package.xml | 1 -
4 files changed, 26 insertions(+), 2 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 7c57d5ba..bed939a1 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -26,6 +26,7 @@ Release Versions:
- feat(controllers): add TF broadcaster in BaseControllerInterface (#170)
- test(controllers): add TF listener and broadcaster tests (#172)
- feat(components): get clproto message type from attribute (#175)
+ - fix(components): add missing test case (#181)
## 5.0.2
diff --git a/source/modulo_components/test/python/conftest.py b/source/modulo_components/test/python/conftest.py
index a1141daa..fce0b0a7 100644
--- a/source/modulo_components/test/python/conftest.py
+++ b/source/modulo_components/test/python/conftest.py
@@ -79,7 +79,8 @@ def publish(self):
component = component_type("minimal_sensor_output")
component._output = random_sensor
- component.add_output("sensor_state", "_output", JointState, default_topic=topic, publish_on_step=publish_on_step)
+ component.add_output("sensor_state", "_output", JointState,
+ default_topic=topic, publish_on_step=publish_on_step)
component.publish = publish.__get__(component)
return component
diff --git a/source/modulo_components/test/python/test_lifecycle_component_communication.py b/source/modulo_components/test/python/test_lifecycle_component_communication.py
index 624f7cd0..ccbece2d 100644
--- a/source/modulo_components/test/python/test_lifecycle_component_communication.py
+++ b/source/modulo_components/test/python/test_lifecycle_component_communication.py
@@ -48,6 +48,29 @@ def test_input_output_manual(ros_exec, make_lifecycle_change_client, random_pose
assert random_pose.dist(minimal_cartesian_input.input) < 1e-3
+@pytest.mark.parametrize("minimal_sensor_input", [[LifecycleComponent, "/topic"]], indirect=True)
+@pytest.mark.parametrize("minimal_sensor_output", [[LifecycleComponent, "/topic", False]], indirect=True)
+def test_input_output_manual_sensor(
+ ros_exec, make_lifecycle_change_client, random_sensor, minimal_sensor_output, minimal_sensor_input):
+ input_change_client = make_lifecycle_change_client("minimal_sensor_input")
+ output_change_client = make_lifecycle_change_client("minimal_sensor_output")
+ ros_exec.add_node(input_change_client)
+ ros_exec.add_node(output_change_client)
+ ros_exec.add_node(minimal_sensor_input)
+ ros_exec.add_node(minimal_sensor_output)
+ input_change_client.configure(ros_exec)
+ output_change_client.configure(ros_exec)
+ input_change_client.activate(ros_exec)
+ output_change_client.activate(ros_exec)
+ ros_exec.spin_until_future_complete(minimal_sensor_input.received_future, timeout_sec=0.5)
+ assert not minimal_sensor_input.received_future.done()
+ minimal_sensor_output.publish()
+ ros_exec.spin_until_future_complete(minimal_sensor_input.received_future, timeout_sec=0.5)
+ assert minimal_sensor_input.received_future.done() and minimal_sensor_input.received_future.result()
+ for key in random_sensor.get_fields_and_field_types().keys():
+ assert getattr(random_sensor, key) == getattr(minimal_sensor_input.input, key)
+
+
@pytest.mark.parametrize("minimal_cartesian_input", [[LifecycleComponent, "/topic"]], indirect=True)
@pytest.mark.parametrize("minimal_joint_output", [[LifecycleComponent, "/topic", True]], indirect=True)
def test_input_output_invalid_type(ros_exec, minimal_joint_output, minimal_cartesian_input):
diff --git a/source/modulo_controllers/package.xml b/source/modulo_controllers/package.xml
index d704ffd3..51102fc8 100644
--- a/source/modulo_controllers/package.xml
+++ b/source/modulo_controllers/package.xml
@@ -11,7 +11,6 @@
controller_interface
hardware_interface
- kdl_parser
pluginlib
rclcpp
rclcpp_lifecycle