You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@camel.apache.org by da...@apache.org on 2013/09/17 09:35:00 UTC

[2/3] CAMEL-6584: camel-splunk component. Thanks to Preben Asmussen for the contribution.

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/main/resources/META-INF/LICENSE.txt
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/main/resources/META-INF/LICENSE.txt b/components/camel-splunk/src/main/resources/META-INF/LICENSE.txt
new file mode 100644
index 0000000..6b0b127
--- /dev/null
+++ b/components/camel-splunk/src/main/resources/META-INF/LICENSE.txt
@@ -0,0 +1,203 @@
+
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed under the Apache License, Version 2.0 (the "License");
+   you may not use this file except in compliance with the License.
+   You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+   Unless required by applicable law or agreed to in writing, software
+   distributed under the License is distributed on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+   See the License for the specific language governing permissions and
+   limitations under the License.
+

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/main/resources/META-INF/NOTICE.txt
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/main/resources/META-INF/NOTICE.txt b/components/camel-splunk/src/main/resources/META-INF/NOTICE.txt
new file mode 100644
index 0000000..2e215bf
--- /dev/null
+++ b/components/camel-splunk/src/main/resources/META-INF/NOTICE.txt
@@ -0,0 +1,11 @@
+   =========================================================================
+   ==  NOTICE file corresponding to the section 4 d of                    ==
+   ==  the Apache License, Version 2.0,                                   ==
+   ==  in this case for the Apache Camel distribution.                    ==
+   =========================================================================
+
+   This product includes software developed by
+   The Apache Software Foundation (http://www.apache.org/).
+
+   Please read the different LICENSE files present in the licenses directory of
+   this distribution.

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/main/resources/META-INF/services/org/apache/camel/component/splunk
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/main/resources/META-INF/services/org/apache/camel/component/splunk b/components/camel-splunk/src/main/resources/META-INF/services/org/apache/camel/component/splunk
new file mode 100644
index 0000000..2d3de8d
--- /dev/null
+++ b/components/camel-splunk/src/main/resources/META-INF/services/org/apache/camel/component/splunk
@@ -0,0 +1,17 @@
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements.  See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License.  You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+class=org.apache.camel.component.splunk.SplunkComponent

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ConsumerTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ConsumerTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ConsumerTest.java
new file mode 100644
index 0000000..c16813f
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ConsumerTest.java
@@ -0,0 +1,68 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk;
+
+import java.io.InputStream;
+import java.util.Map;
+
+import com.splunk.Job;
+import com.splunk.JobCollection;
+import org.apache.camel.Exchange;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.junit.Test;
+
+import static org.mockito.Matchers.anyMap;
+import static org.mockito.Matchers.anyString;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+
+public class ConsumerTest extends SplunkMockTestSupport {
+
+    @Test
+    public void testSearch() throws Exception {
+        MockEndpoint searchMock = getMockEndpoint("mock:search-result");
+        searchMock.expectedMessageCount(3);
+        searchMock.expectedPropertyReceived(Exchange.BATCH_SIZE, 3);
+        JobCollection jobCollection = mock(JobCollection.class);
+        Job jobMock = mock(Job.class);
+        when(service.getJobs()).thenReturn(jobCollection);
+        when(jobCollection.create(anyString(), anyMap())).thenReturn(jobMock);
+        when(jobMock.isDone()).thenReturn(Boolean.TRUE);
+        InputStream stream = ConsumerTest.class.getResourceAsStream("/resultsreader_test_data.json");
+        when(jobMock.getResults(anyMap())).thenReturn(stream);
+
+        assertMockEndpointsSatisfied();
+        SplunkEvent recieved = searchMock.getReceivedExchanges().get(0).getIn().getBody(SplunkEvent.class);
+        assertNotNull(recieved);
+        Map<String, String> data = recieved.getEventData();
+        assertEquals("indexertpool", data.get("name"));
+        assertEquals(true, searchMock.getReceivedExchanges().get(2).getProperty(Exchange.BATCH_COMPLETE, Boolean.class));
+        stream.close();
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("splunk://normal?delay=5s&username=foo&password=bar&initEarliestTime=-10s&latestTime=now&search=search index=myindex&sourceType=testSource")
+                        .to("mock:search-result");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/Helper.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/Helper.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/Helper.java
new file mode 100644
index 0000000..cd9194c
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/Helper.java
@@ -0,0 +1,86 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk;
+
+import java.io.IOException;
+import java.net.Socket;
+import java.util.Map;
+
+import com.splunk.Args;
+import com.splunk.Index;
+import com.splunk.IndexCollection;
+import com.splunk.Input;
+import com.splunk.InputCollection;
+import com.splunk.Service;
+
+import static org.mockito.Matchers.anyInt;
+import static org.mockito.Matchers.anyString;
+import static org.mockito.Matchers.isA;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+
+public final class Helper {
+
+    private Helper() {
+    }
+
+    public static DefaultSplunkConfigurationFactory mockComponent(final Service service, final Socket socket) {
+        return new DefaultSplunkConfigurationFactory() {
+            @Override
+            public SplunkConfiguration parseMap(Map<String, Object> parameters) {
+                return new MockConnectionSettings(service, socket);
+            }
+        };
+    }
+
+}
+
+final class MockConnectionSettings extends SplunkConfiguration {
+    private Service service;
+    private Socket socket;
+
+    public MockConnectionSettings(Service service, Socket socket) {
+        super("foo", "bar");
+        this.service = service;
+        this.socket = socket;
+        mockSplunkWriterApi();
+    }
+
+    private void mockSplunkWriterApi() {
+        try {
+            Index index = mock(Index.class);
+            IndexCollection indexColl = mock(IndexCollection.class);
+            when(service.getIndexes()).thenReturn(indexColl);
+            InputCollection inputCollection = mock(InputCollection.class);
+            when(service.getInputs()).thenReturn(inputCollection);
+            Input input = mock(Input.class);
+            when(service.open(anyInt())).thenReturn(socket);
+            when(inputCollection.get(anyString())).thenReturn(input);
+            when(indexColl.get(anyString())).thenReturn(index);
+            when(index.attach(isA(Args.class))).thenReturn(socket);
+            when(socket.getOutputStream()).thenReturn(System.out);
+        } catch (IOException e) {
+            throw new RuntimeException(e);
+        }
+    }
+
+    @Override
+    public Service createService() {
+        return service;
+    }
+
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ProducerTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ProducerTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ProducerTest.java
new file mode 100644
index 0000000..dbbb02c
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/ProducerTest.java
@@ -0,0 +1,94 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk;
+
+import org.apache.camel.EndpointInject;
+import org.apache.camel.Producer;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.apache.camel.component.splunk.support.StreamDataWriter;
+import org.apache.camel.component.splunk.support.SubmitDataWriter;
+import org.apache.camel.component.splunk.support.TcpDataWriter;
+import org.junit.Test;
+
+public class ProducerTest extends SplunkMockTestSupport {
+
+    @EndpointInject(uri = "splunk://stream")
+    protected SplunkEndpoint streamEndpoint;
+
+    @EndpointInject(uri = "splunk://submit")
+    protected SplunkEndpoint submitEndpoint;
+
+    @EndpointInject(uri = "splunk://tcp")
+    protected SplunkEndpoint tcpEndpoint;
+
+    @Test
+    public void testStreamWriter() throws Exception {
+        MockEndpoint mock = getMockEndpoint("mock:stream-result");
+        mock.setExpectedMessageCount(1);
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key11", "value1");
+        splunkEvent.addPair("key22", "value2");
+        splunkEvent.addPair("key33", "value3");
+        template.sendBody("direct:stream", splunkEvent);
+        assertMockEndpointsSatisfied();
+        Producer streamProducer = streamEndpoint.createProducer();
+        assertIsInstanceOf(StreamDataWriter.class, ((SplunkProducer) streamProducer).getDataWriter());
+    }
+
+    @Test
+    public void testSubmitWriter() throws Exception {
+        MockEndpoint mock = getMockEndpoint("mock:submitresult");
+        mock.setExpectedMessageCount(1);
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key1", "value1");
+        splunkEvent.addPair("key2", "value2");
+        splunkEvent.addPair("key3", "value1");
+        template.sendBody("direct:submit", splunkEvent);
+        assertMockEndpointsSatisfied();
+        Producer submitProducer = submitEndpoint.createProducer();
+        assertIsInstanceOf(SubmitDataWriter.class, ((SplunkProducer) submitProducer).getDataWriter());
+    }
+
+    @Test
+    public void testTcpWriter() throws Exception {
+        MockEndpoint mock = getMockEndpoint("mock:tcpresult");
+        mock.setExpectedMessageCount(1);
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key1", "value1");
+        splunkEvent.addPair("key2", "value2");
+        splunkEvent.addPair("key3", "value3");
+        template.sendBody("direct:tcp", splunkEvent);
+        assertMockEndpointsSatisfied();
+        Producer tcpProducer = tcpEndpoint.createProducer();
+        assertIsInstanceOf(TcpDataWriter.class, ((SplunkProducer) tcpProducer).getDataWriter());
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("direct:stream").to("splunk://stream?username=foo&password=bar&index=myindex&sourceType=StreamSourceType&source=StreamSource").to("mock:stream-result");
+
+                from("direct:submit").to("splunk://submit?username=foo&password=bar&index=myindex&sourceType=testSource&source=test").to("mock:submitresult");
+
+                from("direct:tcp").to("splunk://tcp?username=foo&password=bar&tcpReceiverPort=2222&index=myindex&sourceType=testSource&source=test").to("mock:tcpresult");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkComponentConfigurationTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkComponentConfigurationTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkComponentConfigurationTest.java
new file mode 100644
index 0000000..a027455
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkComponentConfigurationTest.java
@@ -0,0 +1,88 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk;
+
+import org.apache.camel.test.junit4.CamelTestSupport;
+import org.junit.Test;
+
+public class SplunkComponentConfigurationTest extends CamelTestSupport {
+
+    @Test
+    public void createProducerEndpointWithMinimalConfiguration() throws Exception {
+        SplunkComponent component = context.getComponent("splunk", SplunkComponent.class);
+
+        SplunkEndpoint endpoint = (SplunkEndpoint) component.createEndpoint("splunk://test?username=test&password=pw");
+        assertEquals("localhost", endpoint.getConfiguration().getHost());
+        assertEquals(8089, endpoint.getConfiguration().getPort());
+        assertEquals("test", endpoint.getConfiguration().getUsername());
+        assertEquals("pw", endpoint.getConfiguration().getPassword());
+        assertEquals("https", endpoint.getConfiguration().getScheme());
+        assertEquals(5000, endpoint.getConfiguration().getConnectionTimeout());
+    }
+
+    @Test
+    public void createProducerEndpointWithMaximalConfiguration() throws Exception {
+        SplunkComponent component = context.getComponent("splunk", SplunkComponent.class);
+
+        SplunkEndpoint endpoint = (SplunkEndpoint) component.createEndpoint("splunk://tcp?username=test&password=pw&host=myhost&port=3333&"
+                + "tcpReceiverPort=4444&index=myindex&sourceType=testSource&" + "source=test&owner=me&app=fantasticapp");
+        assertEquals("myhost", endpoint.getConfiguration().getHost());
+        assertEquals(3333, endpoint.getConfiguration().getPort());
+        assertEquals("test", endpoint.getConfiguration().getUsername());
+        assertEquals("pw", endpoint.getConfiguration().getPassword());
+        assertEquals(4444, endpoint.getConfiguration().getTcpReceiverPort());
+        assertEquals("myindex", endpoint.getConfiguration().getIndex());
+        assertEquals("testSource", endpoint.getConfiguration().getSourceType());
+        assertEquals("test", endpoint.getConfiguration().getSource());
+        assertEquals("me", endpoint.getConfiguration().getOwner());
+        assertEquals("fantasticapp", endpoint.getConfiguration().getApp());
+    }
+
+    @Test
+    public void createConsumerEndpointWithMinimalConfiguration() throws Exception {
+        SplunkComponent component = context.getComponent("splunk", SplunkComponent.class);
+
+        SplunkEndpoint endpoint = (SplunkEndpoint) component.createEndpoint("splunk://realtime?username=test&" + "password=pw&search=Splunk search query goes here");
+        assertEquals("localhost", endpoint.getConfiguration().getHost());
+        assertEquals(8089, endpoint.getConfiguration().getPort());
+        assertEquals("test", endpoint.getConfiguration().getUsername());
+        assertEquals("pw", endpoint.getConfiguration().getPassword());
+        assertEquals("https", endpoint.getConfiguration().getScheme());
+        assertEquals(5000, endpoint.getConfiguration().getConnectionTimeout());
+        assertEquals("Splunk search query goes here", endpoint.getConfiguration().getSearch());
+    }
+
+    @Test
+    public void createConsumerEndpointWithMaximalConfiguration() throws Exception {
+        SplunkComponent component = context.getComponent("splunk", SplunkComponent.class);
+
+        SplunkEndpoint endpoint = (SplunkEndpoint) component.createEndpoint("splunk://normal?username=test&password=pw&host=myhost&port=3333&delay=10s&"
+                + "search=Splunk search query goes here&initEarliestTime=-1d"
+                + "&latestTime=now&fieldList=field1,field2&count=10&" + "owner=me&app=fantasticapp");
+        assertEquals("myhost", endpoint.getConfiguration().getHost());
+        assertEquals(3333, endpoint.getConfiguration().getPort());
+        assertEquals("test", endpoint.getConfiguration().getUsername());
+        assertEquals("pw", endpoint.getConfiguration().getPassword());
+        assertEquals("-1d", endpoint.getConfiguration().getInitEarliestTime());
+        assertEquals("now", endpoint.getConfiguration().getLatestTime());
+        assertEquals("field1,field2", endpoint.getConfiguration().getFieldList());
+        assertEquals(10, endpoint.getConfiguration().getCount());
+        assertEquals("me", endpoint.getConfiguration().getOwner());
+        assertEquals("fantasticapp", endpoint.getConfiguration().getApp());
+    }
+
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkMockTestSupport.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkMockTestSupport.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkMockTestSupport.java
new file mode 100644
index 0000000..d292405
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/SplunkMockTestSupport.java
@@ -0,0 +1,52 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk;
+
+import java.net.Socket;
+
+import com.splunk.Service;
+import org.apache.camel.CamelContext;
+import org.apache.camel.test.junit4.CamelTestSupport;
+import org.mockito.Mock;
+import org.mockito.MockitoAnnotations;
+
+import static org.mockito.Mockito.reset;
+
+public abstract class SplunkMockTestSupport extends CamelTestSupport {
+
+    @Mock
+    Service service;
+
+    @Mock
+    Socket socket;
+
+    @Override
+    protected CamelContext createCamelContext() throws Exception {
+        CamelContext context = super.createCamelContext();
+
+        // set splunk to use mocked connection factory
+        MockitoAnnotations.initMocks(this);
+        reset(service);
+        reset(socket);
+        SplunkComponent splunk = context.getComponent("splunk", SplunkComponent.class);
+        DefaultSplunkConfigurationFactory cf = Helper.mockComponent(service, socket);
+        splunk.setSplunkConfigurationFactory(cf);
+
+        return context;
+    }
+
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/NormalSearchTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/NormalSearchTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/NormalSearchTest.java
new file mode 100644
index 0000000..d7011bd
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/NormalSearchTest.java
@@ -0,0 +1,58 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk.integration;
+
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.junit.Ignore;
+import org.junit.Test;
+
+@Ignore("run manually since it requires a running local splunk server")
+public class NormalSearchTest extends SplunkTest {
+
+    @Test
+    public void testSearch() throws Exception {
+        MockEndpoint searchMock = getMockEndpoint("mock:search-result");
+        searchMock.expectedMessageCount(1);
+        getMockEndpoint("mock:submit-result").expectedMessageCount(1);
+
+        assertMockEndpointsSatisfied(20, TimeUnit.SECONDS);
+        SplunkEvent recieved = searchMock.getReceivedExchanges().get(0).getIn().getBody(SplunkEvent.class);
+        assertNotNull(recieved);
+        Map<String, String> data = recieved.getEventData();
+        assertEquals("value1", data.get("key1"));
+        assertEquals("value2", data.get("key2"));
+        assertEquals("value3", data.get("key3"));
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("direct:submit").to("splunk://submit?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&index=" + INDEX + "&sourceType=testSource&source=test")
+                        .to("mock:submit-result");
+
+                from("splunk://normal?delay=5s&username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&initEarliestTime=-10s&latestTime=now" + "&search=search index="
+                                + INDEX + " sourcetype=testSource").to("mock:search-result");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/RealtimeSearchTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/RealtimeSearchTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/RealtimeSearchTest.java
new file mode 100644
index 0000000..3486714
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/RealtimeSearchTest.java
@@ -0,0 +1,56 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk.integration;
+
+import java.util.Map;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.junit.Ignore;
+import org.junit.Test;
+
+@Ignore("run manually since it requires a running local splunk server")
+public class RealtimeSearchTest extends SplunkTest {
+
+    @Test
+    public void testRealtimeSearch() throws Exception {
+        MockEndpoint searchMock = getMockEndpoint("mock:search-saved");
+        searchMock.expectedMessageCount(1);
+
+        assertMockEndpointsSatisfied();
+        SplunkEvent recieved = searchMock.getReceivedExchanges().get(0).getIn().getBody(SplunkEvent.class);
+        assertNotNull(recieved);
+        Map<String, String> data = recieved.getEventData();
+        assertEquals("value1", data.get("key1"));
+        assertEquals("value2", data.get("key2"));
+        assertEquals("value3", data.get("key3"));
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("direct:submit").to("splunk://submit?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&index=" + INDEX + "&sourceType=testSource&source=test")
+                        .to("mock:submit-result");
+
+                from("splunk://realtime?delay=5s&username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&initEarliestTime=rt-10s&search=search index=" + INDEX
+                                + " sourcetype=testSource").to("mock:search-saved");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SavedSearchTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SavedSearchTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SavedSearchTest.java
new file mode 100644
index 0000000..000de42
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SavedSearchTest.java
@@ -0,0 +1,59 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk.integration;
+
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.junit.Ignore;
+import org.junit.Test;
+
+@Ignore("run manually since it requires a running local splunk server")
+public class SavedSearchTest extends SplunkTest {
+
+    // before run there should be created a saved search 'junit' in splunk
+
+    @Test
+    public void testSavedSearch() throws Exception {
+        MockEndpoint searchMock = getMockEndpoint("mock:search-saved");
+        searchMock.expectedMessageCount(1);
+
+        assertMockEndpointsSatisfied(20, TimeUnit.SECONDS);
+        SplunkEvent recieved = searchMock.getReceivedExchanges().get(0).getIn().getBody(SplunkEvent.class);
+        assertNotNull(recieved);
+        Map<String, String> data = recieved.getEventData();
+        assertEquals("value1", data.get("key1"));
+        assertEquals("value2", data.get("key2"));
+        assertEquals("value3", data.get("key3"));
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("direct:submit").to("splunk://submit?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&index=" + INDEX + "&sourceType=testSource&source=test")
+                        .to("mock:submit-result");
+
+                from("splunk://savedsearch?delay=5s&username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&initEarliestTime=-10s&latestTime=now" + "&savedSearch=junit")
+                        .to("mock:search-saved");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkProducerTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkProducerTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkProducerTest.java
new file mode 100644
index 0000000..a92dac8
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkProducerTest.java
@@ -0,0 +1,82 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk.integration;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.junit.Ignore;
+import org.junit.Test;
+
+@Ignore("run manually since it requires a running local splunk server")
+public class SplunkProducerTest extends SplunkTest {
+
+    // Splunk tcp reciever port configured in Splunk
+    private static final String TCP_RECIEVER_PORT = "9997";
+
+    @Test
+    public void testStreamWriter() throws Exception {
+        MockEndpoint mock = getMockEndpoint("mock:stream-result");
+        mock.expectedMinimumMessageCount(1);
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key11", "value1");
+        splunkEvent.addPair("key22", "value2");
+        splunkEvent.addPair("key33", "value3");
+        template.sendBody("direct:stream", splunkEvent);
+        assertMockEndpointsSatisfied();
+    }
+
+    @Test
+    public void testSubmitWriter() throws Exception {
+        MockEndpoint mock = getMockEndpoint("mock:submitresult");
+        mock.expectedMinimumMessageCount(1);
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key1", "value1");
+        splunkEvent.addPair("key2", "value2");
+        splunkEvent.addPair("key3", "value1");
+        template.sendBody("direct:submit", splunkEvent);
+        assertMockEndpointsSatisfied();
+    }
+
+    @Test
+    public void testTcpWriter() throws Exception {
+        MockEndpoint mock = getMockEndpoint("mock:tcpresult");
+        mock.expectedMinimumMessageCount(1);
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key1", "value1");
+        splunkEvent.addPair("key2", "value2");
+        splunkEvent.addPair("key3", "value3");
+        template.sendBody("direct:tcp", splunkEvent);
+        assertMockEndpointsSatisfied();
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("direct:stream").to("splunk://stream?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&index=" + INDEX
+                        + "&sourceType=StreamSourceType&source=StreamSource").to("mock:stream-result");
+
+                from("direct:submit").to("splunk://submit?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&index=" + INDEX + "&sourceType=testSource&source=test")
+                        .to("mock:submitresult");
+
+                from("direct:tcp").to("splunk://tcp?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&tcpRecieverPort=" + TCP_RECIEVER_PORT + "&index=" + INDEX
+                        + "&sourceType=testSource&source=test").to("mock:tcpresult");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkTest.java
new file mode 100644
index 0000000..b922ed3
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/SplunkTest.java
@@ -0,0 +1,42 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk.integration;
+
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.apache.camel.test.junit4.CamelTestSupport;
+import org.junit.Before;
+
+public abstract class SplunkTest extends CamelTestSupport {
+    // TEST WILL RUN ON SPLUNK DEFAULT LOCALHOST+PORT
+    // the Splunk username/pw created when Splunk was initialized during your
+    // login.
+
+    protected static final String SPLUNK_USERNAME = "admin";
+    protected static final String SPLUNK_PASSWORD = "preben1212";
+    // should be created in splunk before test run;
+    protected static final String INDEX = "junit";
+
+    @Before
+    public void init() throws Exception {
+        SplunkEvent splunkEvent = new SplunkEvent();
+        splunkEvent.addPair("key1", "value1");
+        splunkEvent.addPair("key2", "value2");
+        splunkEvent.addPair("key3", "value3");
+        template.sendBody("direct:submit", splunkEvent);
+    }
+
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/TestFieldListSearchTest.java
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/TestFieldListSearchTest.java b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/TestFieldListSearchTest.java
new file mode 100644
index 0000000..7b93271
--- /dev/null
+++ b/components/camel-splunk/src/test/java/org/apache/camel/component/splunk/integration/TestFieldListSearchTest.java
@@ -0,0 +1,55 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.splunk.integration;
+
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.component.splunk.event.SplunkEvent;
+import org.junit.Ignore;
+import org.junit.Test;
+
+@Ignore("run manually since it requires a running local splunk server")
+public class TestFieldListSearchTest extends SplunkTest {
+
+    @Test
+    public void testFieldListSearch() throws Exception {
+        MockEndpoint searchMock = getMockEndpoint("mock:search-result2");
+        searchMock.expectedMessageCount(1);
+        getMockEndpoint("mock:submit-result").expectedMessageCount(1);
+        assertMockEndpointsSatisfied(20, TimeUnit.SECONDS);
+        SplunkEvent recieved = searchMock.getReceivedExchanges().get(0).getIn().getBody(SplunkEvent.class);
+        assertNotNull(recieved);
+        Map<String, String> data = recieved.getEventData();
+        assertEquals("value1", data.get("key1"));
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            public void configure() {
+                from("direct:submit").to("splunk://submit?username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&index=" + INDEX + "&sourceType=testSource&source=test")
+                        .to("mock:submit-result");
+
+                from("splunk://normal?delay=5s&username=" + SPLUNK_USERNAME + "&password=" + SPLUNK_PASSWORD + "&initEarliestTime=-10s&latestTime=now" + "&search=search index="
+                        + INDEX + " sourcetype=testSource&fieldList=key1").to("mock:search-result2");
+            }
+        };
+    }
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/resources/log4j.properties
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/resources/log4j.properties b/components/camel-splunk/src/test/resources/log4j.properties
new file mode 100644
index 0000000..c9c6ad5
--- /dev/null
+++ b/components/camel-splunk/src/test/resources/log4j.properties
@@ -0,0 +1,36 @@
+## ---------------------------------------------------------------------------
+## Licensed to the Apache Software Foundation (ASF) under one or more
+## contributor license agreements.  See the NOTICE file distributed with
+## this work for additional information regarding copyright ownership.
+## The ASF licenses this file to You under the Apache License, Version 2.0
+## (the "License"); you may not use this file except in compliance with
+## the License.  You may obtain a copy of the License at
+## 
+## http://www.apache.org/licenses/LICENSE-2.0
+## 
+## Unless required by applicable law or agreed to in writing, software
+## distributed under the License is distributed on an "AS IS" BASIS,
+## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+## See the License for the specific language governing permissions and
+## limitations under the License.
+## ---------------------------------------------------------------------------
+#
+# The logging properties used for testing
+#
+log4j.rootLogger=INFO, file
+
+# uncomment the following line to turn on Camel debugging
+#log4j.logger.org.apache.camel.component.splunk=TRACE
+
+# CONSOLE appender not used by default
+log4j.appender.out=org.apache.log4j.ConsoleAppender
+log4j.appender.out.layout=org.apache.log4j.PatternLayout
+log4j.appender.out.layout.ConversionPattern=[%30.30t] %-30.30c{1} %-5p %m%n
+#log4j.appender.out.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
+
+# File appender
+log4j.appender.file=org.apache.log4j.FileAppender
+log4j.appender.file.layout=org.apache.log4j.PatternLayout
+log4j.appender.file.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
+log4j.appender.file.file=target/camel-splunk-test.log
+log4j.appender.file.append=false

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/camel-splunk/src/test/resources/resultsreader_test_data.json
----------------------------------------------------------------------
diff --git a/components/camel-splunk/src/test/resources/resultsreader_test_data.json b/components/camel-splunk/src/test/resources/resultsreader_test_data.json
new file mode 100644
index 0000000..0717bd4
--- /dev/null
+++ b/components/camel-splunk/src/test/resources/resultsreader_test_data.json
@@ -0,0 +1,40 @@
+{ "init_offset": 0,
+  "messages": [
+    {
+      "text": "base lispy: [ AND index::_internal source::*metrics.log ]",
+      "type": "DEBUG"
+    },
+    {
+      "text": "search context: user=\"admin\", app=\"search\", bs-pathname=\"/Applications/splunk-ace/etc\"",
+      "type": "DEBUG"
+    },
+    {
+      "text": "Your timerange was substituted based on your search string",
+      "type": "INFO"
+    }
+  ],
+  "preview": false,
+  "results": [
+    {
+      "group": "tpool",
+      "host": "splunks-ombra.sv.splunk.com",
+      "name": "indexertpool",
+      "source": "/Applications/splunk-ace/var/log/splunk/metrics.log",
+      "sourcetype": "splunkd"
+    },
+    {
+      "group": "tpool",
+      "host": "splunks-ombra.sv.splunk.com",
+      "name": "bundlereplthreadpool",
+      "source": "/Applications/splunk-ace/var/log/splunk/metrics.log",
+      "sourcetype": "splunkd"
+    },
+    {
+      "group": "tpool",
+      "host": "splunks-ombra.sv.splunk.com",
+      "name": "batchreadertpool",
+      "source": "/Applications/splunk-ace/var/log/splunk/metrics.log",
+      "sourcetype": "splunkd"
+    }
+  ]
+}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/camel/blob/e47197b9/components/pom.xml
----------------------------------------------------------------------
diff --git a/components/pom.xml b/components/pom.xml
index 23dd79e..3ef980b 100644
--- a/components/pom.xml
+++ b/components/pom.xml
@@ -161,6 +161,7 @@
     <module>camel-sjms</module>
     <module>camel-soap</module>
     <module>camel-solr</module>
+    <module>camel-splunk</module>
     <module>camel-spring-batch</module>
     <module>camel-spring-javaconfig</module>
     <module>camel-spring-integration</module>