package org.zstack.test.core.cloudbus;
import junit.framework.Assert;
import org.junit.Before;
import org.junit.Test;
import org.zstack.core.Platform;
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 TestCanonicalEvent2 {
CLogger logger = Utils.getLogger(TestCanonicalEvent2.class);
ComponentLoader loader;
EventFacade evtf;
String ret;
String retUuid;
@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/{uuid}";
final String uuid = Platform.getUuid();
evtf.on(path, new EventCallback<String>() {
@Override
public void run(Map<String, String> tokens, String data) {
retUuid = tokens.get("uuid");
ret = data;
}
});
String sample = "hello, world";
String concretePath = String.format("/test/event/%s", uuid);
evtf.fire(concretePath, sample);
TimeUnit.SECONDS.sleep(1);
Assert.assertTrue(sample.equals(ret));
Assert.assertTrue(retUuid.equals(uuid));
}
}