-
Notifications
You must be signed in to change notification settings - Fork 170
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for topic QOS for ros2topic bw, delay and hz #935
base: rolling
Are you sure you want to change the base?
Conversation
Signed-off-by: Anthony Welte <[email protected]>
7f6a506
to
392e320
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
test with QoS arguments would be ideal for hz
, bw
, deley
and echo
. (this also can be a follow-up PR, i think)
@@ -253,3 +256,78 @@ def add_qos_arguments(parser: ArgumentParser, subscribe_or_publish: str, default | |||
help=( | |||
f'Quality of service liveliness lease duration setting to {subscribe_or_publish} ' | |||
'with (overrides liveliness lease duration value of --qos-profile option')) | |||
|
|||
def extract_qos_arguments(args): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I do not understand why this is needed here. it does not do anything but passing all variables into another class object, can you elaborate this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's definitely useless. I had a few alternatives in mind but none that I was satisfied with:
- just pass
args
to the_rostopic_verb
functions as theqos
parameter. But in that case I might as well remove the other arguments from_rostopic_verb
sinceargs
has all of them - split each qos argument into their own function parameters but that would have added 6 parameters to both
_rostopic_verb
andchoose_qos
I'm not sure what would best fit the style of this package. What do you think ?
|
||
return qos | ||
|
||
def choose_qos(node, topic_name: str, qos_args): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i think moving this to ros2topic/api
is nice to do here aligned with add_qos_arguments
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
besides that, i see choose_qos
function is doing like adaptive qos configuration based on the concerned publisher information for durability and reliability to avoid incompatible QoS setting when it starts echo. I think this can be also applied to ros2 topic pub
without this adaptive qos checking for the publisher? that does a bit more refactoring and cleaning for ros2topic
qos functions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure what you mean. From what I understand apart from the adaptive QoS configuration choose_qos
just calls qos_profile_from_short_keys
which ends up calling the same function profile_configure_short_keys
that is called by pub ?
'topic', | ||
'topic_name', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do we need to change this? Is this related to what this PR is fixing? just checking.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's not needed but I initially implemented this feature by removing all parameters from _rostopic_verb
and just passing it args
and noticed that different verbs used different argument names so I harmonized them.
'--window', '-w', type=positive_int, default=DEFAULT_WINDOW_SIZE, | ||
'--window', '-w', dest='window_size', type=positive_int, default=DEFAULT_WINDOW_SIZE, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same here, is this required for this PR?
Signed-off-by: Anthony Welte <[email protected]>
I'm planning on adding tests once I have time and figure out how to run the tests without getting 13 failures after over 7 min of runtime |
I’ve explored adding tests for the QoS parameters but couldn’t find a clear starting point. Since the other verbs, Additionally, I made a small change to the existing tests to address an instability in |
Signed-off-by: Anthony Welte <[email protected]>
3b31907
to
399ef65
Compare
ros2cli/ros2topic/test/test_echo_pub.py Lines 308 to 312 in 01578e7
this checks if the QoS is compatible or not with the QoS arguments for |
This PR adds support for QoS configuration for the verbs: bw, delay and hz.
It moves the logic to decide on the QoS from
echo
intoros2topic.api
to keep the same logic for the 4 verbs.I'm not really satisfied with my
extract_qos_arguments
function. It's a bit useless, it might be cleaner to just pass the full args to each_rostopic_verb
functionResolves: #719