-
Notifications
You must be signed in to change notification settings - Fork 58
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
Do not require repository for root build.gradle #62
Comments
Yes, the plugin creates the new configuration in the buildscript in the root project and adds there PIT dependencies. It was done 2 years ago and I cannot call if there was a problem in putting it only in the modules with the PIT plugin applied not just once in the root project. AFAIR someone already complained on that in the past. It could be changed. However, it would break a backward compatibility as developers can use Nevertheless, I'm not getting completely the whole configuration problem in your project. Gradle plugins are usually defined as a dependency in the root projects and later applied in desired modules. Where would you like to define |
I simply apply dependencies in the buildSrc project and the dependencies of buildSrc will be visible in all build scripts. Given that I almost always have a buildSrc project, it just doesn't make sense to declare some of the things in the root build.gradle (also declaring the repositories again). Especially, since the buildscript block is much more limited in what you can do there. Though I haven't thought everything through but would it be possible to have 'info.solidsoft.gradle.pitest:gradle-pitest-plugin' depend on the artifact you manually add ('org.pitest:pitest-command-line')? That way, you don't have to mutate the build script's class loader. I personally would also be ok (as a workaround), if I could manually apply the dependency instead (even if that means a little extra configuration on my part). |
As mentioned by @remal in #155 (comment) it may cause I plan to come back to that conception in the next iteration. |
I finally took a closer look at that and it doesn't seem to be too problematic. I moved the configuration from the buildscript scope for the root project to the regular scope for the current project (the same as the Codenarc plugin made by the Gradle team). I'm not sure about the side effects of using a regular configuration instead of buildscript one. @kelemen @remal You may want to test 1.5.0-SNAPSHOT I've just uploaded:
In the simple case, the required change is just to move the configuration out of the buildscript (and to subprojects if available):
It shouldn't be required to create the configuration as the plugin creates it, however, it seems to be created too late as I register my plugin right after JavaPlugin has been applied:
I will think if it can be simplified. For using the new 1.4.7+ syntax for JUnit 5 plugin or no using plugin at all, in the majority of cases it should just work without any change. |
@szpak Could you please write how the usage will look like now? Can I use the plugin in this manner? apply plugin: "info.solidsoft.pitest"
dependencies {
pitest "org.pitest:pitest-command-line"
pitest "org.pitest:pitest-junit5-plugin"
}
pitest {
testPlugin = "junit5"
} |
Btw, with changes in 1.4.7 it should be as easy as:
(but please also change the first construction to confirm that it works in general). |
configurations.create('pitest') Why do you need it? Isn't the configuration created by the plugin itself?
dependencies {
pitest "org.pitest:pitest-command-line"
} Usually plugins add "optional dependencies" (see how it's done in SpotBugs) I thought that you're using the same mechanism, in this case I have to put default dependency myself... What am I missing here?
pitest {
junit5PluginVersion = '0.12'
} Unfortunately, tools like Dependabot or Renovate won't handle it. They handle only dependencies written in common manner. |
Please take a look at my previous message where I explain why I suspect it fails without that (II plan to take a look at that, but please propose the change in code to fix it if you know a simple solution).
I didn't know that mechanism. When I started writing my plugin it most likely didn't exist :-). However, I add that dependency when plugin is applied, based on
I know, the support for Gradle is much worse than for Maven. On the other hand, to keep the configuration simple, how often JUnit 5 plugin for PIT is updated? Maybe in that case it would be more feasible to subscribe to updates in that repo with https://gitpunch.com/ or GitHub releases itself and 2 times a year craft a PR manually? |
BTW How about including JUnit5 into Gradle plugin? It won"t consume much space and will make configuration easier |
I do not understand what do you exactly would like to achieve. The following would be hard to beat :-).
(it's enough to have PIT with the JUnit 5 plugin up and running in the simple case) |
Unless you wanted to suggest its addition to PIT itself (the same as the TestNG plugin). However, it more question to Henry. |
Guys, I've just uploaded the new SNAPSHOT with removed the need to create the
|
As is now, the plugin forces me to have a block like this in the beginning of root build.gradle:
This is inconvenient when the project is setup to rely on buildSrc (the buildscript block is more restricting).
The text was updated successfully, but these errors were encountered: