-
Notifications
You must be signed in to change notification settings - Fork 100
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
Generate Multiple playback harnesses when multiple crashes exist in a single harness. #2496
Generate Multiple playback harnesses when multiple crashes exist in a single harness. #2496
Conversation
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.
Few questions regarding the change -
- Do all of the tests have unique identifiers as suffixes? I'm assuming yes, but can you make that more clear in the regression tests that you've added?
- Would it make sense to hide this behavior behind a flag?
I'm asking because the vscode extension runs the playback command and in cases where there's more than one unit test being generated, I'm wondering how the behavior might change and if there's something we need to change within the extension as well, to accommodate these cases.
|
I'll mark this as draft since it is not immidiately clear what ought to be done. Thus fixing the test fails at this point does not make sense. |
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.
Thanks for doing this. I have 2 requests:
- Can you please add a test for
inplace
where Kani will add more than one test for more than one harness at the same time? I'm a bit worried about updating the file multiple times in a row since we use original line numbers to calculate the test position. - The current implementation is generating a modified version of the file N times. Can we add all the tests in one pass instead?
fb41650
to
0cae000
Compare
@celinval I think I resolved your comments with the exception of the |
I'm a bit worried about a potential proof having a lot of crashes as @YoshikiTakashima has mentioned, and the user clicking the concrete playback button and discovering that they have a lot of test cases pasted into their source. It might be annoying to deal with. Does it make sense to be worried about this corner case? Do we have any plans to deal with that when that happens? |
@jaisnan I think it's plausible if the harness is large. One possibility is that we inject first N harnesses where N is a user-set parameter in the extension. Not sure if there is a good way to prioritize them. As for dealing with it when it happens, I think most IDEs have a history beyond last save, so ctrl-z should still work. Not too familiar except for Emacs and VS Code though. |
We could add a configurable cap, and even set its default to 1 to keep the same behavior as today. Regarding priorities, we could have different modes, like user assertions, cover statements and UB checks (the last doesn't work yet with concrete playback). I was wondering if by default we should only generate tests for assertion failures. Another possibility is to allow users to specify which property they want to generate the testcase for. We don't have any stable way of doing so though. @adpaco-aws, any thoughts? |
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.
Awesome! Thanks @YoshikiTakashima
tests/script-based-pre/playback_multi_harness_multi_inject/playback_opts.sh
Outdated
Show resolved
Hide resolved
tests/script-based-pre/playback_multi_harness_multi_inject/playback_opts.sh
Outdated
Show resolved
Hide resolved
tests/script-based-pre/playback_multi_harness_multi_inject/playback_opts.sh
Show resolved
Hide resolved
This is a good starting point: we can remove the technical limitation first and decide on what properties to target later.
Still, tests generated for cover statement could be useful for proof debugging. I don't think test cases for UB checks would be that useful though. |
I think UB tests would be useful. For example, memory checks could be debugged using valgrind, and other UB checks could be debugged using MIRI. |
Right, I hadn't thought of using them with other tools. |
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.
Just some minor comments. Thanks!
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.
Just please prune the info. Thanks!
Description of changes:
Allow multiple harnesses to be generated.
Resolved issues:
Resolves #2461
Call-outs:
Not sure what is requested here.
Testing:
How is this change tested?
tests/ui/concrete-playback/single-harness-multi-trace
Is this a refactor change? No
Checklist
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 and MIT licenses.