Merge pull request #32 from durron597/master

Fixed bug #31
This commit is contained in:
bennidi 2013-05-21 13:47:45 -07:00
commit 16f92eee06
3 changed files with 48 additions and 0 deletions

View File

@ -62,6 +62,8 @@ public class ReflectionUtils {
public static Collection<Class> getSuperclasses(Class from) {
Collection<Class> superclasses = new LinkedList<Class>();
// collectInterfaces needs to come first otherwise you call it on class "Object"
collectInterfaces(from, superclasses);
while (!from.equals(Object.class) && !from.isInterface()) {
superclasses.add(from.getSuperclass());
collectInterfaces(from, superclasses);

View File

@ -0,0 +1,36 @@
package net.engio.mbassy;
import net.engio.mbassy.bus.BusConfiguration;
import net.engio.mbassy.bus.MBassador;
import net.engio.mbassy.common.DeadMessage;
import net.engio.mbassy.listener.Handler;
import net.engio.mbassy.messages.ITestMessage;
import net.engio.mbassy.messages.TestMessage3;
import org.junit.Assert;
import org.junit.Test;
/**
* A test to make sure that Interface subscriptions are working correctly
*
* @author durron597
*/
public class InterfaceTest {
@Test
public void testMBassador() {
MBassador<ITestMessage> bus = new MBassador<ITestMessage>(BusConfiguration.Default());
bus.subscribe(this);
TestMessage3 myFoo = new TestMessage3();
bus.publish(myFoo);
}
@Handler
public void handleFoo(ITestMessage f) {
Assert.assertTrue(f instanceof TestMessage3);
}
@Handler
public void handleDead(DeadMessage d) {
Assert.fail("This class should handle this message appropriately!");
}
}

View File

@ -0,0 +1,10 @@
package net.engio.mbassy.messages;
/**
* A test message that uses an interface
*
* @author durron597
*/
public class TestMessage3 implements ITestMessage {
}