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

[BUG] Scala 2.13 build with JDK 11 or 17 fails OpcodeSuite tests #9555

Closed
NVnavkumar opened this issue Oct 26, 2023 · 7 comments · Fixed by #10057
Closed

[BUG] Scala 2.13 build with JDK 11 or 17 fails OpcodeSuite tests #9555

NVnavkumar opened this issue Oct 26, 2023 · 7 comments · Fixed by #10057
Assignees
Labels
bug Something isn't working Scala 2.13 Issues related to Scala 2.13 binaries

Comments

@NVnavkumar
Copy link
Collaborator

From the Scala 2.13 PR #8592 (comment). There are some unresolved unit test failures in OpcodeSuite when building against JDK 11 or 17 (not with JDK 8).

 JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64 mvn -Pjdk11 test -pl udf-compiler -Dbuildver=330
- java lang string builder test - append *** FAILED ***
  OpcodeSuite.this.udfIsCompiled[T](ds1) was false (OpcodeSuite.scala:52)
- string test - + concat *** FAILED ***
  OpcodeSuite.this.udfIsCompiled[T](ds1) was false (OpcodeSuite.scala:52)
...
- throw a SparkException object *** FAILED ***
  OpcodeSuite.this.udfIsCompiled[T](ds1) was false (OpcodeSuite.scala:52)
- Conditional array buffer processing *** FAILED ***
  OpcodeSuite.this.udfIsCompiled[T](ds1) was false (OpcodeSuite.scala:52)

Tests: succeeded 161, failed 4, canceled 0, ignored 0, pending 0

The underlying issue seems to be a problem with invokedynamic which starts showing up in JDK 11 and 17 builds. Should fix these so JDK 11 and JDK 17 builds can pass with Scala 2.13.

The code does run fine though with Java 11 and 17 runtime environments if built with JDK 8.

@NVnavkumar NVnavkumar added bug Something isn't working ? - Needs Triage Need team to review and classify labels Oct 26, 2023
@abellina
Copy link
Collaborator

@seanprime7 for visibility. We may need some help here, and we'll also need to fork this part of the compiler so it can work with JDK8 and JDK11+, because we have lots of spark versions built on JDK8 we support.

@gerashegalov gerashegalov added the Scala 2.13 Issues related to Scala 2.13 binaries label Oct 31, 2023
@mattahrens mattahrens removed the ? - Needs Triage Need team to review and classify label Oct 31, 2023
@abellina
Copy link
Collaborator

abellina commented Nov 1, 2023

We are looking at the bytecode produced with @seanprime7 for the four udfs. The differences I see are actually between scala 2.12 and 2.13, not between jdk versions within a scala version. (e.g. scala 2.12+jdk 8 is the same as scala 2.12+jdk17, but scala 2.13+jdk 8 is not the same as scala 2.12+jdk8).

@abellina
Copy link
Collaborator

@NVnavkumar I am not an expert at the 2.13 builds. Does this mean that for 2.13 the UDF compiler is being built but the tests are getting skipped? E.g. what is the state of the UDF compiler today (other than these tests are failing...)

@NVnavkumar
Copy link
Collaborator Author

NVnavkumar commented Nov 13, 2023

The artifacts are built and tested with Scala 2.13 and JDK 8. We don't built with JDK 11 or 17, and that's what causes the failed tests (ie the Scala 2.13+JDK11/17 built artifact fails the unit tests in OpcodeSuite, but Scala2.13+JDK8 built artifact passes thoses tests)

The nightly artifacts I believe are all built with JDK 8 (correct me if I'm wrong @pxLi )

@abellina
Copy link
Collaborator

@NVnavkumar @pxLi would it make sense to (for now) skip the scalatests so we unblock 2.13 + JDK11/17?

I'd hate to hold that CI because of these few tests that are failing.

@pxLi
Copy link
Collaborator

pxLi commented Nov 14, 2023

The nightly artifacts I believe are all built with JDK 8 (correct me if I'm wrong @pxLi )

Yes, the nightly one is built against jdk8 and run the with jdk17 runtime.

would it make sense to (for now) skip the scalatests so we unblock 2.13 + JDK11/17?

currently we should only have CI in github actions to test against scala213 build against JDK11&17 (no test runs)
and also they should be optional ones, feel free to ignore those if confirm known issue

@abellina
Copy link
Collaborator

The status is that we'll try to get these tests fixed in the next sprint but that this is not a blocker for 23.12 release.

abellina pushed a commit that referenced this issue Dec 20, 2023
…10057)

* Add support for StringConcatFactory.makeConcatWithConstants (#9555)

Signed-off-by: Sean Lee <[email protected]>

* Update copyright year

Signed-off-by: Sean Lee <[email protected]>

---------

Signed-off-by: Sean Lee <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working Scala 2.13 Issues related to Scala 2.13 binaries
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants