Skip to content

Commit

Permalink
FORGE-1565: Added tests. ServiceRegistryImpl.loadClass returns the wr…
Browse files Browse the repository at this point in the history
…ong class though
  • Loading branch information
gastaldi committed Feb 10, 2014
1 parent d4ffc57 commit d4f0db9
Show file tree
Hide file tree
Showing 4 changed files with 196 additions and 2 deletions.
22 changes: 22 additions & 0 deletions tests/src/main/java/test/org/jboss/forge/furnace/mocks/Aa.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package test.org.jboss.forge.furnace.mocks;
/**
* Copyright 2014 Red Hat, Inc. and/or its affiliates.
*
* Licensed under the Eclipse Public License version 1.0, available at
* http://www.eclipse.org/legal/epl-v10.html
*/


/**
* Keep the class name. The Hashcode should be the same as BB
*
* @author <a href="ggastald@redhat.com">George Gastaldi</a>
*/
public class Aa
{
public static void main(String[] args) throws Exception
{
System.out.println("test.Aa".hashCode());
System.out.println("test.BB".hashCode());
}
}
16 changes: 16 additions & 0 deletions tests/src/main/java/test/org/jboss/forge/furnace/mocks/BB.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package test.org.jboss.forge.furnace.mocks;
/**
* Copyright 2014 Red Hat, Inc. and/or its affiliates.
*
* Licensed under the Eclipse Public License version 1.0, available at
* http://www.eclipse.org/legal/epl-v10.html
*/

