stringdispatch.java
来自「开源的axis2框架的源码。用于开发WEBSERVER」· Java 代码 · 共 385 行 · 第 1/2 页
JAVA
385 行
/*
* 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.axis2.jaxws.dispatch;
import java.net.UnknownHostException;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import javax.xml.ws.Dispatch;
import javax.xml.ws.ProtocolException;
import javax.xml.ws.Response;
import javax.xml.ws.Service;
import javax.xml.ws.WebServiceException;
import junit.framework.TestCase;
import org.apache.axis2.jaxws.TestLogger;
public class StringDispatch extends TestCase {
/**
* Invoke a sync Dispatch<String> in PAYLOAD mode
*/
public void testSyncPayloadMode() throws Exception {
TestLogger.logger.debug("---------------------------------------");
TestLogger.logger.debug("test: " + getName());
// Initialize the JAX-WS client artifacts
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE);
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL);
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
String.class, Service.Mode.PAYLOAD);
// Invoke the Dispatch
TestLogger.logger.debug(">> Invoking sync Dispatch");
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent);
assertNotNull("dispatch invoke returned null", response);
TestLogger.logger.debug(response);
// Check to make sure the content is correct
assertTrue(!response.contains("soap"));
assertTrue(!response.contains("Envelope"));
assertTrue(!response.contains("Body"));
assertTrue(response.contains("echoStringResponse"));
}
/**
* Invoke a sync Dispatch<String> in PAYLOAD mode
* Server response with exception. Section 4.3.2
* says we should get a ProtocolException, not a
* WebServiceException.
*/
public void testSyncPayloadMode_exception() throws Exception {
TestLogger.logger.debug("---------------------------------------");
TestLogger.logger.debug("test: " + getName());
// Initialize the JAX-WS client artifacts
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE);
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL);
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
String.class, Service.Mode.PAYLOAD);
// Invoke the Dispatch
TestLogger.logger.debug(">> Invoking sync Dispatch");
Exception e = null;
try {
// The _bad string passes "THROW EXCEPTION", which causes the echo function on the
// server to throw a RuntimeException. We should get a ProtocolException here on the client
String response = dispatch.invoke(DispatchTestConstants.sampleBodyContent_bad);
} catch (Exception ex) {
e = ex;
}
assertNotNull("No exception received", e);
assertTrue("'e' should be of type ProtocolException", e instanceof ProtocolException);
}
/**
* Invoke a sync Dispatch<String> in MESSAGE mode
*/
public void testSyncWithMessageMode() throws Exception {
TestLogger.logger.debug("---------------------------------------");
TestLogger.logger.debug("test: " + getName());
// Initialize the JAX-WS client artifacts
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE);
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL);
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
String.class, Service.Mode.MESSAGE);
// Invoke the Dispatch
TestLogger.logger.debug(">> Invoking sync Dispatch");
String response = dispatch.invoke(DispatchTestConstants.sampleSoapMessage);
assertNotNull("dispatch invoke returned null", response);
TestLogger.logger.debug(response);
// Check to make sure the content is correct
assertTrue(response.contains("soap"));
assertTrue(response.contains("Envelope"));
assertTrue(response.contains("Body"));
assertTrue(response.contains("echoStringResponse"));
}
/**
* Invoke a Dispatch<String> using the async callback API in PAYLOAD mode
*/
public void testAsyncCallbackPayloadMode() throws Exception {
TestLogger.logger.debug("---------------------------------------");
TestLogger.logger.debug("test: " + getName());
// Initialize the JAX-WS client artifacts
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE);
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL);
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
String.class, Service.Mode.PAYLOAD);
// Create the callback for async responses
AsyncCallback<String> callback = new AsyncCallback<String>();
TestLogger.logger.debug(">> Invoking async (callback) Dispatch");
Future<?> monitor = dispatch.invokeAsync(DispatchTestConstants.sampleBodyContent, callback);
while (!monitor.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
String response = callback.getValue();
assertNotNull("dispatch invoke returned null", response);
TestLogger.logger.debug(response);
// Check to make sure the content is correct
assertTrue(!response.contains("soap"));
assertTrue(!response.contains("Envelope"));
assertTrue(!response.contains("Body"));
assertTrue(response.contains("echoStringResponse"));
}
/**
* Invoke a Dispatch<String> using the async callback API in MESSAGE mode
*/
public void testAsyncCallbackMessageMode() throws Exception {
TestLogger.logger.debug("---------------------------------------");
TestLogger.logger.debug("test: " + getName());
// Initialize the JAX-WS client artifacts
Service svc = Service.create(DispatchTestConstants.QNAME_SERVICE);
svc.addPort(DispatchTestConstants.QNAME_PORT, null, DispatchTestConstants.URL);
Dispatch<String> dispatch = svc.createDispatch(DispatchTestConstants.QNAME_PORT,
String.class, Service.Mode.MESSAGE);
// Create the callback for async responses
AsyncCallback<String> callback = new AsyncCallback<String>();
TestLogger.logger.debug(">> Invoking async (callback) Dispatch with Message Mode");
Future<?> monitor = dispatch.invokeAsync(DispatchTestConstants.sampleSoapMessage, callback);
while (!monitor.isDone()) {
TestLogger.logger.debug(">> Async invocation still not complete");
Thread.sleep(1000);
}
String response = callback.getValue();
assertNotNull("dispatch invoke returned null", response);
TestLogger.logger.debug(response);
// Check to make sure the content is correct
assertTrue(response.contains("soap"));
assertTrue(response.contains("Envelope"));
assertTrue(response.contains("Body"));
assertTrue(response.contains("echoStringResponse"));
}
/**
* Invoke a Dispatch<String> using the async polling API in PAYLOAD mode
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?