Freeman,

> +    public static final String SOAP_JMS_CONTENTENCODING =
> "SOAPJMS_contentEncoding";

I'm a bit concerned about pushing SOAP/JMS things out beyone the SOAP binding.  
  
Is it possible to have the SOAP/JMS interceptors or similar just map this 
directly into the normal CONTENT_ENCODING header the GZIP interceptors already 
use?   I think we already do that for a few headers, right?

Dan



On Friday 17 December 2010 1:37:59 am [email protected] wrote:
> Author: ffang
> Date: Fri Dec 17 06:37:59 2010
> New Revision: 1050284
> 
> URL: http://svn.apache.org/viewvc?rev=1050284&view=rev
> Log:
> [CXF-3174]support gzip encoding compliant with Soap over JMS spec
> 
> Added:
>    
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/Gzi
> pServer.java
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/JMS
> ClientServerGzipTest.java
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/gzi
> pBus.xml Modified:
>    
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/JMSFaultFactory.java
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSConstants.java
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSInInterceptor.java
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPFeature.java
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPInInterceptor.java
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPOutInterceptor.java
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMS
> Utils.java
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spe
> c/JMSSpecConstants.java
> cxf/trunk/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd
> 
> Modified:
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/JMSFaultFactory.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/bindings/soap/src/main/java/org/
> apache/cxf/binding/soap/jms/interceptor/JMSFaultFactory.java?rev=1050284&r1
> =1050283&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/JMSFaultFactory.java (original) +++
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/JMSFaultFactory.java Fri Dec 17 06:37:59 2010 @@ -43,6 +43,14 @@
> public final class JMSFaultFactory {
>          return createFault(SoapJMSConstants.getContentTypeMismatchQName(),
> m); }
> 
> +    public static JMSFault createContentEncodingNotSupported(String
> contentEncoding) { +        String m = new
> org.apache.cxf.common.i18n.Message("CONTENT_ENCODING_NOT_SUPPORTED", LOG,
> +                                                          new Object[] {
> +                                                             
> contentEncoding +                                                         
> }).toString(); +        return
> createFault(SoapJMSConstants.getContentTypeMismatchQName(), m); +    }
> +
>      public static JMSFault createMalformedRequestURIFault(String
> requestURI) { String m = new
> org.apache.cxf.common.i18n.Message("MALFORMED_REQUESTURI", LOG, new
> Object[] {
> 
> Modified:
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSConstants.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/bindings/soap/src/main/java/org/
> apache/cxf/binding/soap/jms/interceptor/SoapJMSConstants.java?rev=1050284&r
> 1=1050283&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSConstants.java (original) +++
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSConstants.java Fri Dec 17 06:37:59 2010 @@ -37,6 +37,7 @@
> public final class SoapJMSConstants {
>      public static final String SOAPACTION_PARAMETER_NAME = "soapAction";
>      public static final String TARGETSERVICE_PARAMETER_NAME =
> "targetService"; public static final String CONTENTTYPE_PARAMETER_NAME =
> "contentType"; +    public static final String
> CONTENTENCODING_PARAMETER_NAME = "contentEncoding"; public static final
> String ISFAULT_PARAMETER_NAME = "isFault";
> 
>      // JMS Field name
> @@ -46,6 +47,7 @@ public final class SoapJMSConstants {
>      public static final String SOAPACTION_FIELD = SOAP_JMS_PREFIX +
> SOAPACTION_PARAMETER_NAME; public static final String TARGETSERVICE_FIELD
> = SOAP_JMS_PREFIX + TARGETSERVICE_PARAMETER_NAME; public static final
> String CONTENTTYPE_FIELD = SOAP_JMS_PREFIX + CONTENTTYPE_PARAMETER_NAME; +
>    public static final String CONTENTENCODING_FIELD = SOAP_JMS_PREFIX +
> CONTENTENCODING_PARAMETER_NAME; public static final String ISFAULT_FIELD =
> SOAP_JMS_PREFIX + ISFAULT_PARAMETER_NAME;
> 
>      public static final String SOAP_JMS_SPECIFICIATION_TRANSPORTID =
> "http://www.w3.org/2010/soapjms/";; @@ -53,6 +55,7 @@ public final class
> SoapJMSConstants {
> 
>      // fault codes
>      private static final String JMS_CONTENTTYPEMISMATCH_FAULT_CODE =
> "contentTypeMismatch"; +    private static final String
> JMS_CONTENTENCODINGNOTSUPPORTED_FAULT_CODE =
> "contentEncodingNotSupported"; private static final String
> JMS_MALFORMEDREQUESTURI_FAULT_CODE = "malformedRequestURI"; private static
> final String JMS_MISMATCHEDSOAPACTION_FAULT_CODE = "mismatchedSoapAction";
> private static final String JMS_MISSINGCONTENTTYPE_FAULT_CODE =
> "missingContentType"; @@ -68,6 +71,10 @@ public final class
> SoapJMSConstants {
>      public static QName getContentTypeMismatchQName() {
>          return new QName(SOAP_JMS_NAMESPACE,
> JMS_CONTENTTYPEMISMATCH_FAULT_CODE); }
> +
> +    public static QName getContentEncodingNotSupportedQName() {
> +        return new QName(SOAP_JMS_NAMESPACE,
> JMS_CONTENTENCODINGNOTSUPPORTED_FAULT_CODE); +    }
> 
>      public static QName getMalformedRequestURIQName() {
>          return new QName(SOAP_JMS_NAMESPACE,
> JMS_MALFORMEDREQUESTURI_FAULT_CODE);
> 
> Modified:
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSInInterceptor.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/bindings/soap/src/main/java/org/
> apache/cxf/binding/soap/jms/interceptor/SoapJMSInInterceptor.java?rev=10502
> 84&r1=1050283&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSInInterceptor.java (original) +++
> cxf/trunk/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/i
> nterceptor/SoapJMSInInterceptor.java Fri Dec 17 06:37:59 2010 @@ -47,6
> +47,7 @@ public class SoapJMSInInterceptor extend
>              .get(Message.PROTOCOL_HEADERS));
>          if (headers != null) {
>              checkContentType(message, headers);
> +            checkContentEncoding(message, headers);
>              checkRequestURI(message, headers);
>              checkSoapAction(message, headers);
>              checkBindingVersion(message, headers);
> @@ -58,6 +59,28 @@ public class SoapJMSInInterceptor extend
>       * @param message
>       * @param headers
>       */
> +    private void checkContentEncoding(SoapMessage message, Map<String,
> List<String>> headers) { +        List<String> contentEncodingList =
> headers.get(SoapJMSConstants.CONTENTENCODING_FIELD); +        JMSFault
> jmsFault = null;
> +        if (contentEncodingList != null && contentEncodingList.size() > 0)
> { +            String contentEncoding = contentEncodingList.get(0);
> +            if (!"gzip".equals(contentEncoding)) {
> +                jmsFault =
> JMSFaultFactory.createContentEncodingNotSupported(contentEncoding); +     
>       }
> +        }
> +        if (jmsFault != null) {
> +            Fault f = createFault(message, jmsFault);
> +            if (f != null) {
> +                throw f;
> +            }
> +        }
> +    }
> +
> +
> +    /**
> +     * @param message
> +     * @param headers
> +     */
>      private void checkJMSMessageFormat(SoapMessage message, Map<String,
> List<String>> headers) { List<String> mt =
> headers.get(SoapJMSConstants.JMS_MESSAGE_TYPE); if (mt != null &&
> mt.size() > 0) {
> 
> Modified:
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPFeature.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/transports/common/src/main/java/
> org/apache/cxf/transport/common/gzip/GZIPFeature.java?rev=1050284&r1=105028
> 3&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPFeature.java (original) +++
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPFeature.java Fri Dec 17 06:37:59 2010 @@ -68,7 +68,6 @@ public
> class GZIPFeature extends Abstrac
>      @Override
>      protected void initializeProvider(InterceptorProvider provider, Bus
> bus) { provider.getInInterceptors().add(IN);
> -        provider.getInFaultInterceptors().add(IN);
>          if (threshold == -1) {
>              provider.getOutInterceptors().add(OUT);
>              provider.getOutFaultInterceptors().add(OUT);
> 
> Modified:
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPInInterceptor.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/transports/common/src/main/java/
> org/apache/cxf/transport/common/gzip/GZIPInInterceptor.java?rev=1050284&r1=
> 1050283&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPInInterceptor.java (original) +++
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPInInterceptor.java Fri Dec 17 06:37:59 2010 @@ -68,6 +68,9 @@
> public class GZIPInInterceptor extends A
>          if (protocolHeaders != null) {
>              List<String> contentEncoding =
> HttpHeaderHelper.getHeader(protocolHeaders,
> HttpHeaderHelper.CONTENT_ENCODING); +            if (contentEncoding ==
> null) {
> +                contentEncoding =
> protocolHeaders.get(GZIPOutInterceptor.SOAP_JMS_CONTENTENCODING); +       
>     }
>              if (contentEncoding != null
>                  && (contentEncoding.contains("gzip") ||
> contentEncoding.contains("x-gzip"))) { try {
> 
> Modified:
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPOutInterceptor.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/transports/common/src/main/java/
> org/apache/cxf/transport/common/gzip/GZIPOutInterceptor.java?rev=1050284&r1
> =1050283&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPOutInterceptor.java (original) +++
> cxf/trunk/rt/transports/common/src/main/java/org/apache/cxf/transport/comm
> on/gzip/GZIPOutInterceptor.java Fri Dec 17 06:37:59 2010 @@ -89,6 +89,8 @@
> public class GZIPOutInterceptor extends
>       * given by the client in Accept-Encoding.
>       */
>      public static final String GZIP_ENCODING_KEY =
> GZIPOutInterceptor.class.getName() + ".gzipEncoding"; +
> +    public static final String SOAP_JMS_CONTENTENCODING =
> "SOAPJMS_contentEncoding";
> 
>      private static final ResourceBundle BUNDLE =
> BundleUtils.getBundle(GZIPOutInterceptor.class); private static final
> Logger LOG = LogUtils.getL7dLogger(GZIPOutInterceptor.class); @@ -165,6
> +167,11 @@ public class GZIPOutInterceptor extends
>              if (requestHeaders != null) {
>                  List<String> acceptEncodingHeader =
> CastUtils.cast(HttpHeaderHelper .getHeader(requestHeaders,
> HttpHeaderHelper.ACCEPT_ENCODING)); +                List<String>
> jmsEncodingHeader =
> CastUtils.cast(requestHeaders.get(SOAP_JMS_CONTENTENCODING)); +           
>     if (jmsEncodingHeader != null && jmsEncodingHeader.contains("gzip")) {
> +                    permitted = UseGzip.YES;
> +                    message.put(GZIP_ENCODING_KEY, "gzip");
> +                }
>                  if (acceptEncodingHeader != null) {
>                      if (LOG.isLoggable(Level.FINE)) {
>                          LOG.fine("Accept-Encoding header: " +
> acceptEncodingHeader);
> 
> Modified:
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMS
> Utils.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/transports/jms/src/main/java/org
> /apache/cxf/transport/jms/JMSUtils.java?rev=1050284&r1=1050283&r2=1050284&v
> iew=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMS
> Utils.java (original) +++
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMS
> Utils.java Fri Dec 17 06:37:59 2010 @@ -48,6 +48,7 @@ import
> org.apache.cxf.common.util.SOAPCo
>  import org.apache.cxf.helpers.CastUtils;
>  import org.apache.cxf.helpers.HttpHeaderHelper;
>  import org.apache.cxf.security.SecurityContext;
> +import org.apache.cxf.transport.common.gzip.GZIPOutInterceptor;
>  import org.apache.cxf.transport.jms.spec.JMSSpecConstants;
>  import org.apache.cxf.transport.jms.uri.JMSEndpoint;
>  import org.apache.cxf.transport.jms.uri.JMSEndpointParser;
> @@ -245,6 +246,10 @@ public final class JMSUtils {
>                  messageProperties.setSOAPJMSContentType(jmsMessage
>                     
> .getStringProperty(JMSSpecConstants.CONTENTTYPE_FIELD)); }
> +            if
> (jmsMessage.propertyExists(JMSSpecConstants.CONTENTENCODING_FIELD)) { +   
>             messageProperties.setSOAPJMSContentEncoding(jmsMessage +      
>              .getStringProperty(JMSSpecConstants.CONTENTENCODING_FIELD));
> +            }
>              if
> (jmsMessage.propertyExists(JMSSpecConstants.SOAPACTION_FIELD)) {
> messageProperties.setSOAPJMSSOAPAction(jmsMessage
> .getStringProperty(JMSSpecConstants.SOAPACTION_FIELD)); @@ -281,6 +286,8
> @@ public final class JMSUtils {
>                  // set the message encoding
>                  inMessage.put(org.apache.cxf.message.Message.ENCODING,
> getEncoding(contentType)); }
> +
> +
>          } catch (JMSException ex) {
>              throw JmsUtils.convertJmsAccessException(ex);
>          }
> @@ -437,6 +444,10 @@ public final class JMSUtils {
>          }
>          return contentType;
>      }
> +
> +    public static String getContentEncoding(org.apache.cxf.message.Message
> message) { +        return
> (String)message.get(GZIPOutInterceptor.GZIP_ENCODING_KEY); +    }
> 
>      public static Message buildJMSMessageFromCXFMessage(JMSConfiguration
> jmsConfig, org.apache.cxf.message.Message outMessage, @@ -510,6 +521,11 @@
> public final class JMSUtils {
>             
> jmsMessage.setStringProperty(JMSSpecConstants.CONTENTTYPE_FIELD,
> messageProperties .getSOAPJMSContentType());
>          }
> +
> +        if (messageProperties.isSetSOAPJMSContentEncoding()) {
> +           
> jmsMessage.setStringProperty(JMSSpecConstants.CONTENTENCODING_FIELD,
> messageProperties +                .getSOAPJMSContentEncoding());
> +        }
> 
>          if (messageProperties.isSetSOAPJMSSOAPAction()) {
>             
> jmsMessage.setStringProperty(JMSSpecConstants.SOAPACTION_FIELD,
> messageProperties @@ -583,6 +599,9 @@ public final class JMSUtils {
>              messageProperties.setSOAPJMSBindingVersion("1.0");
>          }
>         
> messageProperties.setSOAPJMSContentType(getContentType(outMessage)); +    
>    if (getContentEncoding(outMessage) != null) {
> +           
> messageProperties.setSOAPJMSContentEncoding(getContentEncoding(outMessage)
> ); +        }
>          String soapAction = null;
>          // Retrieve or create protocol headers
>          Map<String, List<String>> headers = CastUtils.cast((Map<?,
> ?>)outMessage
> 
> Modified:
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spe
> c/JMSSpecConstants.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/transports/jms/src/main/java/org
> /apache/cxf/transport/jms/spec/JMSSpecConstants.java?rev=1050284&r1=1050283
> &r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spe
> c/JMSSpecConstants.java (original) +++
> cxf/trunk/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spe
> c/JMSSpecConstants.java Fri Dec 17 06:37:59 2010 @@ -55,6 +55,7 @@ public
> final class JMSSpecConstants {
>      public static final String SOAPACTION_PARAMETER_NAME = "soapAction";
>      public static final String TARGETSERVICE_PARAMETER_NAME =
> "targetService"; public static final String CONTENTTYPE_PARAMETER_NAME =
> "contentType"; +    public static final String
> CONTENTENCODING_PARAMETER_NAME = "contentEncoding"; public static final
> String ISFAULT_PARAMETER_NAME = "isFault";
> 
>      // JMS Field name
> @@ -64,6 +65,7 @@ public final class JMSSpecConstants {
>      public static final String SOAPACTION_FIELD = SOAP_JMS_PREFIX +
> SOAPACTION_PARAMETER_NAME; public static final String TARGETSERVICE_FIELD
> = SOAP_JMS_PREFIX + TARGETSERVICE_PARAMETER_NAME; public static final
> String CONTENTTYPE_FIELD = SOAP_JMS_PREFIX + CONTENTTYPE_PARAMETER_NAME; +
>    public static final String CONTENTENCODING_FIELD = SOAP_JMS_PREFIX +
> CONTENTENCODING_PARAMETER_NAME; public static final String ISFAULT_FIELD =
> SOAP_JMS_PREFIX + ISFAULT_PARAMETER_NAME;
> 
>      //
> 
> Modified:
> cxf/trunk/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd URL:
> http://svn.apache.org/viewvc/cxf/trunk/rt/transports/jms/src/main/resource
> s/schemas/wsdl/jms.xsd?rev=1050284&r1=1050283&r2=1050284&view=diff
> ==========================================================================
> ==== ---
> cxf/trunk/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd
> (original) +++
> cxf/trunk/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd Fri
> Dec 17 06:37:59 2010 @@ -104,6 +104,7 @@
>          <xs:attribute name="SOAPJMSTargetService" type="xs:string"/>
>       <xs:attribute name="SOAPJMSBindingVersion" type="xs:string"/>
>       <xs:attribute name="SOAPJMSContentType" type="xs:string"/>
> +        <xs:attribute name="SOAPJMSContentEncoding" type="xs:string"/>
>       <xs:attribute name="SOAPJMSSOAPAction" type="xs:anyURI"/>
>       <xs:attribute name="SOAPJMSIsFault" 
type="pt:ParameterizedBoolean"/>
>       <xs:attribute name="SOAPJMSRequestURI" type="xs:string"/>
> 
> Added:
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/Gzi
> pServer.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/systests/transports/src/test/java/o
> rg/apache/cxf/systest/jms/GzipServer.java?rev=1050284&view=auto
> ==========================================================================
> ==== ---
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/Gzi
> pServer.java (added) +++
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/Gzi
> pServer.java Fri Dec 17 06:37:59 2010 @@ -0,0 +1,54 @@
> +/**
> + * 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.cxf.systest.jms;
> +
> +import javax.xml.ws.Endpoint;
> +
> +import org.apache.cxf.Bus;
> +import org.apache.cxf.BusFactory;
> +import org.apache.cxf.bus.spring.SpringBusFactory;
> +import org.apache.cxf.testutil.common.AbstractBusTestServerBase;
> +import org.apache.cxf.testutil.common.EmbeddedJMSBrokerLauncher;
> +
> +
> +public class GzipServer extends AbstractBusTestServerBase {
> +    public static final String PORT = "9000";
> //allocatePort(GzipServer.class); +
> +    protected void run()  {
> +        Object impleDoc = new GreeterImplDoc();
> +        SpringBusFactory bf = new SpringBusFactory();
> +        Bus bus = bf.createBus("org/apache/cxf/systest/jms/gzipBus.xml");
> +        BusFactory.setDefaultBus(bus);
> +        EmbeddedJMSBrokerLauncher.updateWsdlExtensors(bus,
> "testutils/hello_world_doc_lit.wsdl"); +        Endpoint.publish(null,
> impleDoc);
> +    }
> +
> +
> +    public static void main(String[] args) {
> +        try {
> +            GzipServer s = new GzipServer();
> +            s.start();
> +        } catch (Exception ex) {
> +            ex.printStackTrace();
> +            System.exit(-1);
> +        } finally {
> +            System.out.println("done!");
> +        }
> +    }
> +}
> 
> Added:
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/JMS
> ClientServerGzipTest.java URL:
> http://svn.apache.org/viewvc/cxf/trunk/systests/transports/src/test/java/o
> rg/apache/cxf/systest/jms/JMSClientServerGzipTest.java?rev=1050284&view=aut
> o
> ==========================================================================
> ==== ---
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/JMS
> ClientServerGzipTest.java (added) +++
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/JMS
> ClientServerGzipTest.java Fri Dec 17 06:37:59 2010 @@ -0,0 +1,140 @@
> +/**
> + * 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.cxf.systest.jms;
> +
> +import java.lang.reflect.UndeclaredThrowableException;
> +import java.net.URL;
> +import java.util.HashMap;
> +import java.util.Map;
> +
> +
> +import javax.xml.namespace.QName;
> +
> +import org.apache.cxf.Bus;
> +import org.apache.cxf.BusFactory;
> +import org.apache.cxf.bus.spring.SpringBusFactory;
> +import org.apache.cxf.endpoint.Client;
> +import org.apache.cxf.frontend.ClientProxy;
> +import org.apache.cxf.service.model.EndpointInfo;
> +import org.apache.cxf.testutil.common.AbstractBusClientServerTestBase;
> +import org.apache.cxf.testutil.common.EmbeddedJMSBrokerLauncher;
> +import org.apache.cxf.transport.jms.AddressType;
> +import org.apache.cxf.transport.jms.JMSNamingPropertyType;
> +import org.apache.hello_world_doc_lit.Greeter;
> +import org.apache.hello_world_doc_lit.PingMeFault;
> +import org.apache.hello_world_doc_lit.SOAPService2;
> +
> +import org.junit.BeforeClass;
> +import org.junit.Test;
> +
> +public class JMSClientServerGzipTest extends
> AbstractBusClientServerTestBase { +    static final String JMS_PORT =
> EmbeddedJMSBrokerLauncher.PORT; +    static final String PORT =
> GzipServer.PORT;
> +
> +    private String wsdlString;
> +
> +    @BeforeClass
> +    public static void startServers() throws Exception {
> +        Map<String, String> props = new HashMap<String, String>();
> +        if
> (System.getProperty("org.apache.activemq.default.directory.prefix") !=
> null) { +           
> props.put("org.apache.activemq.default.directory.prefix", +               
>       System.getProperty("org.apache.activemq.default.directory.prefix"));
> +        }
> +        props.put("java.util.logging.config.file",
> +                  System.getProperty("java.util.logging.config.file"));
> +
> +        assertTrue("server did not launch correctly",
> +                   launchServer(EmbeddedJMSBrokerLauncher.class, props,
> null)); +
> +        assertTrue("server did not launch correctly",
> +                   launchServer(GzipServer.class));
> +
> +    }
> +
> +    public URL getWSDLURL(String s) throws Exception {
> +        URL u = getClass().getResource(s);
> +        wsdlString = u.toString().intern();
> +        EmbeddedJMSBrokerLauncher.updateWsdlExtensors(getBus(),
> wsdlString); +        System.gc();
> +        System.gc();
> +        return u;
> +    }
> +    public QName getServiceName(QName q) {
> +        return q;
> +    }
> +    public QName getPortName(QName q) {
> +        return q;
> +    }
> +
> +    @Test
> +    public void testGzipEncodingWithJms() throws Exception {
> +        SpringBusFactory bf = new SpringBusFactory();
> +        Bus bus = bf.createBus("org/apache/cxf/systest/jms/gzipBus.xml");
> +        BusFactory.setDefaultBus(bus);
> +        QName serviceName = getServiceName(new
> QName("http://apache.org/hello_world_doc_lit";, +                          
>       "SOAPService2"));
> +        QName portName = getPortName(new
> QName("http://apache.org/hello_world_doc_lit";, "SoapPort2")); +        URL
> wsdl = getWSDLURL("/wsdl/hello_world_doc_lit.wsdl");
> +        assertNotNull(wsdl);
> +
> +        SOAPService2 service = new SOAPService2(wsdl, serviceName);
> +        assertNotNull(service);
> +
> +        String response1 = new String("Hello Milestone-");
> +        String response2 = new String("Bonjour");
> +        try {
> +            Greeter greeter = service.getPort(portName, Greeter.class);
> +
> +            Client client = ClientProxy.getClient(greeter);
> +            EndpointInfo ei = client.getEndpoint().getEndpointInfo();
> +            AddressType address = ei.getTraversedExtensor(new
> AddressType(), AddressType.class); +            JMSNamingPropertyType name
> = new JMSNamingPropertyType(); +            JMSNamingPropertyType password
> = new JMSNamingPropertyType(); +           
> name.setName("java.naming.security.principal");
> +            name.setValue("ivan");
> +            password.setName("java.naming.security.credentials");
> +            password.setValue("the-terrible");
> +            address.getJMSNamingProperty().add(name);
> +            address.getJMSNamingProperty().add(password);
> +            for (int idx = 0; idx < 5; idx++) {
> +
> +                greeter.greetMeOneWay("test String");
> +
> +                String greeting = greeter.greetMe("Milestone-" + idx);
> +                assertNotNull("no response received from service",
> greeting); +                String exResponse = response1 + idx;
> +                assertEquals(exResponse, greeting);
> +
> +                String reply = greeter.sayHi();
> +                assertNotNull("no response received from service", reply);
> +                assertEquals(response2, reply);
> +
> +                try {
> +                    greeter.pingMe();
> +                    fail("Should have thrown FaultException");
> +                } catch (PingMeFault ex) {
> +                    assertNotNull(ex.getFaultInfo());
> +                }
> +
> +            }
> +        } catch (UndeclaredThrowableException ex) {
> +            throw (Exception)ex.getCause();
> +        }
> +    }
> +}
> 
> Added:
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/gzi
> pBus.xml URL:
> http://svn.apache.org/viewvc/cxf/trunk/systests/transports/src/test/java/o
> rg/apache/cxf/systest/jms/gzipBus.xml?rev=1050284&view=auto
> ==========================================================================
> ==== ---
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/gzi
> pBus.xml (added) +++
> cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/gzi
> pBus.xml Fri Dec 17 06:37:59 2010 @@ -0,0 +1,47 @@
> +<?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.
> +-->
> +
> +<beans xmlns="http://www.springframework.org/schema/beans";
> +      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance";
> +      xmlns:cxf="http://cxf.apache.org/core";
> +      xmlns:jms="http://cxf.apache.org/transports/jms";
> +      xsi:schemaLocation="
> +http://cxf.apache.org/core http://cxf.apache.org/schemas/core.xsd
> +http://cxf.apache.org/transports/jms
> http://cxf.apache.org/schemas/configuration/jms.xsd
> +http://www.springframework.org/schema/beans
> http://www.springframework.org/schema/beans/spring-beans-2.0.xsd";> +
> +
> +    <cxf:bus>
> +        <cxf:features>
> +            <bean class="org.apache.cxf.feature.LoggingFeature"/>
> +            <bean
> class="org.apache.cxf.transport.common.gzip.GZIPFeature"> +               
> <property name="threshold">
> +                    <!-- set threshold as 10 byte to ensure gzip compress
> happen for short test message--> +                    <value>10</value>
> +                </property>
> +            </bean>
> +        </cxf:features>
> +    </cxf:bus>
> +    <jms:conduit
> name="{http://apache.org/hello_world_doc_lit}SoapPort2.jms-conduit";> +    
>    <!--must use binary message format for gzip compress-->
> +        <jms:runtimePolicy messageType="binary"/>
> +    </jms:conduit>
> +</beans>
> +

-- 
Daniel Kulp
[email protected]
http://dankulp.com/blog

Reply via email to