-
Notifications
You must be signed in to change notification settings - Fork 15
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
have_one_new_sample
raises timeout failure when executed in a loop
#244
Comments
have_one_new_sample
raises timeout failure when executed in a loophave_one_new_sample
raises timeout failure when executed in a loop
It depends on how your task behaves.
If you really mean to test that there is a 1:1 match between a If you want to test that your task receives a certain number of samples after having written a certain number of samples (but don't care about the 1:1 mapping), there is no available predicate right now. So, I'd go for
Obviously, all of it would be better factored out in a new |
I would like to test a 1:1 matching. My task is I am not sure if this is a syskit bug. However, for testing this, I created a simple orogen task that receives an base::Angle angle;
while (_in_samples.read(angle) == RTT::NewData) {
_out_samples.write(angle);
} |
Mmmm ... I do agree with your assessment, it does seem to be a Syskit or Syskit/RTT bug. One thing you could try is to display "CONNECTED" / "NOT CONNECTED" just before the write in the component. If there's a race in the |
What you suggested is something like that? base::Angle angle;
while (_in_samples.read(angle) == RTT::NewData) {
if (_out_samples.connected())
std::cout << "CONNECTED" << std::endl;
else
std::cout << "NOT CONNECTED" << std::endl;
_out_samples.write(angle);
} I have done this test. The in_expect_execution.txt is the output with the reader inside the The out_expect_execution.txt is with the reader out of the With the reader inside the
|
Hey. I'm sorry, but I won't have a lot more time to look at it today. The error message seems to indicate that the component reads its input port while the writer is being disconnected. This is not totally unexpected - the second call to read in the while could happen during the disconnection. But then I don't see why there should be more of it in the |
Ok. So, new insight from #247 The test code is not disconnecting the readers after the It turns out that there is super-linear complexity in RTT w.r.t. the number of channels attached to a port. My guess is that reading is getting simply too slow. The obvious bugfix would be to ensure that the readers/writers created during the tests are disconnected at the end of the test. |
For you information, after this PR #246, I have changed the tests as shown below. It worked as expected. actuals = expect_execution { syskit_write task.in_port, *samples }
.to { have_new_samples task.out_port, size }
expected.each_with_index do |exp, i|
assert_equal exp, actuals[i]
end |
Good workaround, but then you're not testing exactly what the component is supposed to be doing, that is writing one sample for each sample read (because of the Syskit bug). You could for instance write more than one and still have |
@gustavoneves12 why the label change. You have not asked anything since my last reply ? In addition, the labels are for the developers to triage the issues. A.k.a. "help wanted" and "question" is for the developers to say "we need people to answer our questions before we can go on". It's not for the person asking to say "it's urgent to me". Because, it's always urgent to the person that's asking |
@doudou I just changed the labels for convenience. Because I would like to classify this issue as a question since at that time when I opened this issue, I didn't know if this is an issue or not. In my point of view issue always sound like a bug. Sorry, I didn't want to say it is urgent to me. Should I remove these labels? |
Labels are not for the convenience of the person that report them, but for the developers. They're here to triage the issues for development. So, unless you are willing to try and fix issues (please do!), they are not for you to use. |
The method
have_one_new_sample
is raising a timeout failure whenexpect_execution
is executed in a loop as shown in the code below:It seems some samples have been lost. In my tests cases,
samples
have 120 elements. To make it works, I created areader
out of theexpect_execution.to
block as in the code below:Did I do something wrong?
Why the first code did not work and the second one works?
The text was updated successfully, but these errors were encountered: