Fix: sysmon falls back to ctrace when branch=True (issue #2172)#2175
Open
Supull wants to merge 4 commits into
Open
Fix: sysmon falls back to ctrace when branch=True (issue #2172)#2175Supull wants to merge 4 commits into
Supull wants to merge 4 commits into
Conversation
) When using branch coverage on Python 3.14+, sysmon ends up being slower than ctrace. This is because sysmon's big advantage is disabling events after the first time a line is seen. But for branch coverage it cannot do that, since the same line can be reached from many different places in the code. So it keeps firing a Python callback on every single execution, which is actually slower than ctrace's C-level trace function. Fix: when branch=True and the user has not explicitly chosen a core, quietly fall back to ctrace instead. If you explicitly set COVERAGE_CORE=sysmon you still get sysmon. This only affects the default behavior.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Fixes #2172
When using branch coverage on Python 3.14+, sysmon ends up being slower than ctrace. This is because sysmon's big advantage is disabling events after the first time a line is seen. But for branch coverage it cannot do that, since the same line can be reached from many different places in the code. So it keeps firing a Python callback on every single execution, which is actually slower than ctrace's C-level trace function.
Fix: when branch=True and the user has not explicitly chosen a core, quietly fall back to ctrace instead. If you explicitly set COVERAGE_CORE=sysmon you still get sysmon. This only affects the default behavior.