| /** |
| * 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.aws.ec2; |
| |
| import java.util.ArrayList; |
| import java.util.Collection; |
| |
| import com.amazonaws.services.ec2.model.DescribeInstanceStatusResult; |
| import com.amazonaws.services.ec2.model.DescribeInstancesResult; |
| import com.amazonaws.services.ec2.model.InstanceStateName; |
| import com.amazonaws.services.ec2.model.InstanceType; |
| import com.amazonaws.services.ec2.model.MonitorInstancesResult; |
| import com.amazonaws.services.ec2.model.MonitoringState; |
| import com.amazonaws.services.ec2.model.RunInstancesResult; |
| import com.amazonaws.services.ec2.model.StartInstancesResult; |
| import com.amazonaws.services.ec2.model.StopInstancesResult; |
| import com.amazonaws.services.ec2.model.TerminateInstancesResult; |
| import com.amazonaws.services.ec2.model.UnmonitorInstancesResult; |
| |
| import org.apache.camel.Exchange; |
| import org.apache.camel.Processor; |
| import org.apache.camel.test.spring.CamelSpringTestSupport; |
| import org.junit.Before; |
| import org.junit.Test; |
| import org.springframework.context.support.AbstractApplicationContext; |
| import org.springframework.context.support.ClassPathXmlApplicationContext; |
| |
| public class EC2ComponentSpringTest extends CamelSpringTestSupport { |
| |
| private AmazonEC2ClientMock amazonEc2Client; |
| |
| @Override |
| @Before |
| public void setUp() throws Exception { |
| super.setUp(); |
| |
| amazonEc2Client = context.getRegistry().lookupByNameAndType("amazonEC2Client", AmazonEC2ClientMock.class); |
| } |
| |
| @Test |
| public void createAndRunInstances() { |
| |
| Exchange exchange = template.request("direct:createAndRun", new Processor() { |
| public void process(Exchange exchange) throws Exception { |
| exchange.getIn().setHeader(EC2Constants.OPERATION, EC2Operations.createAndRunInstances); |
| exchange.getIn().setHeader(EC2Constants.IMAGE_ID, "test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCE_TYPE, InstanceType.T2Micro); |
| exchange.getIn().setHeader(EC2Constants.INSTANCE_MIN_COUNT, 1); |
| exchange.getIn().setHeader(EC2Constants.INSTANCE_MAX_COUNT, 1); |
| } |
| }); |
| |
| RunInstancesResult resultGet = (RunInstancesResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getImageId(), "test-1"); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getInstanceType(), InstanceType.T2Micro.toString()); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getInstanceId(), "instance-1"); |
| } |
| |
| @Test |
| public void ec2CreateAndRunTestWithKeyPair() throws Exception { |
| |
| Exchange exchange = template.request("direct:createAndRun", new Processor() { |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| exchange.getIn().setHeader(EC2Constants.OPERATION, EC2Operations.createAndRunInstances); |
| exchange.getIn().setHeader(EC2Constants.IMAGE_ID, "test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCE_TYPE, InstanceType.T2Micro); |
| exchange.getIn().setHeader(EC2Constants.INSTANCE_MIN_COUNT, 1); |
| exchange.getIn().setHeader(EC2Constants.INSTANCE_MAX_COUNT, 1); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_KEY_PAIR, "keypair-1"); |
| } |
| }); |
| |
| RunInstancesResult resultGet = (RunInstancesResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getImageId(), "test-1"); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getInstanceType(), InstanceType.T2Micro.toString()); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getInstanceId(), "instance-1"); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getSecurityGroups().size(), 2); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getSecurityGroups().get(0).getGroupId(), "id-3"); |
| assertEquals(resultGet.getReservation().getInstances().get(0).getSecurityGroups().get(1).getGroupId(), "id-4"); |
| } |
| |
| @Test |
| public void startInstances() { |
| |
| Exchange exchange = template.request("direct:start", new Processor() { |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| StartInstancesResult resultGet = (StartInstancesResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getStartingInstances().get(0).getInstanceId(), "test-1"); |
| assertEquals(resultGet.getStartingInstances().get(0).getPreviousState().getName(), InstanceStateName.Stopped.toString()); |
| assertEquals(resultGet.getStartingInstances().get(0).getCurrentState().getName(), InstanceStateName.Running.toString()); |
| } |
| |
| @Test |
| public void stopInstances() { |
| |
| Exchange exchange = template.request("direct:stop", new Processor() { |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| StopInstancesResult resultGet = (StopInstancesResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getStoppingInstances().get(0).getInstanceId(), "test-1"); |
| assertEquals(resultGet.getStoppingInstances().get(0).getPreviousState().getName(), InstanceStateName.Running.toString()); |
| assertEquals(resultGet.getStoppingInstances().get(0).getCurrentState().getName(), InstanceStateName.Stopped.toString()); |
| } |
| |
| @Test |
| public void terminateInstances() { |
| |
| Exchange exchange = template.request("direct:terminate", new Processor() { |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| TerminateInstancesResult resultGet = (TerminateInstancesResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getTerminatingInstances().get(0).getInstanceId(), "test-1"); |
| assertEquals(resultGet.getTerminatingInstances().get(0).getPreviousState().getName(), InstanceStateName.Running.toString()); |
| assertEquals(resultGet.getTerminatingInstances().get(0).getCurrentState().getName(), InstanceStateName.Terminated.toString()); |
| } |
| |
| @Test |
| public void ec2DescribeSpecificInstancesTest() throws Exception { |
| |
| Exchange exchange = template.request("direct:describe", new Processor() { |
| |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("instance-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| DescribeInstancesResult resultGet = (DescribeInstancesResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getReservations().size(), 1); |
| assertEquals(resultGet.getReservations().get(0).getInstances().size(), 1); |
| } |
| |
| @Test |
| public void ec2DescribeStatusSpecificInstancesTest() throws Exception { |
| |
| Exchange exchange = template.request("direct:describeStatus", new Processor() { |
| |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| assertMockEndpointsSatisfied(); |
| |
| DescribeInstanceStatusResult resultGet = (DescribeInstanceStatusResult) exchange.getOut().getBody(); |
| assertEquals(resultGet.getInstanceStatuses().size(), 1); |
| assertEquals(resultGet.getInstanceStatuses().get(0).getInstanceState().getName(), InstanceStateName.Running.toString()); |
| } |
| |
| @Test |
| public void ec2RebootInstancesTest() throws Exception { |
| |
| Exchange exchange = template.request("direct:reboot", new Processor() { |
| |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| } |
| |
| @Test |
| public void ec2MonitorInstancesTest() throws Exception { |
| |
| Exchange exchange = template.request("direct:monitor", new Processor() { |
| |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| MonitorInstancesResult resultGet = (MonitorInstancesResult) exchange.getOut().getBody(); |
| |
| assertEquals(resultGet.getInstanceMonitorings().size(), 1); |
| assertEquals(resultGet.getInstanceMonitorings().get(0).getInstanceId(), "test-1"); |
| assertEquals(resultGet.getInstanceMonitorings().get(0).getMonitoring().getState(), MonitoringState.Enabled.toString()); |
| } |
| |
| @Test |
| public void ec2UnmonitorInstancesTest() throws Exception { |
| |
| Exchange exchange = template.request("direct:unmonitor", new Processor() { |
| |
| @Override |
| public void process(Exchange exchange) throws Exception { |
| Collection l = new ArrayList(); |
| l.add("test-1"); |
| exchange.getIn().setHeader(EC2Constants.INSTANCES_IDS, l); |
| } |
| }); |
| |
| UnmonitorInstancesResult resultGet = (UnmonitorInstancesResult) exchange.getOut().getBody(); |
| |
| assertEquals(resultGet.getInstanceMonitorings().size(), 1); |
| assertEquals(resultGet.getInstanceMonitorings().get(0).getInstanceId(), "test-1"); |
| assertEquals(resultGet.getInstanceMonitorings().get(0).getMonitoring().getState(), MonitoringState.Disabled.toString()); |
| } |
| |
| @Override |
| protected AbstractApplicationContext createApplicationContext() { |
| return new ClassPathXmlApplicationContext( |
| "org/apache/camel/component/aws/ec2/EC2ComponentSpringTest-context.xml"); |
| } |
| } |