1
2
3
4
5
6
7
8
9
10
11 package org.mule.module.rss;
12
13 import org.mule.api.MuleEventContext;
14 import org.mule.api.MuleMessage;
15 import org.mule.api.client.MuleClient;
16 import org.mule.tck.functional.EventCallback;
17 import org.mule.tck.functional.FunctionalTestComponent;
18 import org.mule.tck.junit4.FunctionalTestCase;
19 import org.mule.util.concurrent.Latch;
20
21 import com.sun.syndication.feed.synd.SyndFeed;
22
23 import java.io.InputStream;
24 import java.util.concurrent.TimeUnit;
25
26 import org.junit.Test;
27
28 import static org.junit.Assert.assertEquals;
29 import static org.junit.Assert.assertTrue;
30
31 public class RssFeedConsumeAndTransformTestCase extends FunctionalTestCase
32 {
33 private Latch receiveLatch = new Latch();
34 private MuleMessage message = null;
35
36 @Override
37 protected String getConfigResources()
38 {
39 return "rss-consume-transform-feed.xml";
40 }
41
42 @Override
43 protected void doSetUp() throws Exception
44 {
45 FunctionalTestComponent comp = (FunctionalTestComponent)getComponent("feedTransformer");
46 comp.setEventCallback(new EventCallback()
47 {
48 @Override
49 public void eventReceived(MuleEventContext context, Object component) throws Exception
50 {
51 message = context.getMessage();
52 receiveLatch.countDown();
53 }
54 });
55 }
56
57 @Test
58 public void testSendFeed() throws Exception
59 {
60 InputStream input = SampleFeed.feedAsStream();
61
62 MuleClient client = muleContext.getClient();
63 client.dispatch("vm://fromTest", input, null);
64
65 assertTrue(receiveLatch.await(RECEIVE_TIMEOUT, TimeUnit.MILLISECONDS));
66
67 Object payload = message.getPayload();
68 assertTrue(payload instanceof SyndFeed);
69
70 SyndFeed feed = (SyndFeed) payload;
71 assertEquals(25, feed.getEntries().size());
72 }
73 }