package org.zstack.test.core.cloudbus; import junit.framework.Assert; import org.junit.Before; import org.junit.Test; import org.zstack.core.cloudbus.CloudBusIN; import org.zstack.core.componentloader.ComponentLoader; import org.zstack.header.AbstractService; import org.zstack.header.Service; import org.zstack.header.message.Message; import org.zstack.header.message.MessageReply; import org.zstack.header.message.NeedReplyMessage; import org.zstack.test.BeanConstructor; import org.zstack.utils.Utils; import org.zstack.utils.logging.CLogger; import java.util.ArrayList; import java.util.List; import java.util.concurrent.TimeUnit; public class TestCloudBusMultiCallTimeout { CLogger logger = Utils.getLogger(TestCloudBusMultiCallTimeout.class); ComponentLoader loader; CloudBusIN bus; Service serv; int msgNum = 10; int ignoreMsgIndex = 5; public static class HelloWorldMsg extends NeedReplyMessage { private int index; public int getIndex() { return index; } public void setIndex(int index) { this.index = index; } } public static class HelloWorldReply extends MessageReply { private int index; public int getIndex() { return index; } public void setIndex(int index) { this.index = index; } } class FakeService extends AbstractService { @Override public boolean start() { bus.registerService(this); bus.activeService(this); return true; } @Override public boolean stop() { bus.deActiveService(this); bus.unregisterService(this); return true; } @Override public void handleMessage(Message msg) { if (msg.getClass() == HelloWorldMsg.class) { HelloWorldMsg hmsg = (HelloWorldMsg) msg; HelloWorldReply r = new HelloWorldReply(); r.setIndex(hmsg.getIndex()); if (hmsg.getIndex() != ignoreMsgIndex) { bus.reply(msg, r); } } } @Override public String getId() { return this.getClass().getCanonicalName(); } } @Before public void setUp() throws Exception { BeanConstructor con = new BeanConstructor(); loader = con.build(); bus = loader.getComponent(CloudBusIN.class); serv = new FakeService(); serv.start(); } @Test public void test() throws InterruptedException, ClassNotFoundException { List<HelloWorldMsg> msgs = new ArrayList<HelloWorldMsg>(msgNum); for (int i = 0; i < msgNum; i++) { HelloWorldMsg msg = new HelloWorldMsg(); msg.setIndex(i); msg.setServiceId(FakeService.class.getCanonicalName()); msg.setTimeout(TimeUnit.SECONDS.toMillis(2)); msgs.add(msg); } List<MessageReply> rs = bus.call(msgs); serv.stop(); for (MessageReply r : rs) { if (!r.isSuccess()) { Assert.assertEquals(rs.indexOf(r), this.ignoreMsgIndex); } } } }