-
Notifications
You must be signed in to change notification settings - Fork 274
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
generateProto always up-to-date #180
Comments
@amc6 can you provide some steps on how to reproduce this problem?
|
Additionally, if you change the proto to remove a message, the old java files are left in the generated-sources directory. GenerateProtoTask needs a |
You may be able to solve this issue almost trivially by extending SourceTask instead of DefaultTask. |
Regarding clearing the output dir before generating new code: this seems a bit risky to me, because we would have to make sure that directory does not contain anything we should not delete. If SourceTask already solves this problem, I think we should extend it. |
The way gradle works, every task MUST have a unique output directory, which is then added separately to the target sourceset. The entire premise gradle's input and output tracking relies on this. If the directory contains anything other than that generated by the generateProto task, it's an invalid build configuration, which in gradle 3 will cause performance issues, and in gradle 4/5 with build cache will cause bad builds. |
The plugin allows people to specify an output dir that is outside of Maybe this can be fixed just for the non overridden case. @amc6 @shevek can either of you contribute a test case for the always up to date issue? I am still unsuccessful in reproducing it. |
@zpencer Another option than generating the protos straight into a directory to be checked into the repo (which still has the problem of not removing any stale output) is to generate the code into a fixed output directory but have another task that can sync the output into a configurable source directory. |
@davidburstrom, see also #332. I think we should be deprecating generatedFilesBaseDir and we instead emulate the old behavior by auto-creating a Copy task if the option is specified. |
Gradle tasks should not output into a directory which contains any other files, as this breaks build caching, and a break of build caching in the middle of an enterprise build costs a LOT of money. It's basically moving towards being a rule these days that the situation @zpencer describes is forbidden. If you want to have a dir which contains the outputs of multiple tasks, you make each of those tasks output into its own output dir, and then sync them all together using from(task0), from(task1), etc. |
* Add proto java source generation * Workaround for google/protobuf-gradle-plugin#180. Update to latest proto versions. * Update build.gradle.kts
A simple workaround in Gradle is to do // given that com.google.protobuf:protobuf-gradle-plugin is present on the script classpath
tasks.withType(com.google.protobuf.gradle.GenerateProtoTask).configureEach { task ->
doFirst {
file(outputBaseDir).deleteDir()
}
} With that snippet in place, output will never be stale and the cache artifacts won't get poisoned. If you've configured the |
Sorry I don't have cycles to work on this. I have unassigned myself so others can feel free to take this issue. |
Should this remain open as a valid bug, even if we don't plan to fix it? |
@shevek, this was simply a duplicate. |
Expected: Editing a protobuf file and then running
./gradlew generateProto
should regenerate the code for the changed proto.Actual: The task is considered "up-to-date" by gradle and doesn't run.
protoc version: 3.4.0
protobuf-gradle-plugin version: 0.8.3
As a workaround I've configured the task so that it is never considered up to date, but that isn't ideal since it will cause all dependent tasks to be not up to date. But if I'm missing something here, please let me know.
The text was updated successfully, but these errors were encountered: