[ https://issues.apache.org/jira/browse/GROOVY-10214?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17413266#comment-17413266 ]
Paul King commented on GROOVY-10214: ------------------------------------ Do you think it is possible in your environment to {{git bisect}} using "gradlew installGroovy -PskipIndy" between the 3.0.8 and 3.0.9 tags and point your test environment to the generated groovy? I don't know how involved that would be - but would be another way to make progress. Otherwise, my intuition would be to look for something that might have changed for primitives vs wrapper type in method/property selection in the context of categories. > Update from Groovy 3.0.8 to 3.0.9 breaks category class > ------------------------------------------------------- > > Key: GROOVY-10214 > URL: https://issues.apache.org/jira/browse/GROOVY-10214 > Project: Groovy > Issue Type: Bug > Affects Versions: 3.0.9 > Environment: java --version > openjdk 16.0.2 2021-07-20 > OpenJDK Runtime Environment Temurin-16.0.2+7 (build 16.0.2+7) > OpenJDK 64-Bit Server VM Temurin-16.0.2+7 (build 16.0.2+7, mixed mode, > sharing) > Reporter: Alexander Veit > Priority: Major > > We have a category class as part of our product's Groovy API that breaks > after the update from Groovy 3.0.8 (indy) to 3.0.9 (indy). > Scripts that call the category class with Integer of Long arguments throw an > exception. E.g. > {code:java} > use (org.example.Convert) > { > assert '1234' == 1234.canonicalLexicalRepresentation > } > {code} > throws > {noformat} > java.lang.IllegalArgumentException: argument type mismatch > at > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:78) > at > java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.base/java.lang.reflect.Method.invoke(Method.java:567) > at > org.codehaus.groovy.runtime.metaclass.ReflectionMetaMethod.invoke(ReflectionMetaMethod.java:54) > at > org.codehaus.groovy.runtime.metaclass.NewInstanceMetaMethod.invoke(NewInstanceMetaMethod.java:54) > at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:323) > at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:1956) > at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:3843) > at > org.codehaus.groovy.runtime.InvokerHelper.getProperty(InvokerHelper.java:199) > at > org.codehaus.groovy.runtime.callsite.PojoMetaClassGetPropertySite.getProperty(PojoMetaClassGetPropertySite.java:36) > at > org.codehaus.groovy.runtime.callsite.AbstractCallSite.callGetProperty(AbstractCallSite.java:329) > at > org.example.test.testInteger$_run_closure1.doCall(testInteger.groovy:5) > at org.example.test.testInteger$_run_closure1.doCall(testInteger.groovy) > at > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:78) > at > java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.base/java.lang.reflect.Method.invoke(Method.java:567) > at > org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:107) > at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:323) > at > org.codehaus.groovy.runtime.metaclass.ClosureMetaClass.invokeMethod(ClosureMetaClass.java:274) > at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1035) > at groovy.lang.Closure.call(Closure.java:412) > at groovy.lang.Closure.call(Closure.java:406) > at > org.codehaus.groovy.runtime.GroovyCategorySupport$ThreadCategoryInfo.use(GroovyCategorySupport.java:123) > at > org.codehaus.groovy.runtime.GroovyCategorySupport$ThreadCategoryInfo.access$300(GroovyCategorySupport.java:72) > at > org.codehaus.groovy.runtime.GroovyCategorySupport.use(GroovyCategorySupport.java:258) > at > org.codehaus.groovy.runtime.DefaultGroovyMethods.use(DefaultGroovyMethods.java:568) > at org.codehaus.groovy.runtime.dgm$880.invoke(Unknown Source) > at > org.codehaus.groovy.runtime.callsite.PogoMetaMethodSite$PogoMetaMethodSiteNoUnwrapNoCoerce.invoke(PogoMetaMethodSite.java:226) > at > org.codehaus.groovy.runtime.callsite.PogoMetaMethodSite.callCurrent(PogoMetaMethodSite.java:61) > at > org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(CallSiteArray.java:51) > at > org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:171) > at > org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:194) > at org.example.test.testInteger.run(testInteger.groovy:3) > at groovy.lang.GroovyShell.evaluate(GroovyShell.java:427) > at groovy.lang.GroovyShell.evaluate(GroovyShell.java:470) > {noformat} > The categoy class is implemented in Java and looks something like > {code:java} > public final class Convert > { > private Convert() > { > } > public static final String > getCanonicalLexicalRepresentation(CharSequence p_chseq) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Boolean > p_bool) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Byte > p_byte) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Short > p_short) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Integer > p_int) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Long p_lng) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Float > p_flt) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(Double > p_dbl) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(BigDecimal > p_decimal, boolean p_bInteger) > { > return "foo"; > } > public static final String > getCanonicalLexicalRepresentationDateTime(Date p_dt) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentationDate(Date > p_dt) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentationTime(Date > p_dt) > { > return "foo"; > } > public static final String getCanonicalLexicalRepresentation(QName > p_qnm) > { > return "foo"; > } > public static String getCanonicalLexicalRepresentation(Object p_value, > QName p_qnmType) > { > return "foo"; > } > } > {code} -- This message was sent by Atlassian Jira (v8.3.4#803005)