Skip to content
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

fix failing tests in java17 CI run #198

Merged
merged 2 commits into from
Feb 4, 2023

Conversation

pjfanning
Copy link
Member

@pjfanning pjfanning commented Feb 3, 2023

Relates to #186

See https://github.com/FasterXML/jackson-modules-base/actions/runs/4039573403

Unfortunately, this change stops the gradle-module-plugin working. It does appear to fix the tests. I tried reworking how that gradle-module-plugin is declared but nothing seems to work.

https://github.com/FasterXML/jackson-modules-base/actions/runs/4080247967/jobs/7032511522

@cowtowncoder
Copy link
Member

Sounds good, thank you for this.

On Gradle module plugin... is that the gradle module metadata thing? It should only be needed with JDK 8 build (for releases).

@pjfanning pjfanning force-pushed the fix-java17-ci-build branch from 8b14541 to 0837e65 Compare February 3, 2023 09:18
@pjfanning pjfanning changed the base branch from 2.15 to 2.14 February 3, 2023 09:19
@pjfanning pjfanning force-pushed the fix-java17-ci-build branch from 349f97e to ba48549 Compare February 3, 2023 09:23
@pjfanning pjfanning marked this pull request as draft February 3, 2023 09:39
@pjfanning
Copy link
Member Author

pjfanning commented Feb 3, 2023

Sounds good, thank you for this.

On Gradle module plugin... is that the gradle module metadata thing? It should only be needed with JDK 8 build (for releases).

Yes - that plugin.

I simply can't get that plugin to work - I either end up with it not working (the .module files it is supposed to produce do not get produced) or that plugin ends up causing the build to fail.

It may require us to choose - support that funky plugin or be able to run the tests in JDK 17.

In the end, the .module file is only a minor nicety - Gradle is well able to use poms, why we need to hack the pom and have this weird .module too - I struggle to see the real benefit.

@cowtowncoder
Copy link
Member

cowtowncoder commented Feb 3, 2023

Sounds good, thank you for this.
On Gradle module plugin... is that the gradle module metadata thing? It should only be needed with JDK 8 build (for releases).

Yes - that plugin.

I simply can't get that plugin to work - I either end up with it not working (the .module files it is supposed to produce do not get produced) or that plugin ends up causing the build to fail.

It may require us to choose - support that funky plugin or be able to run the tests in JDK 17.

In the end, the .module file is only a minor nicety - Gradle is well able to use poms, why we need to hack the pom and have this weird .module too - I struggle to see the real benefit.

Yeah I hear you. At the same time, dropping something that was working up until now (for couple of versions) does not sound good either. I do not know how valuable module info files are; I got the impression they might be more of an experimental feature earlier. But maybe its status has improved.

But let's see if we can get help: @jjohannes I think you know about this module, right?

@jjohannes
Copy link

jjohannes commented Feb 3, 2023

Thanks for letting me know. I am certainly interested in fixing this in the plugin, if it wrongly throws this error in certain cases.

As a first step, can you upgrade the plugin to 0.3.0 (latest version). Maybe that helps already. Can we do that just on this project first to test? It's probably not that easy to update the parent POM where the version is in (?)

Not sure how the different Java version can be responsible for this, but I'll investigate.

@pjfanning
Copy link
Member Author

@jjohannes thanks for the input - v0.3.0 still has same problem

@jjohannes
Copy link

So I don't know why this only fails in the Java 17 build on CI, but this is a valid problem with the build.

jackson-module-afterburner uses the maven shade plugin which generates a "new POM" that is then published. This POM no longer contains the comment. You can see the path in the error message:

/home/runner/work/jackson-modules-base/jackson-modules-base/afterburner/dependency-reduced-pom.xml

This is already broken. If you look at he published POM, you see that it also misses the comment:
https://repo1.maven.org/maven2/com/fasterxml/jackson/module/jackson-module-afterburner/2.14.2/jackson-module-afterburner-2.14.2.pom

The real fix would be to add the comment to the dependency-reduced-pom.xml as well. Do you know if and how that can be done in the maven shade plugin?

