-
Notifications
You must be signed in to change notification settings - Fork 290
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
WELD-2763 Correct how Weld chooses proxy package when a bean has unas…
…signable interface type
- Loading branch information
Showing
11 changed files
with
204 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
16 changes: 16 additions & 0 deletions
16
...rc/test/java/org/jboss/weld/tests/classDefining/unimplemented/interfaces/MyExtension.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces; | ||
|
||
import jakarta.enterprise.event.Observes; | ||
import jakarta.enterprise.inject.spi.Extension; | ||
import jakarta.enterprise.inject.spi.ProcessBeanAttributes; | ||
|
||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.NotImplementedIface; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.impl.CDIBean; | ||
|
||
public class MyExtension implements Extension { | ||
|
||
public void pba(@Observes ProcessBeanAttributes<CDIBean> pba) { | ||
// add the type of the interface the class doesn't directly implement | ||
pba.configureBeanAttributes().addType(NotImplementedIface.class); | ||
} | ||
} |
45 changes: 45 additions & 0 deletions
45
...ining/unimplemented/interfaces/ProxyCreationForCdiBeanWithUnimplementedInterfaceTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces; | ||
|
||
import jakarta.enterprise.inject.spi.Extension; | ||
import jakarta.inject.Inject; | ||
|
||
import org.jboss.arquillian.container.test.api.Deployment; | ||
import org.jboss.arquillian.junit.Arquillian; | ||
import org.jboss.shrinkwrap.api.Archive; | ||
import org.jboss.shrinkwrap.api.BeanArchive; | ||
import org.jboss.shrinkwrap.api.ShrinkWrap; | ||
import org.jboss.weld.test.util.Utils; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.BeanIface; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.NotImplementedIface; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.impl.CDIBean; | ||
import org.junit.Assert; | ||
import org.junit.Test; | ||
import org.junit.runner.RunWith; | ||
|
||
@RunWith(Arquillian.class) | ||
public class ProxyCreationForCdiBeanWithUnimplementedInterfaceTest { | ||
|
||
@Deployment | ||
public static Archive<?> deploy() { | ||
return ShrinkWrap.create(BeanArchive.class, Utils.getDeploymentNameAsHash(ProxyCreationForEjbLocalTest.class)) | ||
.addClasses(MyExtension.class, ProxyCreationForCdiBeanWithUnimplementedInterfaceTest.class, CDIBean.class, | ||
NotImplementedIface.class, BeanIface.class) | ||
.addAsServiceProvider(Extension.class, MyExtension.class); | ||
} | ||
|
||
@Inject | ||
NotImplementedIface cdiBean; | ||
|
||
@Test | ||
public void testProxyPackageMatchesTheClass() { | ||
// sanity check of the testing setup | ||
Assert.assertEquals(NotImplementedIface.class.getSimpleName(), cdiBean.ping3()); | ||
|
||
// The assertion is based solely on inspecting the proxy format - expected package and first mentioned class | ||
// We cannot rely on verifying that the class can be defined because if this runs on WFLY, it is a non-issue | ||
// due to using ClassLoader#defineClass. The mismatch only shows when using MethodHandles.Lookup | ||
// see https://github.com/jakartaee/platform-tck/issues/1194 for more information | ||
Assert.assertEquals(CDIBean.class.getPackage(), cdiBean.getClass().getPackage()); | ||
Assert.assertTrue(cdiBean.getClass().getName().startsWith(CDIBean.class.getName())); | ||
} | ||
} |
53 changes: 53 additions & 0 deletions
53
...jboss/weld/tests/classDefining/unimplemented/interfaces/ProxyCreationForEjbLocalTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces; | ||
|
||
import jakarta.inject.Inject; | ||
|
||
import org.jboss.arquillian.container.test.api.Deployment; | ||
import org.jboss.arquillian.junit.Arquillian; | ||
import org.jboss.shrinkwrap.api.Archive; | ||
import org.jboss.shrinkwrap.api.BeanArchive; | ||
import org.jboss.shrinkwrap.api.ShrinkWrap; | ||
import org.jboss.weld.test.util.Utils; | ||
import org.jboss.weld.tests.category.Integration; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.LocalInterface1; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.LocalInterface2; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.NotImplementedButDeclaredInterface; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.impl.StatelessLocalBean; | ||
import org.junit.Assert; | ||
import org.junit.Test; | ||
import org.junit.experimental.categories.Category; | ||
import org.junit.runner.RunWith; | ||
|
||
@Category(Integration.class) | ||
@RunWith(Arquillian.class) | ||
public class ProxyCreationForEjbLocalTest { | ||
|
||
@Deployment | ||
public static Archive<?> deploy() { | ||
return ShrinkWrap.create(BeanArchive.class, Utils.getDeploymentNameAsHash(ProxyCreationForEjbLocalTest.class)) | ||
.addClasses(ProxyCreationForEjbLocalTest.class, LocalInterface1.class, LocalInterface2.class, | ||
NotImplementedButDeclaredInterface.class, StatelessLocalBean.class); | ||
} | ||
|
||
@Inject | ||
StatelessLocalBean bean1; | ||
|
||
@Inject | ||
NotImplementedButDeclaredInterface bean2; | ||
|
||
@Test | ||
public void testProxyPackageMatchesTheClass() { | ||
// sanity check of the testing setup | ||
Assert.assertEquals(LocalInterface1.class.getSimpleName(), bean1.ping1()); | ||
|
||
// also assert invoking the method from the interface bean doesn't implement directly | ||
Assert.assertEquals(NotImplementedButDeclaredInterface.class.getSimpleName(), bean2.ping3()); | ||
|
||
// The assertion is based solely on inspecting the proxy format - expected package and first mentioned class | ||
// We cannot rely on verifying that the class can be defined because this runs on WFLY which directly uses | ||
// ClassLoader#defineClass in which case it's a non-issue. The mismatch only shows when using MethodHandles.Lookup | ||
// see https://github.com/jakartaee/platform-tck/issues/1194 for more information | ||
Assert.assertEquals(StatelessLocalBean.class.getPackage(), bean1.getClass().getPackage()); | ||
Assert.assertTrue(bean1.getClass().getName().startsWith(StatelessLocalBean.class.getName())); | ||
} | ||
} |
5 changes: 5 additions & 0 deletions
5
...st/java/org/jboss/weld/tests/classDefining/unimplemented/interfaces/ifaces/BeanIface.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces; | ||
|
||
public interface BeanIface { | ||
String ping1(); | ||
} |
5 changes: 5 additions & 0 deletions
5
...a/org/jboss/weld/tests/classDefining/unimplemented/interfaces/ifaces/LocalInterface1.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces; | ||
|
||
public interface LocalInterface1 { | ||
String ping1(); | ||
} |
5 changes: 5 additions & 0 deletions
5
...a/org/jboss/weld/tests/classDefining/unimplemented/interfaces/ifaces/LocalInterface2.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces; | ||
|
||
public interface LocalInterface2 { | ||
String ping2(); | ||
} |
8 changes: 8 additions & 0 deletions
8
...sts/classDefining/unimplemented/interfaces/ifaces/NotImplementedButDeclaredInterface.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces; | ||
|
||
import jakarta.ejb.Local; | ||
|
||
@Local | ||
public interface NotImplementedButDeclaredInterface extends LocalInterface1 { | ||
String ping3(); | ||
} |
5 changes: 5 additions & 0 deletions
5
...g/jboss/weld/tests/classDefining/unimplemented/interfaces/ifaces/NotImplementedIface.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces; | ||
|
||
public interface NotImplementedIface { | ||
String ping3(); | ||
} |
20 changes: 20 additions & 0 deletions
20
...c/test/java/org/jboss/weld/tests/classDefining/unimplemented/interfaces/impl/CDIBean.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.impl; | ||
|
||
import jakarta.enterprise.context.ApplicationScoped; | ||
|
||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.BeanIface; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.NotImplementedIface; | ||
|
||
// Plain CDI bean which doesn't implement one interface but has its method | ||
// A CDI extension attempts to add this type programatically | ||
@ApplicationScoped | ||
public class CDIBean implements BeanIface { | ||
@Override | ||
public String ping1() { | ||
return BeanIface.class.getSimpleName(); | ||
} | ||
|
||
public String ping3() { | ||
return NotImplementedIface.class.getSimpleName(); | ||
} | ||
} |
31 changes: 31 additions & 0 deletions
31
.../org/jboss/weld/tests/classDefining/unimplemented/interfaces/impl/StatelessLocalBean.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
package org.jboss.weld.tests.classDefining.unimplemented.interfaces.impl; | ||
|
||
import jakarta.ejb.Local; | ||
import jakarta.ejb.LocalBean; | ||
import jakarta.ejb.Stateless; | ||
|
||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.LocalInterface1; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.LocalInterface2; | ||
import org.jboss.weld.tests.classDefining.unimplemented.interfaces.ifaces.NotImplementedButDeclaredInterface; | ||
|
||
// NOTE: the bean intentionally declares NotImplementedButDeclaredInterface but does *not* implement it directly | ||
@Stateless | ||
@LocalBean | ||
@Local({ LocalInterface1.class, LocalInterface2.class, | ||
NotImplementedButDeclaredInterface.class }) | ||
public class StatelessLocalBean implements LocalInterface1, LocalInterface2 { | ||
|
||
@Override | ||
public String ping1() { | ||
return LocalInterface1.class.getSimpleName(); | ||
} | ||
|
||
@Override | ||
public String ping2() { | ||
return LocalInterface2.class.getSimpleName(); | ||
} | ||
|
||
public String ping3() { | ||
return NotImplementedButDeclaredInterface.class.getSimpleName(); | ||
} | ||
} |