| /* |
| * 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.jclouds; |
| |
| import com.google.common.collect.Lists; |
| import org.apache.camel.builder.RouteBuilder; |
| import org.apache.camel.component.mock.MockEndpoint; |
| import org.apache.camel.test.junit4.CamelTestSupport; |
| import org.jclouds.ContextBuilder; |
| import org.jclouds.blobstore.BlobStore; |
| import org.jclouds.blobstore.BlobStoreContext; |
| import org.jclouds.io.payloads.StringPayload; |
| import org.junit.Test; |
| |
| public class JcloudsMultipleBlobStoreTest extends CamelTestSupport { |
| |
| private static final String TEST_CONTAINER = "testContainer"; |
| private static final String TEST_BLOB1 = "testBlob1"; |
| private static final String TEST_BLOB2 = "testBlob2"; |
| |
| BlobStoreContext blobStoreContext1 = ContextBuilder.newBuilder("transient").name("b1").credentials("identity", "credential").build(BlobStoreContext.class); |
| BlobStore blobStore1 = blobStoreContext1.getBlobStore(); |
| |
| BlobStoreContext blobStoreContext2 = ContextBuilder.newBuilder("transient").name("b2").credentials("identity", "credential").build(BlobStoreContext.class); |
| BlobStore blobStore2 = blobStoreContext2.getBlobStore(); |
| |
| @Test |
| public void testWithMultipleServices() throws InterruptedException { |
| String message1 = "Blob 1"; |
| String message2 = "Blob 2"; |
| |
| MockEndpoint mockEndpoint1 = resolveMandatoryEndpoint("mock:results1", MockEndpoint.class); |
| mockEndpoint1.expectedBodiesReceived(message1); |
| |
| MockEndpoint mockEndpoint2 = resolveMandatoryEndpoint("mock:results2", MockEndpoint.class); |
| mockEndpoint2.expectedBodiesReceived(message2); |
| |
| JcloudsBlobStoreHelper.writeBlob(blobStore1, TEST_CONTAINER, TEST_BLOB1, new StringPayload(message1)); |
| JcloudsBlobStoreHelper.writeBlob(blobStore2, TEST_CONTAINER, TEST_BLOB2, new StringPayload(message2)); |
| |
| mockEndpoint1.assertIsSatisfied(); |
| mockEndpoint2.assertIsSatisfied(); |
| } |
| |
| @Override |
| protected RouteBuilder createRouteBuilder() throws Exception { |
| blobStore1.createContainerInLocation(null, TEST_CONTAINER); |
| blobStore2.createContainerInLocation(null, TEST_CONTAINER); |
| ((JcloudsComponent) context.getComponent("jclouds")).setBlobStores(Lists.newArrayList(blobStore1, blobStore2)); |
| |
| return new RouteBuilder() { |
| public void configure() { |
| from("jclouds:blobstore:b1?container=" + TEST_CONTAINER) |
| .convertBodyTo(String.class) |
| .to("mock:results1"); |
| |
| from("jclouds:blobstore:b2?container=" + TEST_CONTAINER) |
| .convertBodyTo(String.class) |
| .to("mock:results2"); |
| } |
| }; |
| } |
| } |