/*
* Copyright 2004,2005 The Apache Software Foundation.
*
* Licensed 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.axis2.engine;
//todo
import junit.framework.TestCase;
import org.apache.axis2.Constants;
import org.apache.axis2.addressing.AddressingConstants;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.context.MessageContext;
import org.apache.axis2.description.Flow;
import org.apache.axis2.description.FlowImpl;
import org.apache.axis2.description.ServiceDescription;
import org.apache.axis2.handlers.AbstractHandler;
import org.apache.axis2.integration.UtilServer;
import org.apache.axis2.om.OMAbstractFactory;
import org.apache.axis2.om.OMElement;
import org.apache.axis2.om.OMNamespace;
import org.apache.axis2.om.OMOutput;
import org.apache.axis2.phaseresolver.PhaseMetadata;
import org.apache.axis2.soap.SOAPFactory;
import org.apache.axis2.transport.http.SimpleHTTPServer;
import org.apache.axis2.util.Utils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLOutputFactory;
public class HandlerFailureTest extends TestCase {
private Log log = LogFactory.getLog(getClass());
private static final String SERVICE_NAME = "EchoXMLService";
private static final String OPERATION_NAME = "echoOMElement";
private static final String ADDRESS = "http://127.0.0.1:" + (UtilServer.TESTING_PORT) +
"/axis/services/" + SERVICE_NAME + "/" +OPERATION_NAME;
// private static final String ADDRESS = "http://127.0.0.1:8080/axis/services/" + SERVICE_NAME;
private EndpointReference targetEPR = new EndpointReference(AddressingConstants.WSA_TO, ADDRESS);
private QName serviceName = new QName("", SERVICE_NAME);
//private QName serviceName = new QName("", targetEPR.getValue());
private QName operationName = new QName(OPERATION_NAME);
private MessageContext mc;
private Thread thisThread;
private SimpleHTTPServer sas;
public HandlerFailureTest() {
super(HandlerFailureTest.class.getName());
}
public HandlerFailureTest(String testName) {
super(testName);
}
protected void setUp() throws Exception {
}
public void testFailureAtServerRequestFlow() throws Exception {
Flow flow = new FlowImpl();
Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
Utils.addHandler(flow, culprit,PhaseMetadata.PHASE_POLICY_DETERMINATION);
Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
ServiceDescription service = Utils.createSimpleService(serviceName,Echo.class.getName(),operationName);
service.setInFlow(flow);
UtilServer.start();
UtilServer.deployService(service);
try {
callTheService();
} finally {
UtilServer.unDeployService(serviceName);
UtilServer.stop();
}
}
// public void testFailureAtServerResponseFlow() throws Exception {
// ServiceDescription service = Utils.createSimpleService(serviceName,org.apache.axis2.engine.Echo.class.getName(),operationName);
//
//
// Flow flow = new FlowImpl();
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// service.setInFlow(flow);
//
//
// flow = new FlowImpl();
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, culprit,PhaseMetadata.PHASE_POLICY_DETERMINATION);
// Utils.addHandler(flow, new SpeakingHandler(),PhaseMetadata.PHASE_POLICY_DETERMINATION);
// service.setInFlow(flow);
//
// OperationDescription operation = new OperationDescription(operationName);
// service.addOperation(operation);
//
// UtilServer.start();
// UtilServer.deployService(service);
// try {
// callTheService();
// } finally {
// UtilServer.unDeployService(serviceName);
// UtilServer.stop();
// }
// }
protected void tearDown() throws Exception {
}
private void callTheService() throws Exception {
try {
SOAPFactory fac = OMAbstractFactory.getSOAP11Factory();
OMNamespace omNs = fac.createOMNamespace("http://localhost/my", "my");
OMElement method = fac.createOMElement("echoOMElement", omNs);
OMElement value = fac.createOMElement("myValue", omNs);
value.setText("Isaac Assimov, the foundation Sega");
method.addChild(value);
org.apache.axis2.clientapi.Call call = new org.apache.axis2.clientapi.Call();
//EndpointReference targetEPR = new EndpointReference(AddressingConstants.WSA_TO, "http://127.0.0.1:" + Utils.TESTING_PORT + "/axis/services/EchoXMLService");
call.setTransportInfo(Constants.TRANSPORT_HTTP,Constants.TRANSPORT_HTTP,false);
call.setTo(targetEPR);
OMElement result = call.invokeBlocking(operationName.getLocalPart(),method);
OMOutput omOutput = new OMOutput(XMLOutputFactory.newInstance().createXMLStreamWriter(System.out));
result.serialize(omOutput);
omOutput.flush();
fail("the test must fail due to bad service Name");
} catch (AxisFault e) {
e.printStackTrace();
assertTrue((e.getMessage().indexOf(UtilServer.FAILURE_MESSAGE)) > 0);
return;
}
}
private Handler culprit = new AbstractHandler() {
public void invoke(MessageContext msgContext) throws AxisFault {
throw new AxisFault(UtilServer.FAILURE_MESSAGE);
}
};
}