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

Methods and tests for jep334 String #4105

Merged
merged 3 commits into from
Feb 22, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 21 additions & 8 deletions jcl/src/java.base/share/classes/java/lang/String.java
Original file line number Diff line number Diff line change
Expand Up @@ -8298,14 +8298,6 @@ public static String join(CharSequence delimiter, Iterable<? extends CharSequenc
/*[ENDIF] Sidecar19-SE*/

/*[IF Java12]*/
public Optional<String> describeConstable() {
throw new UnsupportedOperationException("Stub for Java 12 compilation (Jep334)");
}

public String resolveConstantDesc(MethodHandles.Lookup lookup) {
throw new UnsupportedOperationException("Stub for Java 12 compilation (Jep334)");
}

/**
* Apply a function to this string. The function expects a single String input and returns an R.
*
Expand All @@ -8315,5 +8307,26 @@ public String resolveConstantDesc(MethodHandles.Lookup lookup) {
public <R> R transform(Function<? super String, ? extends R> f) {
return f.apply(this);
}

/**
* Returns the nominal descriptor of this String instance, or an empty optional
* if construction is not possible.
*
* @return Optional with nominal descriptor of String instance
*/
public Optional<String> describeConstable() {
return Optional.of(this);
}

/**
* Resolves this ConstantDesc instance
*
* @param lookup parameter is ignored
*
* @return the resolved Constable value
*/
public String resolveConstantDesc(MethodHandles.Lookup lookup) {
return this;
}
/*[ENDIF] Java12 */
}
4 changes: 2 additions & 2 deletions test/README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
<!--
Copyright (c) 2016, 2018 IBM Corp. and others
Copyright (c) 2016, 2019 IBM Corp. and others

This program and the accompanying materials are made available under
the terms of the Eclipse Public License 2.0 which accompanies this
Expand Down Expand Up @@ -140,7 +140,7 @@ typical use case for OpenJ9 developers, there are also many cases
where developers need to verify features for a specific version or
compare behaviour against a particular implementation.

JDK_VERSION=[8|9|10|11|Panama|Valhalla] (8 default value)
JDK_VERSION=[8|9|10|11|12|Panama|Valhalla] (8 default value)

JDK_IMPL=[openj9|ibm|hotspot|sap] (openj9 default value)

