/* * 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.proxyservice.test.secureProxy; import org.apache.axiom.om.OMElement; import org.testng.annotations.AfterClass; import org.testng.annotations.BeforeClass; import org.testng.annotations.Test; import org.wso2.carbon.integration.common.admin.client.SecurityAdminServiceClient; import org.wso2.carbon.security.mgt.stub.config.SecurityAdminServiceSecurityConfigExceptionException; import org.wso2.esb.integration.common.utils.ESBIntegrationTest; import org.wso2.esb.integration.common.utils.clients.SecureServiceClient; import javax.xml.namespace.QName; import java.rmi.RemoteException; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertNotNull; public class SecuredProxySecuredBackEndTestCase extends ESBIntegrationTest { private SecureServiceClient secureAxisServiceClient; @BeforeClass(alwaysRun = true) public void setEnvironment() throws Exception { super.init(); loadESBConfigurationFromClasspath( "/artifacts/ESB/proxyconfig/proxy/secureProxy/secured_proxy_secured_backend.xml"); secureAxisServiceClient = new SecureServiceClient(); } @Test(groups = "wso2.esb", description = "- Secure proxy" + "- Secured service secured proxy" + "- used scenario1-policy(UsernameToken) to secure proxy and scenario3-policy(Integrity) to secure backend") public void testSecuredProxySecuredService() throws Exception { OMElement response; String lastPrice; String symbol; applySecurity(); //only https available response = secureAxisServiceClient.sendSecuredStockQuoteRequest(userInfo, getProxyServiceURLHttps("StockQuoteProxy"), 1, "WSO2"); lastPrice = response.getFirstElement().getFirstChildWithName(new QName("http://services.samples/xsd", "last")) .getText(); assertNotNull(lastPrice, "Fault: response message 'last' price null"); symbol = response.getFirstElement().getFirstChildWithName(new QName("http://services.samples/xsd", "symbol")) .getText(); assertEquals(symbol, "WSO2", "Fault: value 'symbol' mismatched"); disableSecurity(); } @AfterClass(alwaysRun = true) public void destroy() throws Exception { super.cleanup(); } private void applySecurity() throws SecurityAdminServiceSecurityConfigExceptionException, RemoteException, InterruptedException { applySecurity("StockQuoteProxy", 1, getUserRole()); } private void disableSecurity() throws SecurityAdminServiceSecurityConfigExceptionException, RemoteException { SecurityAdminServiceClient securityAdminServiceClient = new SecurityAdminServiceClient(contextUrls.getBackEndUrl(), sessionCookie); securityAdminServiceClient.disableSecurity("StockQuoteProxy"); } }