-
Notifications
You must be signed in to change notification settings - Fork 542
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
[SUREFIRE-1266] Skip junit dependency check if module has no tests to run #388
base: master
Are you sure you want to change the base?
Conversation
I put some comments on jira issue. |
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.
More complicated code to very long class ... and resolves one specific case.
@@ -944,6 +944,7 @@ public void execute() | |||
return; | |||
} | |||
} | |||
verifyParameters( true ); |
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.
second call? in one methd.
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.
@CMoH @slawekjaranowski
Here I can see that the method verifyParameters()
is called twice. Why?
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.
The short answer is:
- the first call is meant to run the fast parameters check, also determining if the plugin is enabled
- the second is meant to run more checks, those that are only applicable to modules that do have test classes.
I believe such a split is necessary, since the test getTestClassesDirectory().exists()
at the beginning of verifyParameters()
is insufficient. The test directory might exist, empty, or containing files/classes which don't provide tests to run.
The actual problem for me here is warnIfDefunctGroupsCombinations()
, which should not crash for modules that don't have tests due to parameters inherited from a parent pom.
The correct, more resource-expensive check, is done by scanForTestClasses()
, and the second call to verifyParameters()
only has any effect if there are indeed tests to run (and failIfNoTests==false
).
The second benefit is that the splitting the responsibilities of verifyParameters()
into two methods (although I only started with a quick fix via a boolean parameter) would help as placeholders to continue refining the validation code.
I touched on this also in this comment below.
I am able to assist with changes, if you feel this path is helpful to the plugin.
@@ -1101,7 +1102,7 @@ else if ( out.isDirectory() ) | |||
} | |||
} | |||
|
|||
boolean verifyParameters() | |||
boolean verifyParameters( boolean pluginActive ) |
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.
What does pluginActive
means ... ?
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.
I agree the name choice is not be the best. Please note that I created this to prototype a way to solve it, as well as to point out this design issue visible in verifyParameters()
(which does an insufficient, but speedy check, if the test
folder exists in a module). The second, more expensive check, is done in scanForTestClasses()
.
The reasoning behind it is that some fast parameter validation can be done based purely on configuration, while a better validation can be done after inspecting the test classes, which enables more precise heuristics.
This pointed me to the thought that there is an opportunity to implement these two phases: some parameters need to be checked before looking at tests, to determine if it's worth looking for tests. Next some parameters are not worth checking unless certain test providers and annotations are actually in use (the second phase).
I think your decision to make is whether such a design is desirable or not. I can adjust the contribution for a better design, if desired.
However, I noticed in the issue you want to solve it in a different way. Please close this merge request if you don't need it anymore.
@slawekjaranowski |
I see something related to the PR template referring the jenkins build on master. Worth a rebase? |
@CMoH yes sure, feel free to rebase the branch. |
… run Don't require users to add junit dependencies on all projects when using groups in surefire/failsafe at the reactor-level
I have reviewed our implementation again in the MOJO. |
@Tibor17 Here is my experience bumping into this problem:
I imagine we can work around this limitation by extracting these out of the test artifact into a new module, having a To me, a more elegant solution was to delay the test in surefire until it can verify that the particular jar has any tests to run, which is what this contribution was about. I am confused how come others have not run into similar problems when trying to access this tagging feature of junit, because this becomes interesting later in the project, when things get complex. On the other hand, I have to reprise the branch where I was working on this idea and revisit it. |
Don't require users to add junit dependencies on all projects when using
groups in surefire/failsafe at the reactor-level
This is a proposal on how to achieve this effect, as described in the issue. Please guide me if you have expectations on how to structure this check in a better way (such as a separate method instead of a boolean?)
I have prepared a demo test-case project at https://github.com/CMoH/surefire1266-sample to illustrate the situation and the fix. I can add it to the
surefire-it
folder if you find it worthwhile - maybe in a form more suitable for that purpose. The current incarnation is intended to depict the situation I am faced with, the one that motivated this contribution.