Expand Down
2 changes: 1 addition & 1 deletion test/docs/OpenJ9TestUserGuide.md
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ tools should be installed on your test machine to run tests.
```
JAVA_BIN=<path to JDK bin directory that you wish to test>
SPEC=[linux_x86-64|linux_x86-64_cmprssptrs|...] (platform on which to test)
JDK_VERSION=[8|9|10|11|Panama|Valhalla] (8 default value)
JDK_VERSION=[8|9|10|11|12|Panama|Valhalla] (8 default value)
JDK_IMPL=[openj9|ibm|hotspot|sap] (openj9 default value)
BUILD_LIST=<comma separated projects to be compiled and executed> (default to all projects)
NATIVE_TEST_LIBS=<path to native test libraries> (default to native-test-libs folder at same level as JDK_HOME)
Expand Down
88 changes: 88 additions & 0 deletions test/functional/Java12andUp/build.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
<?xml version="1.0"?>

<!--
Copyright (c) 2018, 2019 IBM Corp. and others

This program and the accompanying materials are made available under
the terms of the Eclipse Public License 2.0 which accompanies this
distribution and is available at https://www.eclipse.org/legal/epl-2.0/
or the Apache License, Version 2.0 which accompanies this distribution and
is available at https://www.apache.org/licenses/LICENSE-2.0.

This Source Code may also be made available under the following
Secondary Licenses when the conditions for such availability set
forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
General Public License, version 2 with the GNU Classpath
Exception [1] and GNU General Public License, version 2 with the
OpenJDK Assembly Exception [2].

[1] https://www.gnu.org/software/classpath/license.html
[2] http://openjdk.java.net/legal/assembly-exception.html

SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
-->

<project name="Java12AndUp" default="build" basedir=".">
<taskdef resource='net/sf/antcontrib/antlib.xml'/>
<description>
Tests for Java 12 and up
</description>
<import file="${TEST_ROOT}/functional/build.xml"/>

<!-- set global properties for this build -->
<property name="DEST" value="${BUILD_ROOT}/functional/Java12andUp" />

<!--Properties for this particular build-->
<property name="src" location="./src"/>
<property name="build" location="./bin"/>

<target name="init">
<mkdir dir="${DEST}" />
<mkdir dir="${build}"/>
</target>

<target name="compile" depends="init" description="Using java ${JDK_VERSION} to compile the source" >
<echo>Ant version is ${ant.version}</echo>
<echo>============COMPILER SETTINGS============</echo>
<echo>===fork: yes</echo>
<echo>===executable: ${compiler.javac}</echo>
<echo>===debug: on</echo>
<echo>===destdir: ${DEST}</echo>

<javac srcdir="${src}" destdir="${build}" debug="true" fork="true" executable="${compiler.javac}" includeAntRuntime="false" encoding="ISO-8859-1">
<src path="${src}"/>
<classpath>
<pathelement location="${TEST_ROOT}/TestConfig/lib/testng.jar"/>
<pathelement location="${TEST_ROOT}/TestConfig/lib/jcommander.jar"/>
<pathelement location="${build}" />
</classpath>
</javac>
</target>

<target name="dist" depends="compile,dist_functional" description="generate the distribution" >
<mkdir dir="${DEST}"/>
<jar jarfile="${DEST}/GeneralTest.jar" filesonly="true">
<fileset dir="${build}"/>
<fileset dir="${src}/../" includes="*.properties,*.xml"/>
</jar>
<copy todir="${DEST}">
<fileset dir="${src}/../" includes="*.xml" />
<fileset dir="${src}/../" includes="*.mk" />
</copy>
</target>

<target name="build" >
<if>
<not>
<matches string="${JDK_VERSION}" pattern="^(8|9|10|11)$$" />
</not>
<then>
<antcall target="clean" inheritall="true" />
</then>
</if>
</target>

<target name="clean" depends="dist" description="clean up" >
<delete dir="${build}"/>
</target>
</project>
48 changes: 48 additions & 0 deletions test/functional/Java12andUp/playlist.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
<?xml version="1.0" encoding="UTF-8"?>

<!--
Copyright (c) 2018, 2019 IBM Corp. and others

This program and the accompanying materials are made available under
the terms of the Eclipse Public License 2.0 which accompanies this
distribution and is available at https://www.eclipse.org/legal/epl-2.0/
or the Apache License, Version 2.0 which accompanies this distribution and
is available at https://www.apache.org/licenses/LICENSE-2.0.

This Source Code may also be made available under the following
Secondary Licenses when the conditions for such availability set
forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
General Public License, version 2 with the GNU Classpath
Exception [1] and GNU General Public License, version 2 with the
OpenJDK Assembly Exception [2].

[1] https://www.gnu.org/software/classpath/license.html
[2] http://openjdk.java.net/legal/assembly-exception.html

SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
-->

<playlist xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../TestConfig/playlist.xsd">
<test>
<testCaseName>Jep334Tests</testCaseName>
<variations>
<variation>NoOptions</variation>
</variations>
<command>$(JAVA_COMMAND) $(JVM_OPTIONS) \
-cp $(Q)$(RESOURCES_DIR)$(P)$(TESTNG)$(P)$(TEST_RESROOT)$(D)GeneralTest.jar$(Q) \
org.testng.TestNG -d $(REPORTDIR) $(Q)$(TEST_RESROOT)$(D)testng.xml$(Q) -testnames Jep334Tests \
-groups $(TEST_GROUP) \
-excludegroups $(DEFAULT_EXCLUDE); \
$(TEST_STATUS)
</command>
<levels>
<level>sanity</level>
</levels>
<groups>
<group>functional</group>
</groups>
<subsets>
<subset>12+</subset>
</subsets>
</test>
</playlist>
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
/*******************************************************************************
* Copyright (c) 2018, 2019 IBM Corp. and others
*
* This program and the accompanying materials are made available under
* the terms of the Eclipse Public License 2.0 which accompanies this
* distribution and is available at https://www.eclipse.org/legal/epl-2.0/
* or the Apache License, Version 2.0 which accompanies this distribution and
* is available at https://www.apache.org/licenses/LICENSE-2.0.
*
* This Source Code may also be made available under the following
* Secondary Licenses when the conditions for such availability set
* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
* General Public License, version 2 with the GNU Classpath
* Exception [1] and GNU General Public License, version 2 with the
* OpenJDK Assembly Exception [2].
*
* [1] https://www.gnu.org/software/classpath/license.html
* [2] http://openjdk.java.net/legal/assembly-exception.html
*
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
*******************************************************************************/
package org.openj9.test.java_lang;

import org.testng.Assert;
import org.testng.annotations.Test;
import org.testng.log4testng.Logger;

import java.lang.invoke.MethodHandles;
import java.lang.invoke.MethodHandles.Lookup;
import java.util.Optional;

/**
* This test Java.lang.String API added in Java 12 and later version.
*
*/
public class Test_String {
public static Logger logger = Logger.getLogger(Test_String.class);

private String empty = "";
private String latin1 = "abc123";
private String nonLatin1 = "abc\u0153";
private String emptyWithTerm = "\n";

/*
* Test Java 12 API String.describeConstable()
*/
@Test(groups = { "level.sanity" })
public void testStringDescribeConstable() throws Throwable {
testStringDescribeConstable_sub(empty);
testStringDescribeConstable_sub(latin1);
testStringDescribeConstable_sub(nonLatin1);
testStringDescribeConstable_sub(emptyWithTerm);
}

private void testStringDescribeConstable_sub(String test) throws Throwable {
logger.debug("testStringDescribeConstable: test with string: " + test);
Optional<String> optionalTest = test.describeConstable();
DanHeidinga marked this conversation as resolved.
Show resolved Hide resolved
String describedTestString = optionalTest.orElseThrow();
Assert.assertTrue(test.equals(describedTestString));
}

/*
* Test Java 12 API String.resolveConstantDesc()
*/
@Test(groups = { "level.sanity" })
public void testStringResolveConstantDesc() {
testStringResolveConstantDesc_sub(empty);
testStringResolveConstantDesc_sub(latin1);
testStringResolveConstantDesc_sub(nonLatin1);
testStringResolveConstantDesc_sub(emptyWithTerm);
}

private void testStringResolveConstantDesc_sub(String test) {
logger.debug("testStringDescribeConstable: test with string: " + test);

/* run test with a valid lookup */
MethodHandles.Lookup lookup = MethodHandles.publicLookup();
String resolvedTest = test.resolveConstantDesc(lookup);
Assert.assertTrue(test.equals(resolvedTest));
DanHeidinga marked this conversation as resolved.
Show resolved Hide resolved

/* run tests with a null lookup (should be ignored) */
String resolvedTest2 = test.resolveConstantDesc(null);
Assert.assertTrue(test.equals(resolvedTest2));
}

}
34 changes: 34 additions & 0 deletions test/functional/Java12andUp/testng.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
<?xml version="1.0" encoding="UTF-8"?>

<!--
Copyright (c) 2018, 2019 IBM Corp. and others

This program and the accompanying materials are made available under
the terms of the Eclipse Public License 2.0 which accompanies this
distribution and is available at https://www.eclipse.org/legal/epl-2.0/
or the Apache License, Version 2.0 which accompanies this distribution and
is available at https://www.apache.org/licenses/LICENSE-2.0.

This Source Code may also be made available under the following
Secondary Licenses when the conditions for such availability set
forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
General Public License, version 2 with the GNU Classpath
Exception [1] and GNU General Public License, version 2 with the
OpenJDK Assembly Exception [2].

[1] https://www.gnu.org/software/classpath/license.html
[2] http://openjdk.java.net/legal/assembly-exception.html

SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
-->

<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Java12andUp suite" parallel="none" verbose="2">

<test name="Jep334Tests">
<classes>
<class name="org.openj9.test.java_lang.Test_String" />
</classes>
</test>

</suite>