-
Notifications
You must be signed in to change notification settings - Fork 96
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
Thread and Address Sanitizer CI #198
base: rolling
Are you sure you want to change the base?
Conversation
fff8f12
to
bc6d3b0
Compare
Note that we should probably figure out how to run these changes in CI from this PR before merging this (to test the CI config works as expected). Also, this probably shouldn't be merged until asan and tsan tests pass (they don't locally). The reason I created this was to make it easier to test this project locally with asan and tsan to begin fixing memory errors and race conditions. |
I think merging it while the asan and tsan tests don't pass is OK, but I agree with the need to have it running from CI. |
I'll see if I can get it to run in my fork to test if it runs. |
I spent today trying to figure out these memory leaks and while I don't have a PR yet I'm getting closer using a combination of asan and valgrind. I hope to have a PR soon that cleans up all manual memory management. |
I'm a little confused by the heavy usage of recursive mutex, does anyone know if there are specific use cases that explain why this repo uses recursive mutexes and if hopefully those use cases are reflected in the tests? |
Signed-off-by: Tyler Weaver <[email protected]>
bc6d3b0
to
3c9b9c9
Compare
I pushed a rebase of this to see if the latest merged changes fix the bug found by asan. |
Signed-off-by: Tyler Weaver [email protected]
This adds a github actions CI job for tsan and asan.
This can be tested by building locally with the new cmake variables added. For example building and testing with colcon can be done like this:
tsan:
asan:
I'm creating this with the hope that we can fix the errors found by ASAN and TSAN here so that projects that depend on this library can use ASAN and TSAN themselves.
Locally I've applied this change over #186 and was able to observe it reduced the number of errors found by ASAN.