/* *Copyright (c) 2005-2010, WSO2 Inc. (http://www.wso2.org) All Rights Reserved. * *WSO2 Inc. 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.wso2.carbon.esb.samples.test.endpoint; import org.testng.Assert; import org.testng.annotations.AfterClass; import org.testng.annotations.BeforeClass; import org.testng.annotations.Test; import org.wso2.carbon.automation.engine.annotations.ExecutionEnvironment; import org.wso2.carbon.automation.engine.annotations.SetEnvironment; import org.wso2.esb.integration.common.utils.ESBIntegrationTest; import org.wso2.esb.integration.common.utils.clients.LoadbalanceFailoverClient; import org.wso2.esb.integration.common.utils.servers.axis2.SampleAxis2Server; /** * Sample 52: Using Load Balancing Endpoints to Handle Peak Loads */ public class Sample52TestCase extends ESBIntegrationTest { private SampleAxis2Server axis2Server1; private SampleAxis2Server axis2Server2; private SampleAxis2Server axis2Server3; private LoadbalanceFailoverClient lbClient; @BeforeClass(alwaysRun = true) public void setEnvironment() throws Exception { super.init(); loadSampleESBConfiguration(52); axis2Server1 = new SampleAxis2Server("test_axis2_server_9001.xml"); axis2Server2 = new SampleAxis2Server("test_axis2_server_9002.xml"); axis2Server3 = new SampleAxis2Server("test_axis2_server_9003.xml"); axis2Server1.deployService(SampleAxis2Server.LB_SERVICE_1); axis2Server2.deployService(SampleAxis2Server.LB_SERVICE_2); axis2Server3.deployService(SampleAxis2Server.LB_SERVICE_3); axis2Server1.start(); axis2Server2.start(); axis2Server3.start(); lbClient = new LoadbalanceFailoverClient(); } @SetEnvironment(executionEnvironments = { ExecutionEnvironment.STANDALONE }) @Test(groups = { "wso2.esb" }, description = "Using Load Balancing Endpoints to Handle Peak Loads") public void testLoadBalanceEndpoint() throws Exception { String[] resMessages = { "Response from server: Server_1", "Response from server: Server_2", "Response from server: Server_3", "Response from server: Server_1", "Response from server: Server_2", "Response from server: Server_3", "Response from server: Server_2", "Response from server: Server_3", "Response from server: Server_2", "Response from server: Server_3" }; for (int i = 0; i < 10; i++) { String response = lbClient.sendLoadBalanceRequest(getMainSequenceURL(), null); Assert.assertNotNull(response, "Response is null"); Assert.assertTrue(response.contains(resMessages[i]), "Response message should be : " + resMessages[i]); if (i == 5) { axis2Server1.stop(); } } } @AfterClass(alwaysRun = true) public void close() throws Exception { super.cleanup(); if (axis2Server1.isStarted()) { axis2Server1.stop(); } if (axis2Server2.isStarted()) { axis2Server2.stop(); } if (axis2Server3.isStarted()) { axis2Server3.stop(); } axis2Server1 = null; axis2Server2 = null; axis2Server3 = null; lbClient = null; } }