package org.zstack.test.core.cloudbus;
import junit.framework.Assert;
import org.junit.Before;
import org.junit.Test;
import org.zstack.core.cloudbus.EventCallback;
import org.zstack.core.cloudbus.EventFacade;
import org.zstack.core.cloudbus.EventFacadeImpl;
import org.zstack.core.componentloader.ComponentLoader;
import org.zstack.test.BeanConstructor;
import org.zstack.utils.Utils;
import org.zstack.utils.logging.CLogger;
import java.util.Map;
import java.util.concurrent.TimeUnit;
/**
* Created with IntelliJ IDEA.
* User: frank
* Time: 12:38 AM
* To change this template use File | Settings | File Templates.
*/
public class TestCanonicalEvent10 {
CLogger logger = Utils.getLogger(TestCanonicalEvent10.class);
ComponentLoader loader;
EventFacade evtf;
int count;
@Before
public void setUp() throws Exception {
BeanConstructor con = new BeanConstructor();
loader = con.build();
evtf = loader.getComponent(EventFacade.class);
((EventFacadeImpl) evtf).start();
}
@Test
public void test() throws InterruptedException {
String path = "/test/event";
EventCallback cb = new EventCallback() {
{
uniqueIdentity = "test";
}
@Override
public void run(Map tokens, Object data) {
count++;
}
};
EventCallback cb1 = new EventCallback() {
{
uniqueIdentity = "test";
}
@Override
public void run(Map tokens, Object data) {
count++;
}
};
evtf.on(path, cb);
evtf.on(path, cb1);
evtf.fire(path, null);
TimeUnit.SECONDS.sleep(1);
Assert.assertEquals(1, count);
}
}