-
Notifications
You must be signed in to change notification settings - Fork 108
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
8321941: Migrate test/jdk/valhalla/valuetypes from primitive classes to null-restricted types #963
Conversation
👋 Welcome back mchung! A progress list of the required criteria for merging this PR into |
@mlchung This change now passes all automated pre-integration checks. ℹ️ This project also has non-automated pre-integration requirements. Please see the file CONTRIBUTING.md for details. After integration, the commit message for the final commit will be:
You can use pull request commands such as /summary, /contributor and /issue to adjust it as needed. At the time when this comment was updated there had been no new commits pushed to the ➡️ To integrate this PR with the above commit message to the |
Webrevs
|
final int PRE_CAST = (needsCast && !isGetter ? nameCursor++ : -1); | ||
final int LINKER_CALL = nameCursor++; | ||
final int FIELD_TYPE = (needsZeroInstance && isGetter ? nameCursor++ : -1); | ||
final int ZERO_INSTANCE = (needsZeroInstance && isGetter ? nameCursor++ : -1); | ||
final int POST_CAST = (needsCast && isGetter ? nameCursor++ : -1); | ||
final int RESULT = nameCursor-1; // either the call or the cast |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Outdated comment, should be
// the call, the zero instance, or the cast
* @run testng/othervm -XX:+EnableValhalla -XX:+EnablePrimitiveClasses -XX:FlatArrayElementMaxSize=-1 ArrayElementVarHandleTest | ||
* @run testng/othervm -XX:+EnableValhalla -XX:+EnablePrimitiveClasses -XX:FlatArrayElementMaxSize=0 ArrayElementVarHandleTest | ||
* @run junit/othervm -XX:+EnableValhalla -XX:FlatArrayElementMaxSize=-1 ArrayElementVarHandleTest | ||
* @run testng/othervm -XX:+EnableValhalla -XX:FlatArrayElementMaxSize=0 ArrayElementVarHandleTest |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
junit here too?
|
||
static Stream<Arguments> identitiesData() { | ||
return Stream.of( | ||
Arguments.of(new Object(), false, false), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The JEP doesn't say this (yet) but new Object()
is an identity instance. java.util.Objects.isIdentityObject() and .isValueObject() will need to be updated too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It already handles that. The two arguments specify if the class of the instance is identity class or value class. The test special cases to verify if the class is Object.class
, it's an identity object.
@@ -24,116 +24,93 @@ | |||
|
|||
/* | |||
* @test | |||
* @summary test VarHandle on primitive class array | |||
* @summary test VarHandle on value class array | |||
* @compile -XDenablePrimitiveClasses ArrayElementVarHandleTest.java |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It looks like the compiler does not need -XDenablePrimitiveClasses.
Except in RecursiveValueClass.java that still has a primitive class declaration.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updated.
@@ -23,62 +23,64 @@ | |||
|
|||
/* | |||
* @test | |||
* @run junit/othervm -XX:+EnableValhalla LambdaTest |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm... we have a mixture of style. The jtreg document states @summary
comes before the action. I will update them.
/integrate |
Going to push as commit 2dc05aa. |
Migrate test/jdk/valhalla/valuetypes tests to use null-restricted types instead.
Progress
Issue
Reviewers
Reviewing
Using
git
Checkout this PR locally:
$ git fetch https://git.openjdk.org/valhalla.git pull/963/head:pull/963
$ git checkout pull/963
Update a local copy of the PR:
$ git checkout pull/963
$ git pull https://git.openjdk.org/valhalla.git pull/963/head
Using Skara CLI tools
Checkout this PR locally:
$ git pr checkout 963
View PR using the GUI difftool:
$ git pr show -t 963
Using diff file
Download this PR as a diff file:
https://git.openjdk.org/valhalla/pull/963.diff
Webrev
Link to Webrev Comment