summaryrefslogtreecommitdiffstats
path: root/branches/sca-java-1.5/samples/holder-ws-service/src
diff options
context:
space:
mode:
authorantelder <antelder@13f79535-47bb-0310-9956-ffa450edef68>2009-04-18 07:36:53 +0000
committerantelder <antelder@13f79535-47bb-0310-9956-ffa450edef68>2009-04-18 07:36:53 +0000
commit6c7ad7c110656f47273dc23228b41e46023492f3 (patch)
tree348f4838b71e73278bd01153e93db88e22e9c189 /branches/sca-java-1.5/samples/holder-ws-service/src
parent5395b820e60118c68eab9c442af3c53e0e2d7f50 (diff)
Create 1.5 branch
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@766260 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'branches/sca-java-1.5/samples/holder-ws-service/src')
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ObjectFactory.java56
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Order.java129
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService.java37
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderServiceImpl.java65
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService_Service.java66
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrder.java64
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrderResponse.java64
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Status.java57
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/package-info.java2
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/META-INF/sca-deployables/orderws.composite33
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/wsdl/orderservice.wsdl71
-rw-r--r--branches/sca-java-1.5/samples/holder-ws-service/src/test/java/org/example/orderservice/OrderServiceTestCase.java104
12 files changed, 748 insertions, 0 deletions
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ObjectFactory.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ObjectFactory.java
new file mode 100644
index 0000000000..e472b2bada
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ObjectFactory.java
@@ -0,0 +1,56 @@
+
+package org.example.orderservice;
+
+import javax.xml.bind.annotation.XmlRegistry;
+
+
+/**
+ * This object contains factory methods for each
+ * Java content interface and Java element interface
+ * generated in the org.example.orderservice package.
+ * <p>An ObjectFactory allows you to programatically
+ * construct new instances of the Java representation
+ * for XML content. The Java representation of XML
+ * content can consist of schema derived interfaces
+ * and classes representing the binding of schema
+ * type definitions, element declarations and model
+ * groups. Factory methods for each of these are
+ * provided in this class.
+ *
+ */
+@XmlRegistry
+public class ObjectFactory {
+
+
+ /**
+ * Create a new ObjectFactory that can be used to create new instances of schema derived classes for package: org.example.orderservice
+ *
+ */
+ public ObjectFactory() {
+ }
+
+ /**
+ * Create an instance of {@link ReviewOrderResponse }
+ *
+ */
+ public ReviewOrderResponse createReviewOrderResponse() {
+ return new ReviewOrderResponse();
+ }
+
+ /**
+ * Create an instance of {@link Order }
+ *
+ */
+ public Order createOrder() {
+ return new Order();
+ }
+
+ /**
+ * Create an instance of {@link ReviewOrder }
+ *
+ */
+ public ReviewOrder createReviewOrder() {
+ return new ReviewOrder();
+ }
+
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Order.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Order.java
new file mode 100644
index 0000000000..7508887a7d
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Order.java
@@ -0,0 +1,129 @@
+
+package org.example.orderservice;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlType;
+
+
+/**
+ * <p>Java class for order complex type.
+ *
+ * <p>The following schema fragment specifies the expected content contained within this class.
+ *
+ * <pre>
+ * &lt;complexType name="order">
+ * &lt;complexContent>
+ * &lt;restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
+ * &lt;sequence>
+ * &lt;element name="customerId" type="{http://www.w3.org/2001/XMLSchema}string" minOccurs="0"/>
+ * &lt;element name="status" type="{http://www.example.org/OrderService/}status" minOccurs="0"/>
+ * &lt;element name="total" type="{http://www.w3.org/2001/XMLSchema}double"/>
+ * &lt;element name="orderId" type="{http://www.w3.org/2001/XMLSchema}int"/>
+ * &lt;/sequence>
+ * &lt;/restriction>
+ * &lt;/complexContent>
+ * &lt;/complexType>
+ * </pre>
+ *
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "order", propOrder = {
+ "customerId",
+ "status",
+ "total",
+ "orderId"
+})
+public class Order {
+
+ protected String customerId;
+ protected Status status;
+ protected double total;
+ protected int orderId;
+
+ /**
+ * Gets the value of the customerId property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getCustomerId() {
+ return customerId;
+ }
+
+ /**
+ * Sets the value of the customerId property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setCustomerId(String value) {
+ this.customerId = value;
+ }
+
+ /**
+ * Gets the value of the status property.
+ *
+ * @return
+ * possible object is
+ * {@link Status }
+ *
+ */
+ public Status getStatus() {
+ return status;
+ }
+
+ /**
+ * Sets the value of the status property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Status }
+ *
+ */
+ public void setStatus(Status value) {
+ this.status = value;
+ }
+
+ /**
+ * Gets the value of the total property.
+ *
+ */
+ public double getTotal() {
+ return total;
+ }
+
+ /**
+ * Sets the value of the total property.
+ *
+ */
+ public void setTotal(double value) {
+ this.total = value;
+ }
+
+ /**
+ * Gets the value of the orderId property.
+ *
+ */
+ public int getOrderId() {
+ return orderId;
+ }
+
+ /**
+ * Sets the value of the orderId property.
+ *
+ */
+ public void setOrderId(int value) {
+ this.orderId = value;
+ }
+
+ // Added manually from wsimport generated class to improve debugging.
+ public String toString() {
+ return "Order[customerId=" + customerId + ",orderId=" + orderId + ",total=" + total + ",status=" + status.value() + "]";
+ }
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService.java
new file mode 100644
index 0000000000..a11d733cc9
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService.java
@@ -0,0 +1,37 @@
+
+package org.example.orderservice;
+
+import javax.jws.WebMethod;
+import javax.jws.WebParam;
+import javax.jws.WebService;
+import javax.xml.bind.annotation.XmlSeeAlso;
+import javax.xml.ws.Holder;
+import javax.xml.ws.RequestWrapper;
+import javax.xml.ws.ResponseWrapper;
+
+
+/**
+ * This class was generated by the JAX-WS RI.
+ * JAX-WS RI 2.1.1 in JDK 6
+ * Generated source version: 2.1
+ *
+ */
+@WebService(name = "OrderService", targetNamespace = "http://www.example.org/OrderService/")
+@XmlSeeAlso({
+ ObjectFactory.class
+})
+public interface OrderService {
+
+
+ /**
+ *
+ * @param myData
+ */
+ @WebMethod(action = "http://www.example.org/OrderService/reviewOrder")
+ @RequestWrapper(localName = "reviewOrder", targetNamespace = "http://www.example.org/OrderService/", className = "org.example.orderservice.ReviewOrder")
+ @ResponseWrapper(localName = "reviewOrderResponse", targetNamespace = "http://www.example.org/OrderService/", className = "org.example.orderservice.ReviewOrderResponse")
+ public void reviewOrder(
+ @WebParam(name = "myData", targetNamespace = "", mode = WebParam.Mode.INOUT)
+ Holder<Order> myData);
+
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderServiceImpl.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderServiceImpl.java
new file mode 100644
index 0000000000..e4ae074437
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderServiceImpl.java
@@ -0,0 +1,65 @@
+/*
+ * 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.example.orderservice;
+
+// import org.osoa.sca.annotations.Service;
+import java.util.Random;
+
+import javax.jws.WebMethod;
+import javax.jws.WebParam;
+import javax.xml.ws.Holder;
+import javax.xml.ws.RequestWrapper;
+import javax.xml.ws.ResponseWrapper;
+
+/**
+ * This class implements the OrderService service.
+ */
+// @Service(OrderService.class)
+public class OrderServiceImpl implements OrderService {
+
+ /** This dummy implementation approves or rejects orders:
+ * < 100 - always approved.
+ * 100-1100 - randomly approved. Probability = (1100 - amount)/10
+ * >1100 - always rejected.
+ */
+ // public Order reviewOrder(Order order) {
+ @WebMethod(action = "http://www.example.org/OrderService/reviewOrder")
+ @RequestWrapper(localName = "reviewOrder", targetNamespace = "http://www.example.org/OrderService/", className = "org.example.orderservice.ReviewOrder")
+ @ResponseWrapper(localName = "reviewOrderResponse", targetNamespace = "http://www.example.org/OrderService/", className = "org.example.orderservice.ReviewOrderResponse")
+ public void reviewOrder(
+ @WebParam(name = "myData", targetNamespace = "", mode = WebParam.Mode.INOUT)
+ Holder<Order> myData) {
+ Order order = myData.value;
+ double total = order.getTotal();
+ if ( total < 100.0 ) {
+ order.setStatus( Status.APPROVED );
+ } else if ( total > 1100.0 ) {
+ order.setStatus( Status.REJECTED );
+ } else {
+ int probability = (int) ((-100.0 + total) / 10.0);
+ Random approver = new Random();
+ if ( approver.nextInt( 100 ) < probability )
+ order.setStatus( Status.APPROVED );
+ else
+ order.setStatus( Status.REJECTED );
+ }
+ System.out.println( ">>> OrderService.reviewOrder return=" + order );
+ // return order;
+ }
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService_Service.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService_Service.java
new file mode 100644
index 0000000000..9c8ff711ea
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/OrderService_Service.java
@@ -0,0 +1,66 @@
+
+package org.example.orderservice;
+
+import java.net.MalformedURLException;
+import java.net.URL;
+import javax.xml.namespace.QName;
+import javax.xml.ws.Service;
+import javax.xml.ws.WebEndpoint;
+import javax.xml.ws.WebServiceClient;
+import javax.xml.ws.WebServiceFeature;
+
+
+/**
+ * This class was generated by the JAX-WS RI.
+ * JAX-WS RI 2.1.1 in JDK 6
+ * Generated source version: 2.1
+ *
+ */
+@WebServiceClient(name = "OrderService", targetNamespace = "http://www.example.org/OrderService/", wsdlLocation = "META-INF/sca-deployables/orderservice.wsdl")
+public class OrderService_Service
+ extends Service
+{
+
+ private final static URL ORDERSERVICE_WSDL_LOCATION;
+
+ static {
+ URL url = null;
+ try {
+ url = new URL("META-INF/sca-deployables/orderservice.wsdl");
+ } catch (MalformedURLException e) {
+ e.printStackTrace();
+ }
+ ORDERSERVICE_WSDL_LOCATION = url;
+ }
+
+ public OrderService_Service(URL wsdlLocation, QName serviceName) {
+ super(wsdlLocation, serviceName);
+ }
+
+ public OrderService_Service() {
+ super(ORDERSERVICE_WSDL_LOCATION, new QName("http://www.example.org/OrderService/", "OrderService"));
+ }
+
+ /**
+ *
+ * @return
+ * returns OrderService
+ */
+ @WebEndpoint(name = "OrderServiceSOAP")
+ public OrderService getOrderServiceSOAP() {
+ return (OrderService)super.getPort(new QName("http://www.example.org/OrderService/", "OrderServiceSOAP"), OrderService.class);
+ }
+
+ /**
+ *
+ * @param features
+ * A list of {@link javax.xml.ws.WebServiceFeature} to configure on the proxy. Supported features not in the <code>features</code> parameter will have their default values.
+ * @return
+ * returns OrderService
+ */
+ @WebEndpoint(name = "OrderServiceSOAP")
+ public OrderService getOrderServiceSOAP(WebServiceFeature... features) {
+ return (OrderService)super.getPort(new QName("http://www.example.org/OrderService/", "OrderServiceSOAP"), OrderService.class, features);
+ }
+
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrder.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrder.java
new file mode 100644
index 0000000000..9e7192a0d0
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrder.java
@@ -0,0 +1,64 @@
+
+package org.example.orderservice;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+
+
+/**
+ * <p>Java class for anonymous complex type.
+ *
+ * <p>The following schema fragment specifies the expected content contained within this class.
+ *
+ * <pre>
+ * &lt;complexType>
+ * &lt;complexContent>
+ * &lt;restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
+ * &lt;sequence>
+ * &lt;element name="myData" type="{http://www.example.org/OrderService/}order"/>
+ * &lt;/sequence>
+ * &lt;/restriction>
+ * &lt;/complexContent>
+ * &lt;/complexType>
+ * </pre>
+ *
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "myData"
+})
+@XmlRootElement(name = "reviewOrder")
+public class ReviewOrder {
+
+ @XmlElement(required = true)
+ protected Order myData;
+
+ /**
+ * Gets the value of the myData property.
+ *
+ * @return
+ * possible object is
+ * {@link Order }
+ *
+ */
+ public Order getMyData() {
+ return myData;
+ }
+
+ /**
+ * Sets the value of the myData property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Order }
+ *
+ */
+ public void setMyData(Order value) {
+ this.myData = value;
+ }
+
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrderResponse.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrderResponse.java
new file mode 100644
index 0000000000..90dbc3f25e
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/ReviewOrderResponse.java
@@ -0,0 +1,64 @@
+
+package org.example.orderservice;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+
+
+/**
+ * <p>Java class for anonymous complex type.
+ *
+ * <p>The following schema fragment specifies the expected content contained within this class.
+ *
+ * <pre>
+ * &lt;complexType>
+ * &lt;complexContent>
+ * &lt;restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
+ * &lt;sequence>
+ * &lt;element name="myData" type="{http://www.example.org/OrderService/}order"/>
+ * &lt;/sequence>
+ * &lt;/restriction>
+ * &lt;/complexContent>
+ * &lt;/complexType>
+ * </pre>
+ *
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "myData"
+})
+@XmlRootElement(name = "reviewOrderResponse")
+public class ReviewOrderResponse {
+
+ @XmlElement(required = true)
+ protected Order myData;
+
+ /**
+ * Gets the value of the myData property.
+ *
+ * @return
+ * possible object is
+ * {@link Order }
+ *
+ */
+ public Order getMyData() {
+ return myData;
+ }
+
+ /**
+ * Sets the value of the myData property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Order }
+ *
+ */
+ public void setMyData(Order value) {
+ this.myData = value;
+ }
+
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Status.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Status.java
new file mode 100644
index 0000000000..73a1b5c45e
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/Status.java
@@ -0,0 +1,57 @@
+
+package org.example.orderservice;
+
+import javax.xml.bind.annotation.XmlEnum;
+import javax.xml.bind.annotation.XmlEnumValue;
+import javax.xml.bind.annotation.XmlType;
+
+
+/**
+ * <p>Java class for status.
+ *
+ * <p>The following schema fragment specifies the expected content contained within this class.
+ * <p>
+ * <pre>
+ * &lt;simpleType name="status">
+ * &lt;restriction base="{http://www.w3.org/2001/XMLSchema}string">
+ * &lt;enumeration value="Created"/>
+ * &lt;enumeration value="Submitted"/>
+ * &lt;enumeration value="Approved"/>
+ * &lt;enumeration value="Rejected"/>
+ * &lt;/restriction>
+ * &lt;/simpleType>
+ * </pre>
+ *
+ */
+@XmlType(name = "status")
+@XmlEnum
+public enum Status {
+
+ @XmlEnumValue("Created")
+ CREATED("Created"),
+ @XmlEnumValue("Submitted")
+ SUBMITTED("Submitted"),
+ @XmlEnumValue("Approved")
+ APPROVED("Approved"),
+ @XmlEnumValue("Rejected")
+ REJECTED("Rejected");
+ private final String value;
+
+ Status(String v) {
+ value = v;
+ }
+
+ public String value() {
+ return value;
+ }
+
+ public static Status fromValue(String v) {
+ for (Status c: Status.values()) {
+ if (c.value.equals(v)) {
+ return c;
+ }
+ }
+ throw new IllegalArgumentException(v);
+ }
+
+}
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/package-info.java b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/package-info.java
new file mode 100644
index 0000000000..64c056b7fb
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/java/org/example/orderservice/package-info.java
@@ -0,0 +1,2 @@
+@javax.xml.bind.annotation.XmlSchema(namespace = "http://www.example.org/OrderService/")
+package org.example.orderservice;
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/META-INF/sca-deployables/orderws.composite b/branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/META-INF/sca-deployables/orderws.composite
new file mode 100644
index 0000000000..d34891d1af
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/META-INF/sca-deployables/orderws.composite
@@ -0,0 +1,33 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ * 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.
+-->
+<composite xmlns="http://www.osoa.org/xmlns/sca/1.0"
+ targetNamespace="http://orderservice"
+ xmlns:hw="http://orderservice"
+ name="orderws">
+
+ <component name="OrderServiceComponent">
+ <implementation.java class="org.example.orderservice.OrderServiceImpl" />
+ <service name="OrderService">
+ <interface.wsdl interface="http://www.example.org/OrderService/#wsdl.interface(OrderService)" />
+ <binding.ws uri="http://localhost:8085/OrderService"/>
+ </service>
+ </component>
+
+</composite>
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/wsdl/orderservice.wsdl b/branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/wsdl/orderservice.wsdl
new file mode 100644
index 0000000000..fd8ef74403
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/main/resources/wsdl/orderservice.wsdl
@@ -0,0 +1,71 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tns="http://www.example.org/OrderService/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" name="OrderService" targetNamespace="http://www.example.org/OrderService/">
+ <wsdl:types>
+ <xsd:schema targetNamespace="http://www.example.org/OrderService/">
+ <xsd:complexType name="order">
+ <xsd:sequence>
+ <xsd:element name="customerId" type="xsd:string" minOccurs="0" />
+ <xsd:element name="status" type="tns:status" minOccurs="0" />
+ <xsd:element name="total" type="xsd:double" />
+ <xsd:element name="orderId" type="xsd:int" />
+ </xsd:sequence>
+ </xsd:complexType>
+
+ <xsd:simpleType name="status">
+ <xsd:restriction base="xsd:string">
+ <xsd:enumeration value="Created" />
+ <xsd:enumeration value="Submitted" />
+ <xsd:enumeration value="Approved" />
+ <xsd:enumeration value="Rejected" />
+ </xsd:restriction>
+ </xsd:simpleType>
+
+ <xsd:element name="reviewOrder">
+ <xsd:complexType>
+ <xsd:sequence>
+ <xsd:element name="myData" type="tns:order"
+ minOccurs="1" maxOccurs="1" />
+ </xsd:sequence>
+ </xsd:complexType>
+ </xsd:element>
+ <xsd:element name="reviewOrderResponse">
+ <xsd:complexType>
+ <xsd:sequence>
+ <xsd:element name="myData" type="tns:order"
+ minOccurs="1" maxOccurs="1" />
+ </xsd:sequence>
+ </xsd:complexType>
+ </xsd:element>
+
+ </xsd:schema>
+ </wsdl:types>
+ <wsdl:message name="reviewOrderRequest">
+ <wsdl:part element="tns:reviewOrder" name="myParameters"/>
+ </wsdl:message>
+ <wsdl:message name="reviewOrderResponse">
+ <wsdl:part element="tns:reviewOrderResponse" name="myResult"/>
+ </wsdl:message>
+ <wsdl:portType name="OrderService">
+ <wsdl:operation name="reviewOrder">
+ <wsdl:input message="tns:reviewOrderRequest"/>
+ <wsdl:output message="tns:reviewOrderResponse"/>
+ </wsdl:operation>
+ </wsdl:portType>
+ <wsdl:binding name="OrderServiceSOAP" type="tns:OrderService">
+ <soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
+ <wsdl:operation name="reviewOrder">
+ <soap:operation soapAction="http://www.example.org/OrderService/reviewOrder"/>
+ <wsdl:input>
+ <soap:body use="literal"/>
+ </wsdl:input>
+ <wsdl:output>
+ <soap:body use="literal"/>
+ </wsdl:output>
+ </wsdl:operation>
+ </wsdl:binding>
+ <wsdl:service name="OrderService">
+ <wsdl:port binding="tns:OrderServiceSOAP" name="OrderServiceSOAP">
+ <soap:address location="http://www.example.org/"/>
+ </wsdl:port>
+ </wsdl:service>
+</wsdl:definitions>
diff --git a/branches/sca-java-1.5/samples/holder-ws-service/src/test/java/org/example/orderservice/OrderServiceTestCase.java b/branches/sca-java-1.5/samples/holder-ws-service/src/test/java/org/example/orderservice/OrderServiceTestCase.java
new file mode 100644
index 0000000000..878e97465e
--- /dev/null
+++ b/branches/sca-java-1.5/samples/holder-ws-service/src/test/java/org/example/orderservice/OrderServiceTestCase.java
@@ -0,0 +1,104 @@
+/*
+ * 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.example.orderservice;
+
+import static junit.framework.Assert.assertNotNull;
+import static junit.framework.Assert.assertTrue;
+import org.junit.After;
+import org.junit.Before;
+import org.junit.Test;
+
+
+import java.io.IOException;
+import javax.xml.ws.Holder;
+import org.apache.tuscany.sca.host.embedded.SCADomain;
+
+/**
+ * Tests that the order server responds.
+ */
+public class OrderServiceTestCase {
+
+ private SCADomain scaDomain;
+
+ @Before
+ public void startServer() throws Exception {
+ scaDomain = SCADomain.newInstance("META-INF/sca-deployables/orderws.composite");
+ }
+
+ @Test
+ public void testOrderReviewApproved() throws IOException {
+ OrderService orderService =
+ scaDomain.getService(OrderService.class, "OrderServiceComponent/OrderService");
+ assertNotNull(orderService);
+
+ Order order = new Order();
+ order.setStatus( Status.CREATED );
+ order.setCustomerId("cust1234");
+ order.setTotal( 50.0 );
+
+ System.out.println( ">>> Order submitted=" + order );
+ Holder<Order> holder = new Holder<Order>( order );
+ orderService.reviewOrder( holder );
+ System.out.println( ">>> Order returned=" + holder.value );
+ assertTrue( holder.value.getStatus() == Status.APPROVED );
+ }
+
+ @Test
+ public void testOrderReviewRejected() throws IOException {
+ OrderService orderService =
+ scaDomain.getService(OrderService.class, "OrderServiceComponent/OrderService");
+ assertNotNull(orderService);
+
+ Order order = new Order();
+ order.setStatus( Status.CREATED );
+ order.setCustomerId("cust2345");
+ order.setTotal( 50000.0 );
+
+ System.out.println( ">>> Order submitted=" + order );
+ Holder<Order> holder = new Holder<Order>( order );
+ orderService.reviewOrder( holder );
+ System.out.println( ">>> Order returned=" + holder.value );
+ assertTrue( holder.value.getStatus() == Status.REJECTED );
+ }
+
+ @Test
+ public void testOrderReviewRandom() throws IOException {
+ OrderService orderService =
+ scaDomain.getService(OrderService.class, "OrderServiceComponent/OrderService");
+ assertNotNull(orderService);
+
+ Order order = new Order();
+ order.setStatus( Status.CREATED );
+ order.setCustomerId("cust3456");
+ order.setTotal( 600.0 );
+
+ System.out.println( ">>> Order submitted=" + order );
+ Holder<Order> holder = new Holder<Order>( order );
+ orderService.reviewOrder( holder );
+ System.out.println( ">>> Order returned=" + holder.value );
+ assertTrue( holder.value.getStatus() != Status.CREATED );
+ }
+
+ @After
+ public void stopServer() throws Exception {
+ if (scaDomain != null)
+ scaDomain.close();
+ }
+
+}