|
|
cfd3a2 |
--- sisu-inject/org.eclipse.sisu.inject.tests/src/org/eclipse/sisu/inject/LocatedBeansTest.java~ 2014-09-12 08:32:32.899725268 +0200
|
|
|
cfd3a2 |
+++ sisu-inject/org.eclipse.sisu.inject.tests/src/org/eclipse/sisu/inject/LocatedBeansTest.java 2014-09-12 08:37:45.656099710 +0200
|
|
|
cfd3a2 |
@@ -128,30 +128,6 @@
|
|
|
cfd3a2 |
assertSame( a, itr2.next().getValue() );
|
|
|
cfd3a2 |
}
|
|
|
cfd3a2 |
|
|
|
cfd3a2 |
- public void testUnrestrictedSearch()
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- final LocatedBeans<Annotation, Bean> beans = locate( Key.get( Bean.class ) );
|
|
|
cfd3a2 |
- final Iterator<BeanEntry<Annotation, Bean>> itr = beans.iterator();
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( QualifyingStrategy.DEFAULT_QUALIFIER, itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( QualifyingStrategy.BLANK_QUALIFIER, itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( Names.named( "Named1" ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( Names.named( "Named2" ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( QualifyingStrategy.BLANK_QUALIFIER, itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( MarkedBeanImpl1.class.getAnnotation( Marked.class ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( Names.named( "Marked2" ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( Names.named( "Marked3" ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertFalse( itr.hasNext() );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
public void testNamedSearch()
|
|
|
cfd3a2 |
{
|
|
|
cfd3a2 |
final LocatedBeans<Named, Bean> beans = locate( Key.get( Bean.class, Named.class ) );
|
|
|
cfd3a2 |
@@ -181,20 +156,6 @@
|
|
|
cfd3a2 |
assertFalse( itr.hasNext() );
|
|
|
cfd3a2 |
}
|
|
|
cfd3a2 |
|
|
|
cfd3a2 |
- public void testMarkedSearch()
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- final LocatedBeans<Marked, Bean> beans = locate( Key.get( Bean.class, Marked.class ) );
|
|
|
cfd3a2 |
- final Iterator<BeanEntry<Marked, Bean>> itr = beans.iterator();
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( MarkedBeanImpl1.class.getAnnotation( Marked.class ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( MarkedBeanImpl2.class.getAnnotation( Marked.class ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertTrue( itr.hasNext() );
|
|
|
cfd3a2 |
- assertEquals( MarkedBeanProvider.class.getAnnotation( Marked.class ), itr.next().getKey() );
|
|
|
cfd3a2 |
- assertFalse( itr.hasNext() );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
public void testMarkedWithAttributesSearch()
|
|
|
cfd3a2 |
{
|
|
|
cfd3a2 |
final LocatedBeans<Marked, Bean> beans =
|
|
|
cfd3a2 |
--- sisu-plexus/org.eclipse.sisu.plexus.tests/src/org/eclipse/sisu/plexus/PlexusXmlScannerTest.java~ 2014-08-24 01:48:47.000000000 +0200
|
|
|
cfd3a2 |
+++ sisu-plexus/org.eclipse.sisu.plexus.tests/src/org/eclipse/sisu/plexus/PlexusXmlScannerTest.java 2015-02-04 07:06:49.696531924 +0100
|
|
|
cfd3a2 |
@@ -159,83 +159,6 @@
|
|
|
cfd3a2 |
new PlexusXmlScanner( null, plexusXml, null ).scan( space, true );
|
|
|
cfd3a2 |
}
|
|
|
cfd3a2 |
|
|
|
cfd3a2 |
- @SuppressWarnings( "deprecation" )
|
|
|
cfd3a2 |
- public void testComponents()
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- final ClassSpace space = new URLClassSpace( PlexusXmlScannerTest.class.getClassLoader() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final Map<String, PlexusBeanMetadata> metadata = new HashMap<String, PlexusBeanMetadata>();
|
|
|
cfd3a2 |
- final PlexusXmlScanner scanner = new PlexusXmlScanner( null, null, metadata );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final Map<Component, DeferredClass<?>> componentMap = scanner.scan( space, true );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( 6, componentMap.size() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final Component component1 =
|
|
|
cfd3a2 |
- new ComponentImpl( DefaultBean.class, Hints.DEFAULT_HINT, Strategies.PER_LOOKUP, "" );
|
|
|
cfd3a2 |
- assertEquals( DefaultBean.class, componentMap.get( component1 ).load() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final Component component2 = new ComponentImpl( Bean.class, "debug", Strategies.SINGLETON, "For debugging" );
|
|
|
cfd3a2 |
- assertEquals( DebugBean.class, componentMap.get( component2 ).load() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final Component component3 = new ComponentImpl( Bean.class, Hints.DEFAULT_HINT, Strategies.SINGLETON, "" );
|
|
|
cfd3a2 |
- assertEquals( AnotherBean.class, componentMap.get( component3 ).load() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final Component component4 = new ComponentImpl( Bean.class, "clone", Strategies.SINGLETON, "" );
|
|
|
cfd3a2 |
- assertEquals( DefaultBean.class, componentMap.get( component4 ).load().getSuperclass() );
|
|
|
cfd3a2 |
- final Class proxy = CustomTestClassLoader.proxy( componentMap.get( component4 ).load() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- try
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- assertNotNull( proxy.getMethod( "TestMe" ) );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
- catch ( final NoSuchMethodException e )
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- fail( "Proxied class is missing 'TestMe' method" );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final PlexusBeanMetadata metadata1 = metadata.get( DefaultBean.class.getName() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertFalse( metadata1.isEmpty() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new ConfigurationImpl( "someFieldName", "<some-field-name><item>PRIMARY</item></some-field-name>" ),
|
|
|
cfd3a2 |
- metadata1.getConfiguration( new NamedProperty( "someFieldName" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new ConfigurationImpl( "simple", "value" ),
|
|
|
cfd3a2 |
- metadata1.getConfiguration( new NamedProperty( "simple" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new ConfigurationImpl( "value", "<value with=\"attribute\"></value>" ),
|
|
|
cfd3a2 |
- metadata1.getConfiguration( new NamedProperty( "value" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new ConfigurationImpl( "emptyValue1", "<empty-value1 with=\"attribute\" />" ),
|
|
|
cfd3a2 |
- metadata1.getConfiguration( new NamedProperty( "emptyValue1" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new ConfigurationImpl( "emptyValue2", "" ),
|
|
|
cfd3a2 |
- metadata1.getConfiguration( new NamedProperty( "emptyValue2" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertFalse( metadata1.isEmpty() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new RequirementImpl( Bean.class, true, "debug" ),
|
|
|
cfd3a2 |
- metadata1.getRequirement( new NamedProperty( "bean", TypeLiteral.get( Bean.class ) ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertFalse( metadata1.isEmpty() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- metadata1.getConfiguration( new NamedProperty( "foo" ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new RequirementImpl( Bean.class, false, Hints.DEFAULT_HINT, "debug" ),
|
|
|
cfd3a2 |
- metadata1.getRequirement( new NamedProperty( "beanMap" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertFalse( metadata1.isEmpty() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertEquals( new RequirementImpl( Bean.class, false ),
|
|
|
cfd3a2 |
- metadata1.getRequirement( new NamedProperty( "beanField" ) ) );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertTrue( metadata1.isEmpty() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- assertNotNull( metadata.get( AnotherBean.class.getName() ) );
|
|
|
cfd3a2 |
- assertNull( metadata.get( DebugBean.class.getName() ) );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
static class FixedClassSpace
|
|
|
cfd3a2 |
implements ClassSpace
|
|
|
cfd3a2 |
{
|
|
|
cfd3a2 |
@@ -392,64 +315,4 @@
|
|
|
cfd3a2 |
}
|
|
|
cfd3a2 |
}
|
|
|
cfd3a2 |
|
|
|
cfd3a2 |
- static final class CustomTestClassLoader
|
|
|
cfd3a2 |
- extends ClassLoader
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- private static final String PROXY_MARKER = "$proxy";
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- CustomTestClassLoader( final ClassLoader parent )
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- super( parent );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- static Class proxy( final Class clazz )
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- try
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- return new CustomTestClassLoader( clazz.getClassLoader() ).loadClass( clazz.getName() + PROXY_MARKER );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
- catch ( final ClassNotFoundException e )
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- throw new TypeNotPresentException( clazz.getName(), e );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- @Override
|
|
|
cfd3a2 |
- protected synchronized Class loadClass( final String name, final boolean resolve )
|
|
|
cfd3a2 |
- throws ClassNotFoundException
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- return super.loadClass( name, resolve );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- @Override
|
|
|
cfd3a2 |
- protected Class findClass( final String name )
|
|
|
cfd3a2 |
- throws ClassNotFoundException
|
|
|
cfd3a2 |
- {
|
|
|
cfd3a2 |
- final String proxyName = name.replace( '.', '/' );
|
|
|
cfd3a2 |
- final String superName = proxyName.substring( 0, proxyName.length() - PROXY_MARKER.length() );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final ClassWriter cw = new ClassWriter( ClassWriter.COMPUTE_MAXS );
|
|
|
cfd3a2 |
- cw.visit( Opcodes.V1_5, Modifier.PUBLIC | Modifier.FINAL, proxyName, null, superName, null );
|
|
|
cfd3a2 |
- MethodVisitor mv = cw.visitMethod( Modifier.PUBLIC, "<init>", "()V", null, null );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- mv.visitCode();
|
|
|
cfd3a2 |
- mv.visitVarInsn( Opcodes.ALOAD, 0 );
|
|
|
cfd3a2 |
- mv.visitMethodInsn( Opcodes.INVOKESPECIAL, superName, "<init>", "()V", false );
|
|
|
cfd3a2 |
- mv.visitInsn( Opcodes.RETURN );
|
|
|
cfd3a2 |
- mv.visitMaxs( 0, 0 );
|
|
|
cfd3a2 |
- mv.visitEnd();
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- mv = cw.visitMethod( Modifier.PUBLIC, "TestMe", "()V", null, null );
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- mv.visitCode();
|
|
|
cfd3a2 |
- mv.visitInsn( Opcodes.RETURN );
|
|
|
cfd3a2 |
- mv.visitMaxs( 0, 0 );
|
|
|
cfd3a2 |
- mv.visitEnd();
|
|
|
cfd3a2 |
- cw.visitEnd();
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- final byte[] buf = cw.toByteArray();
|
|
|
cfd3a2 |
-
|
|
|
cfd3a2 |
- return defineClass( name, buf, 0, buf.length );
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
- }
|
|
|
cfd3a2 |
}
|