@pjfanning
Copy link
Member Author

So I don't know why this only fails in the Java 17 build on CI, but this is a valid problem with the build.

jackson-module-afterburner uses the maven shade plugin which generates a "new POM" that is then published. This POM no longer contains the comment. You can see the path in the error message:

/home/runner/work/jackson-modules-base/jackson-modules-base/afterburner/dependency-reduced-pom.xml

This is already broken. If you look at he published POM, you see that it also misses the comment: https://repo1.maven.org/maven2/com/fasterxml/jackson/module/jackson-module-afterburner/2.14.2/jackson-module-afterburner-2.14.2.pom

The real fix would be to add the comment to the dependency-reduced-pom.xml as well. Do you know if and how that can be done in the maven shade plugin?

in fairness, XML comments are regarded as nice but non-essential - tools keep them or lose them but hardly anyone makes that behaviour controllable

@jjohannes
Copy link

in fairness, XML comments are regarded as nice but non-essential - tools keep them or lose them but hardly anyone makes that behaviour controllable

Sure. One can debate if it was the best decision to use a comment like this by Gradle.

But no matter if one likes it or not, that's how it works.

So if we want to fix it, we need to add that comment to the pom.

In any case I think this is completely unrelated to this PR. The build is already broken on main. And the problem is probably there for longer and the Maven CI build just did not catch it.

@jjohannes
Copy link

@pjfanning can you remove the plugin version upgrade commit again from this PR?

@cowtowncoder can you integrate it as it is, as the build failure is not new from this PR?

Then we can open a separate issue for this. If I find some time next week, I can check how this could be fixed.

@pjfanning pjfanning marked this pull request as ready for review February 4, 2023 00:16
@cowtowncoder
Copy link
Member

cowtowncoder commented Feb 4, 2023

Ok sounds good, I can merge this.

EDIT: Actually change would remove Gradle module metadata generation from all components, not just Afterburner/Blackbird.
I am not 100% sure but wouldn't it be possible to have override to disable module for AB/BB?
If not, we'd need to move plug-in enabling from main level to individual sub-modules other than AB/BB.

pom.xml Show resolved Hide resolved
change profile ids

only run gradle module on java8 due to issues

remove tabs

Update pom.xml

Update pom.xml

Update pom.xml

Update pom.xml

upgrade gradle module plugin

Update pom.xml

Update pom.xml
@pjfanning pjfanning force-pushed the fix-java17-ci-build branch from 715c740 to 6df8246 Compare February 4, 2023 10:14
@cowtowncoder
Copy link
Member

Okay looks good; will merge, need to manually push to 2.15 and master as well.

I wonder if we can have downstream tests to verify successful publishing of GMM (ditto for OSGi metadata). But first things first.

@cowtowncoder cowtowncoder merged commit d6d9071 into FasterXML:2.14 Feb 4, 2023
cowtowncoder added a commit that referenced this pull request Feb 4, 2023
@pjfanning pjfanning deleted the fix-java17-ci-build branch February 4, 2023 23:45
@cowtowncoder
Copy link
Member

Merged to 2.15 and master as well.

@jjohannes
Copy link

I wonder if we can have downstream tests to verify successful publishing of GMM (ditto for OSGi metadata). But first things first.

The test I added here was supposed to inform about issues like this:
https://github.com/FasterXML/jackson-integration-tests/blob/master/src/test/java/com/fasterxml/jackson/integtest/gradle/GradleTest.java

But it's not "strict" enough. I will have a look. I should also upgrade the Gradle version there to make jackson-integration-tests work on Java 17.

@jjohannes
Copy link

jjohannes added a commit to jjohannes/jackson-integration-tests that referenced this pull request Feb 10, 2023
cowtowncoder pushed a commit to FasterXML/jackson-integration-tests that referenced this pull request Feb 12, 2023
* Rework 'Gradle Metadata has been published' test

* Add exceptions for components where Gradle metadata is currently missing

* Fix MixinForJava8DateTimesTest on Java 17

Applies similar solution as:
FasterXML/jackson-modules-base#198
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants