Yes, I agree with Romain (and also many others that have the same
concerns), expecting that the behavior of testing with one JDK that
targets a lower JDK will "just works" is naive.

There are differences at bytecode level, just compile a class with
JDK17 --release 11 and the same class with JDK11 --release 11 and then
compare with diffoscope to see them, this is one of the reasons that
you need to use the same major JDK version to get Reproducible Builds,
you can't expect a build to be reproducible even if you target to the
same release.

I don't expect the bytecode differences to be a real issue, yet
without proper testing (using the same runtime that you target) you
can't be sure.

The HttpClient is one example where you have things like this bug:
https://bugs.java.com/bugdatabase/view_bug.do?bug_id=8245245, fixed
only in Java 16+, meaning that while it *works* on Java 17, it will
fail on Java 11.

We all agree that Toolchains is the way to go for this kind of thing,
but it's important to mention that Toolchains create some friction for
end users and a more involved setup.

And please don't get me wrong, I'm all for using JDK 17, but user
experience is also important.

On Wed, Jul 20, 2022 at 4:23 PM Romain Manni-Bucau
<rmannibu...@gmail.com> wrote:
>
> Was more due to tests failling but there is no guarantee there is no
> difference in the bytecode on one side and the most important IMHO is the
> fact the run behavior can be different so at the end of the day you cant
> assume that because your build with java17 -release 8 worked that it will
> run on your prod.
>
> Romain Manni-Bucau
> @rmannibucau <https://twitter.com/rmannibucau> |  Blog
> <https://rmannibucau.metawerx.net/> | Old Blog
> <http://rmannibucau.wordpress.com> | Github <https://github.com/rmannibucau> |
> LinkedIn <https://www.linkedin.com/in/rmannibucau> | Book
> <https://www.packtpub.com/application-development/java-ee-8-high-performance>
>
>
> Le mer. 20 juil. 2022 à 16:16, Tomo Suzuki <suzt...@google.com.invalid> a
> écrit :
>
> > Hi Romain,
> >
> > > the while loop was not exactly the same
> >
> > Did you observe the difference in the while loop bytecode cause an issue in
> > Java 8 users?
> >
> > Regards,
> > Tomo
> >

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@maven.apache.org
For additional commands, e-mail: dev-h...@maven.apache.org

Reply via email to