-
-
Notifications
You must be signed in to change notification settings - Fork 43
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
Fails to log coverage when using Debugger.IsAttached #71
Comments
Well, after porting my project to nunit and using [Explicit], I get the same type of behaviour. Unfortunately, FCC is broken for me when it comes it comes to any form of optional tests. In fact it's all kinds of temperamental for me. This is just the only issue I could define with a repeatable test. |
Please do post the other issues you have. |
FCC does not have access to the tests that have run/skipped. It executes the coverage tool providing the test dll and there is no concept of a debugger. Can you instead provide an environment variable that a custom FactAttribute has access to ? |
Installed product versions
Description
There's not really a short explanation for this problem. Let's say we have a suite of unit tests and as well as narrow integration tests. i.e. isolated tests that communicate with a single service. We want these integration tests to be manually executable but we don't want them to run by default and we don't want them to run in the pipeline. nunit provides the [Explicit] attribute for this. MSTests provides no functionality and xunit has a kludge that people in the field are relying on. It goes as follows:
Inherit the [Fact] attribute and apply to check to see if the debugger is attached. If the debugger is attached, then don't skip the test. This allows tests flagged with this new attribute to be skipped by default and in the pipeline but they'll execute when you choose Debug Tests. This is ugly but it's a real solution that people are suggesting are relying upon as it's the only way to achieve this in xunit.
This solution works but FCC produces incorrect results.
Consider the code below:
Current behavior
Both of these tests execute and pass. However, Fine Code Coverage reports that Unlucky() and its test are never executed.
Expected behavior
Code coverage should be reported correctly
Side Notes
I've tried my best to minimize this to the smallest amount of code that can demonstrate this with certainty. Perhaps interestingly, it's not the inheritance that causes the problem. It's the IsAttached check. If you remove that block and then execute in debug, FCC reports coverage as expected.
The text was updated successfully, but these errors were encountered: