RFR [9] 8145589: Test6277246.java fails to compile after JDK-8144479
Chris Hegarty
chris.hegarty at oracle.com
Thu Dec 17 15:08:53 UTC 2015
On 17 Dec 2015, at 14:54, Roger Riggs <Roger.Riggs at oracle.com> wrote:
> Hi Chris,
>
> Looks fine.
Thanks Roger. Just a little addition to this review.
While not strictly necessary, I’d like to clean up another, string,
reference use in a reflective call. ( It is not causing a failure as
the security manager will restrict access to sun.*, but it may
avoid confusion in the future.
diff --git a/test/java/beans/EventHandler/Test6277246.java b/test/java/beans/EventHandler/Test6277246.java
--- a/test/java/beans/EventHandler/Test6277246.java
+++ b/test/java/beans/EventHandler/Test6277246.java
@@ -39,7 +39,7 @@
Class container = Class.forName("java.lang.Class");
Class parameter = Class.forName("java.lang.String");
Method method = container.getMethod("forName", parameter);
- Object[] arglist = new Object[] {"sun.misc.BASE64Encoder"};
+ Object[] arglist = new Object[] {"sun.security.x509.X509CertInfo"};
EventHandler eh = new EventHandler(Test6277246.class, "forName", "", "forName");
Object object = eh.invoke(null, method, arglist);
throw new Error((object != null) ? "test failure" : "test error”);
-Chris.
> Roger
>
>
> On 12/17/2015 9:46 AM, Chris Hegarty wrote:
>> The removal of BASE64Encoder, and a related types, in 8144479 [1]
>> has triggered the failure of java/beans/Introspector/Test6277246.java.
>> Another internal type should be used instead of sun.misc.BASE64Encoder.
>> The sun.security.x509 package seems stable, and is being used in other
>> areas, like langtools and jigsaw/jake to test accessibility.
>>
>>
>> diff --git a/test/java/beans/Introspector/Test6277246.java b/test/java/beans/Introspector/Test6277246.java
>> --- a/test/java/beans/Introspector/Test6277246.java
>> +++ b/test/java/beans/Introspector/Test6277246.java
>> @@ -25,7 +25,7 @@
>> * @test
>> * @bug 6277246
>> * @summary Tests problem with java.beans use of reflection
>> - * @modules java.base/sun.misc
>> + * @modules java.base/sun.security.x509
>> * java.desktop
>> * @run main/othervm Test6277246
>> * @author Jeff Nisewanger
>> @@ -36,11 +36,10 @@
>> import java.beans.Introspector;
>> import java.beans.MethodDescriptor;
>> import java.lang.reflect.Method;
>> -import sun.misc.BASE64Encoder;
>> public class Test6277246 {
>> public static void main(String[] args) throws IntrospectionException {
>> - Class type = BASE64Encoder.class;
>> + Class type = sun.security.x509.X509CertInfo.class;
>> System.setSecurityManager(new SecurityManager());
>> BeanInfo info = Introspector.getBeanInfo(type);
>> for (MethodDescriptor md : info.getMethodDescriptors()) {
>> @@ -48,7 +47,7 @@
>> System.out.println(method);
>> String name = method.getDeclaringClass().getName();
>> - if (name.startsWith("sun.misc.")) {
>> + if (name.startsWith("sun.")) {
>> throw new Error("found inaccessible method");
>> }
>> }
>>
>> diff --git a/test/ProblemList.txt b/test/ProblemList.txt
>> --- a/test/ProblemList.txt
>> +++ b/test/ProblemList.txt
>> @@ -126,9 +126,6 @@
>> java/beans/Introspector/8132566/OverridePropertyInfoTest.java generic-all
>> java/beans/Introspector/8132566/OverrideUserDefPropertyInfoTest.java generic-all
>> -# 8145589
>> -java/beans/Introspector/Test6277246.java generic-all
>> -
>> ############################################################################
>> # jdk_lang
>>
>>
>> -Chris.
>>
>> [1] https://bugs.openjdk.java.net/browse/JDK-8144479
>
More information about the core-libs-dev
mailing list