/** * 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.zookeeper; import java.util.List; import org.apache.camel.Exchange; import org.apache.camel.ExchangePattern; import org.apache.camel.Message; import org.apache.camel.builder.RouteBuilder; import org.apache.camel.component.mock.MockEndpoint; import org.apache.camel.component.zookeeper.operations.GetChildrenOperation; import org.apache.zookeeper.CreateMode; import org.apache.zookeeper.data.Stat; import org.junit.Test; import static org.apache.camel.component.zookeeper.ZooKeeperMessage.ZOOKEEPER_CREATE_MODE; import static org.apache.camel.component.zookeeper.ZooKeeperMessage.ZOOKEEPER_NODE; import static org.apache.camel.component.zookeeper.ZooKeeperMessage.ZOOKEEPER_OPERATION; public class ZooKeeperProducerTest extends ZooKeeperTestSupport { private String zookeeperUri; private String testPayload = "TestPayload"; @Override protected RouteBuilder[] createRouteBuilders() throws Exception { return new RouteBuilder[] {new RouteBuilder() { public void configure() throws Exception { zookeeperUri = "zookeeper://localhost:" + getServerPort() + "/node?create=true"; from("direct:roundtrip").to(zookeeperUri).to("mock:producer-out"); from(zookeeperUri).to("mock:consumed-from-node"); } }, new RouteBuilder() { public void configure() throws Exception { from("direct:no-create-fails-set").to("zookeeper://localhost:" + getServerPort() + "/doesnotexist"); } }, new RouteBuilder() { public void configure() throws Exception { from("direct:node-from-header").to("zookeeper://localhost:" + getServerPort() + "/notset?create=true"); from("zookeeper://localhost:" + getServerPort() + "/set?create=true").to("mock:consumed-from-set-node"); } }, new RouteBuilder() { public void configure() throws Exception { from("direct:create-mode").to("zookeeper://localhost:" + getServerPort() + "/persistent?create=true&createMode=PERSISTENT").to("mock:create-mode"); } }, new RouteBuilder() { public void configure() throws Exception { from("direct:delete").to("zookeeper://localhost:39913/to-be-deleted").to("mock:delete"); } }}; } @Test public void testRoundtripOfDataToAndFromZnode() throws Exception { MockEndpoint mock = getMockEndpoint("mock:consumed-from-node"); MockEndpoint pipeline = getMockEndpoint("mock:producer-out"); mock.expectedMessageCount(1); pipeline.expectedMessageCount(1); Exchange e = createExchangeWithBody(testPayload); e.setPattern(ExchangePattern.InOut); template.send("direct:roundtrip", e); assertMockEndpointsSatisfied(); } @Test public void testAsyncRoundtripOfDataToAndFromZnode() throws Exception { MockEndpoint mock = getMockEndpoint("mock:consumed-from-node"); mock.expectedMessageCount(1); Exchange e = createExchangeWithBody(testPayload); template.send("direct:roundtrip", e); assertMockEndpointsSatisfied(); } @Test public void setUsingCreateModeFromHeader() throws Exception { client.createPersistent("/modes-test", "parent for modes"); for (CreateMode mode : CreateMode.values()) { Exchange exchange = createExchangeWithBody(testPayload); exchange.getIn().setHeader(ZOOKEEPER_CREATE_MODE, mode); exchange.getIn().setHeader(ZOOKEEPER_NODE, "/modes-test/" + mode); exchange.setPattern(ExchangePattern.InOut); template.send("direct:node-from-header", exchange); } GetChildrenOperation listing = new GetChildrenOperation(getConnection(), "/modes-test"); assertEquals(CreateMode.values().length, listing.get().getResult().size()); } @Test public void createWithOtherCreateMode() throws Exception { MockEndpoint mock = getMockEndpoint("mock:create-mode"); mock.expectedMessageCount(1); Exchange e = createExchangeWithBody(testPayload); e.setPattern(ExchangePattern.InOut); template.send("direct:create-mode", e); assertMockEndpointsSatisfied(); Stat s = mock.getReceivedExchanges().get(0).getIn().getHeader(ZooKeeperMessage.ZOOKEEPER_STATISTICS, Stat.class); assertEquals(s.getEphemeralOwner(), 0); } @Test public void deleteNode() throws Exception { MockEndpoint mock = getMockEndpoint("mock:delete"); mock.expectedMessageCount(1); client.createPersistent("/to-be-deleted", "to be deleted"); Exchange e = createExchangeWithBody(null); e.setPattern(ExchangePattern.InOut); e.getIn().setHeader(ZOOKEEPER_OPERATION, "DELETE"); template.send("direct:delete", e); assertMockEndpointsSatisfied(); assertNull(client.getConnection().exists("/to-be-deleted", false)); } @Test public void setAndGetListing() throws Exception { client.createPersistent("/set-listing", "parent for set and list test"); Exchange exchange = createExchangeWithBody(testPayload); exchange.getIn().setHeader(ZOOKEEPER_NODE, "/set-listing/firstborn"); exchange.setPattern(ExchangePattern.InOut); template.send("zookeeper://localhost:" + getServerPort() + "/set-listing?create=true&listChildren=true", exchange); List<?> children = exchange.getOut().getMandatoryBody(List.class); assertEquals(1, children.size()); assertEquals("firstborn", children.get(0)); } @Test public void testZookeeperMessage() throws Exception { MockEndpoint mock = getMockEndpoint("mock:consumed-from-node"); mock.expectedMessageCount(1); Exchange exchange = createExchangeWithBody(testPayload); template.send("direct:roundtrip", exchange); assertMockEndpointsSatisfied(); Message received = mock.getReceivedExchanges().get(0).getIn(); assertEquals("/node", ZooKeeperMessage.getPath(received)); assertNotNull(ZooKeeperMessage.getStatistics(received)); } }