/**
* Keep the class name. The Hashcode should be the same as Aa
*
* @author <a href="ggastald@redhat.com">George Gastaldi</a>
*/
public class BB
{
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,126 @@
/**
* Copyright 2013 Red Hat, Inc. and/or its affiliates.
*
* Licensed under the Eclipse Public License version 1.0, available at
* http://www.eclipse.org/legal/epl-v10.html
*/

package test.org.jboss.forge.furnace.addons;

import static org.hamcrest.CoreMatchers.instanceOf;
import static org.hamcrest.CoreMatchers.is;

import java.util.Iterator;

import javax.inject.Inject;

import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.forge.arquillian.AddonDependency;
import org.jboss.forge.arquillian.Dependencies;
import org.jboss.forge.arquillian.archive.ForgeArchive;
import org.jboss.forge.furnace.addons.Addon;
import org.jboss.forge.furnace.addons.AddonId;
import org.jboss.forge.furnace.addons.AddonRegistry;
import org.jboss.forge.furnace.repositories.AddonDependencyEntry;
import org.jboss.forge.furnace.services.Imported;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;

import test.org.jboss.forge.furnace.mocks.Aa;
import test.org.jboss.forge.furnace.mocks.BB;

/**
*
* @author <a href="ggastald@redhat.com">George Gastaldi</a>
*/
@RunWith(Arquillian.class)
public class AddonRegistryMultipleAddonsTest
{

@Deployment
@Dependencies({
@AddonDependency(name = "org.jboss.forge.furnace.container:cdi")
})
public static ForgeArchive getDeployment()
{
ForgeArchive archive = ShrinkWrap.create(ForgeArchive.class)
.addBeansXML()
.addAsAddonDependencies(
AddonDependencyEntry.create("org.jboss.forge.furnace.container:cdi"),
AddonDependencyEntry.create("test:dep2"),
AddonDependencyEntry.create("test:dep1")

);

return archive;
}

@Deployment(name = "test:dep2,2", testable = false, order = 2)
public static ForgeArchive getDeploymentDep2()
{
ForgeArchive archive = ShrinkWrap.create(ForgeArchive.class)
.addClass(BB.class)
.addBeansXML()
.addAsAddonDependencies(
AddonDependencyEntry.create("org.jboss.forge.furnace.container:cdi")
);
return archive;
}

@Deployment(name = "test:dep1,1", testable = false, order = 1)
public static ForgeArchive getDeploymentDep1()
{
ForgeArchive archive = ShrinkWrap
.create(ForgeArchive.class)
.addClass(Aa.class)
.addBeansXML()
.addAsAddonDependencies(
AddonDependencyEntry.create("org.jboss.forge.furnace.container:cdi")
);

return archive;
}

@Inject
private AddonRegistry addonRegistry;

@Test
public void testServiceContainedWithExpectedObjectsDifferentClassLoaders() throws Exception
{
AddonId depOneId = AddonId.from("test:dep1", "1");
AddonId depTwoId = AddonId.from("test:dep2", "2");

Addon depOne = addonRegistry.getAddon(depOneId);
Addon depTwo = addonRegistry.getAddon(depTwoId);

Assert.assertTrue(depOne.getServiceRegistry().hasService(Aa.class));
Assert.assertFalse(depOne.getServiceRegistry().hasService(BB.class));

Assert.assertFalse(depTwo.getServiceRegistry().hasService(Aa.class));
Assert.assertTrue(depTwo.getServiceRegistry().hasService(BB.class));
}

@Test
public void testImportedWithExpectedObjectsDifferentClassLoaders() throws Exception
{
Imported<Aa> services = addonRegistry.getServices(Aa.class);
Assert.assertFalse("Imported<Aa> should have been satisfied", services.isUnsatisfied());
Assert.assertFalse("Imported<Aa> should not have been ambiguous", services.isAmbiguous());
Iterator<Aa> iterator = services.iterator();
Assert.assertTrue(iterator.hasNext());
Assert.assertThat(iterator.next(), is(instanceOf(Aa.class)));
Assert.assertFalse(iterator.hasNext());

Imported<BB> services2 = addonRegistry.getServices(BB.class);
Assert.assertFalse("Imported<BB> should have been satisfied", services.isUnsatisfied());
Assert.assertFalse("Imported<BB> should not have been ambiguous", services.isAmbiguous());
Iterator<BB> iterator2 = services2.iterator();
Assert.assertTrue(iterator2.hasNext());
Assert.assertThat(iterator2.next(), is(instanceOf(BB.class)));
Assert.assertFalse(iterator2.hasNext());
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,11 @@

package test.org.jboss.forge.furnace.addons;

import static org.hamcrest.CoreMatchers.instanceOf;
import static org.hamcrest.CoreMatchers.is;

import java.util.Iterator;

import javax.inject.Inject;

import org.jboss.arquillian.container.test.api.Deployment;
Expand All @@ -22,7 +27,9 @@
import org.junit.Test;
import org.junit.runner.RunWith;

import test.org.jboss.forge.furnace.mocks.BB;
import test.org.jboss.forge.furnace.mocks.PlainBean;
import test.org.jboss.forge.furnace.mocks.Aa;
import test.org.jboss.forge.furnace.mocks.PlainInterface;
import test.org.jboss.forge.furnace.mocks.PlainQualifier;
import test.org.jboss.forge.furnace.mocks.QualifiedPlainBean;
Expand All @@ -42,9 +49,11 @@ public class AddonRegistryTest
})
public static ForgeArchive getDeployment()
{
ForgeArchive archive = ShrinkWrap.create(ForgeArchive.class)
ForgeArchive archive = ShrinkWrap
.create(ForgeArchive.class)
.addClasses(PlainInterface.class, PlainBean.class,
PlainQualifier.class, QualifiedPlainBean.class, ServiceInterface.class, ServiceBean.class)
PlainQualifier.class, QualifiedPlainBean.class, ServiceInterface.class, ServiceBean.class,
Aa.class, BB.class)
.addAsAddonDependencies(
AddonDependencyEntry.create("org.jboss.forge.furnace.container:cdi")
)
Expand Down Expand Up @@ -76,4 +85,25 @@ public void testImportedWithQualifiers() throws Exception
Assert.assertTrue(services.iterator().hasNext());
Assert.assertNotNull(services.iterator().next());
}

@Test
public void testImportedWithExpectedObjectsSameClassLoader() throws Exception
{
Imported<Aa> services = addonRegistry.getServices(Aa.class);
Assert.assertFalse(services.isUnsatisfied());
Assert.assertFalse(services.isAmbiguous());
Iterator<Aa> iterator = services.iterator();
Assert.assertTrue(iterator.hasNext());
Assert.assertThat(iterator.next(), is(instanceOf(Aa.class)));
Assert.assertFalse(iterator.hasNext());

Imported<BB> services2 = addonRegistry.getServices(BB.class);
Assert.assertFalse(services2.isUnsatisfied());
Assert.assertFalse(services2.isAmbiguous());
Iterator<BB> iterator2 = services2.iterator();
Assert.assertTrue(iterator2.hasNext());
Assert.assertThat(iterator2.next(), is(instanceOf(BB.class)));
Assert.assertFalse(iterator2.hasNext());
}

}

0 comments on commit d4f0db9

Please sign in to comment.