From d3c0d07ed67b778d1539e96fa972d8e61ec63cd2 Mon Sep 17 00:00:00 2001 From: Mark Thomas Date: Mon, 29 Jan 2024 03:36:56 +0000 Subject: [PATCH] EL 6.0 new tests (#1217) * Add a test for the new length property supported by ArrayElResolver * Increment release target to 17 for EL TCK * Add new test for RecordELResolver * Code clean-up. No functional change. * Add new test for method visibility * Add tests for OptionalELResolver * Code clean-up. No functional change. * Fix test failure with Java 17 * Code clean-up - no functional change * Remove unused code getFeatureDescriptors() was remove in EL 6.0 --- .../common/el/api/resolver/ResolverTest.java | 87 +------ el/pom.xml | 8 +- .../arrayelresolver/ELClientIT.java | 36 ++- .../jakarta_el/beanelresolver/ELClientIT.java | 52 +++-- .../optionalelresolver/ELClientIT.java | 216 ++++++++++++++++++ .../recordelresolver/ELClientIT.java | 82 +++++++ 6 files changed, 384 insertions(+), 97 deletions(-) create mode 100644 el/src/main/java/com/sun/ts/tests/el/api/jakarta_el/optionalelresolver/ELClientIT.java create mode 100644 el/src/main/java/com/sun/ts/tests/el/api/jakarta_el/recordelresolver/ELClientIT.java diff --git a/common/src/main/java/com/sun/ts/tests/common/el/api/resolver/ResolverTest.java b/common/src/main/java/com/sun/ts/tests/common/el/api/resolver/ResolverTest.java index 5671f158c7..60c14596d5 100644 --- a/common/src/main/java/com/sun/ts/tests/common/el/api/resolver/ResolverTest.java +++ b/common/src/main/java/com/sun/ts/tests/common/el/api/resolver/ResolverTest.java @@ -20,18 +20,12 @@ */ package com.sun.ts.tests.common.el.api.resolver; -import java.beans.FeatureDescriptor; -import java.util.Enumeration; -import java.util.Iterator; -import java.util.Map; +import java.util.Objects; -import jakarta.el.ArrayELResolver; import jakarta.el.BeanELResolver; import jakarta.el.CompositeELResolver; import jakarta.el.ELContext; import jakarta.el.ELResolver; -import jakarta.el.ListELResolver; -import jakarta.el.MapELResolver; import jakarta.el.MethodNotFoundException; import jakarta.el.PropertyNotFoundException; import jakarta.el.PropertyNotWritableException; @@ -98,7 +92,7 @@ public static boolean testCompositeELResolver(ELContext elContext, // getType() elContext.setPropertyResolved(false); - Class type = compResolver.getType(elContext, null, "Bar"); + Class type = compResolver.getType(elContext, null, "Bar"); if (!elContext.isPropertyResolved()) { buf.append("getType() did not resolve" + NL); pass = false; @@ -126,8 +120,7 @@ public static boolean testCompositeELResolver(ELContext elContext, // getCommonPropertyType() elContext.setPropertyResolved(false); - Class commonPropertyType = (compResolver.getCommonPropertyType(elContext, - null)); + Class commonPropertyType = (compResolver.getCommonPropertyType(elContext, null)); buf.append("getCommonPropertyType() returns "); buf.append(commonPropertyType.getName() + NL); @@ -172,7 +165,7 @@ public static boolean testELResolver(ELContext elContext, ELResolver resolver, pass = false; } - if (!readOnly && valueRetrieved != value) { + if (!readOnly && !Objects.equals(valueRetrieved, value)) { if (valueRetrieved == null) { buf.append("null value returned from getValue() method call!" + NL); pass = false; @@ -192,7 +185,7 @@ public static boolean testELResolver(ELContext elContext, ELResolver resolver, // getType() elContext.setPropertyResolved(false); - Class type = resolver.getType(elContext, base, property); + Class type = resolver.getType(elContext, base, property); if (!elContext.isPropertyResolved()) { buf.append("getType() did not resolve" + NL); pass = false; @@ -229,8 +222,7 @@ public static boolean testELResolver(ELContext elContext, ELResolver resolver, // getCommonPropertyType() elContext.setPropertyResolved(false); - Class commonPropertyType = (resolver.getCommonPropertyType(elContext, - base)); + Class commonPropertyType = (resolver.getCommonPropertyType(elContext, base)); buf.append("getCommonPropertyType() returns "); buf.append(commonPropertyType.getName() + "" + NL); @@ -259,7 +251,7 @@ public static boolean testELResolver(ELContext elContext, ELResolver resolver, * @return */ public static boolean testELResolverInvoke(ELContext elContext, - ELResolver resolver, Object beanName, Object methodName, Class[] types, + ELResolver resolver, Object beanName, Object methodName, Class[] types, Object[] values, Boolean negTest, StringBuffer buf) { boolean pass = true; @@ -270,13 +262,13 @@ public static boolean testELResolverInvoke(ELContext elContext, Boolean nameMatch = (Boolean) resolver.invoke(elContext, beanName, methodName, types, values); - if (!nameMatch) { + if (!nameMatch.booleanValue()) { buf.append("invoke() did not Run properly." + NL); pass = false; } } catch (MethodNotFoundException mnfe) { - if (negTest) { + if (negTest.booleanValue()) { buf.append("Test Passed invoke() threw MethodNotFoundException"); } else { pass = false; @@ -290,67 +282,6 @@ public static boolean testELResolverInvoke(ELContext elContext, return pass; } - public static boolean testFeatureDescriptors(Iterator i, ELResolver resolver, - Object base, StringBuffer buf) { - - if (i == null) { - buf.append("getFeatureDescriptors() returns null" + NL); - if (resolver instanceof ArrayELResolver - || resolver instanceof ListELResolver) { - return true; - } else if (resolver instanceof MapELResolver && !(base instanceof Map)) { - return true; - } else if (resolver instanceof BeanELResolver && base != null) { - return true; - } else if (resolver instanceof BarELResolver) { - return true; - } else { - return false; - } - } - - while (i.hasNext()) { - Object obj = i.next(); - if (!(obj instanceof FeatureDescriptor)) { - buf.append("getFeatureDescriptors() "); - buf.append( - "does not return a collection of " + "FeatureDescriptors" + NL); - return false; - } else { - int numAttribs = 0; - FeatureDescriptor fd = (FeatureDescriptor) obj; - Enumeration e = fd.attributeNames(); - while (e.hasMoreElements()) { - String attrib = (String) e.nextElement(); - if (attrib.equals("type")) { - ++numAttribs; - if (!(fd.getValue(attrib) instanceof Class)) { - buf.append("getFeatureDescriptors(): "); - buf.append("Invalid attribute for type." + NL); - return false; - } - } - if (attrib.equals("resolvableAtDesignTime")) { - ++numAttribs; - if (!(fd.getValue(attrib) instanceof Boolean)) { - buf.append("getFeatureDescriptors(): "); - buf.append( - "Invalid attribute for " + "resolvableAtDesignTime." + NL); - return false; - } - } - } - if (numAttribs < 2) { - buf.append("getFeatureDescriptors(): "); - buf.append("Required attribute missing." + NL); - return false; - } - } // else - } // while - - buf.append("Passed all getFeatureDescriptors() tests" + NL); - return true; - } // --- Start Negative Method Tests --- public static boolean testELResolverNPE(ELResolver resolver, Object base, diff --git a/el/pom.xml b/el/pom.xml index 1443d15b10..710456c2eb 100644 --- a/el/pom.xml +++ b/el/pom.xml @@ -1,7 +1,7 @@