1
2
3
4
5
6
7 package org.mule.test.integration.spring.events;
8
9 import org.mule.api.MuleEventContext;
10 import org.mule.api.MuleMessage;
11 import org.mule.module.client.MuleClient;
12 import org.mule.tck.functional.EventCallback;
13 import org.mule.tck.junit4.FunctionalTestCase;
14 import org.mule.tck.junit4.rule.DynamicPort;
15
16 import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicInteger;
17 import org.junit.Rule;
18 import org.junit.Test;
19
20 import static org.junit.Assert.assertEquals;
21 import static org.junit.Assert.assertNotNull;
22
23 public class MuleEventMulticasterTestCase extends FunctionalTestCase
24 {
25
26 private final AtomicInteger eventCount = new AtomicInteger(0);
27
28 @Rule
29 public DynamicPort dynamicPort = new DynamicPort("port1");
30
31 @Override
32 protected String getConfigResources()
33 {
34 return "org/mule/test/integration/spring/events/mule-events-example-app-context.xml";
35 }
36
37 @Override
38 protected void doSetUp() throws Exception
39 {
40 eventCount.set(0);
41 }
42
43 @Test
44 public void testReceiveAsWebService() throws Exception
45 {
46 MuleClient client = new MuleClient(muleContext);
47 OrderManagerBean orderManager = muleContext.getRegistry().get("orderManagerBean");
48 assertNotNull(orderManager);
49 EventCallback callback = new EventCallback()
50 {
51 public void eventReceived(MuleEventContext context, Object o) throws Exception
52 {
53 eventCount.incrementAndGet();
54 }
55 };
56 orderManager.setEventCallback(callback);
57
58 Order order = new Order("Sausage and Mash");
59 MuleMessage result = client.send("axis:http://localhost:" + dynamicPort.getNumber() + "/mule/orderManager?method=processOrder", order,
60 null);
61
62 assertNotNull(result);
63 assertEquals("Order 'Sausage and Mash' Processed", (result.getPayload()));
64 }
65 }