cxf-commits mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From ff...@apache.org
Subject svn commit: r1050299 - in /cxf/branches/2.3.x-fixes: ./ rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/ rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/ rt/transports/jms/src/main/java/org/apache/cxf/...
Date Fri, 17 Dec 2010 07:50:35 GMT
Author: ffang
Date: Fri Dec 17 07:50:34 2010
New Revision: 1050299

URL: http://svn.apache.org/viewvc?rev=1050299&view=rev
Log:
Merged revisions 1050282-1050284 via svnmerge from 
https://svn.apache.org/repos/asf/cxf/trunk

........
  r1050282 | ffang | 2010-12-17 14:12:21 +0800 (五, 17 12 2010) | 1 line
  
  [CXF-3179]bigger waiting time to avoid test failure with busy machine
........
  r1050284 | ffang | 2010-12-17 14:37:59 +0800 (五, 17 12 2010) | 1 line
  
  [CXF-3174]support gzip encoding compliant with Soap over JMS spec
........

Added:
    cxf/branches/2.3.x-fixes/systests/transports/src/test/java/org/apache/cxf/systest/jms/GzipServer.java
      - copied unchanged from r1050284, cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/GzipServer.java
    cxf/branches/2.3.x-fixes/systests/transports/src/test/java/org/apache/cxf/systest/jms/JMSClientServerGzipTest.java
      - copied unchanged from r1050284, cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/JMSClientServerGzipTest.java
    cxf/branches/2.3.x-fixes/systests/transports/src/test/java/org/apache/cxf/systest/jms/gzipBus.xml
      - copied unchanged from r1050284, cxf/trunk/systests/transports/src/test/java/org/apache/cxf/systest/jms/gzipBus.xml
Modified:
    cxf/branches/2.3.x-fixes/   (props changed)
    cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/JMSFaultFactory.java
    cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSConstants.java
    cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSInInterceptor.java
    cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPFeature.java
    cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPInInterceptor.java
    cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPOutInterceptor.java
    cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMSUtils.java
    cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spec/JMSSpecConstants.java
    cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd
    cxf/branches/2.3.x-fixes/systests/ws-specs/src/test/java/org/apache/cxf/systest/ws/rm/ServerPersistenceTest.java

Propchange: cxf/branches/2.3.x-fixes/
------------------------------------------------------------------------------
Binary property 'svnmerge-integrated' - no diff available.

Modified: cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/JMSFaultFactory.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/JMSFaultFactory.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/JMSFaultFactory.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/JMSFaultFactory.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSConstants.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSConstants.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSConstants.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSConstants.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSInInterceptor.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSInInterceptor.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSInInterceptor.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/bindings/soap/src/main/java/org/apache/cxf/binding/soap/jms/interceptor/SoapJMSInInterceptor.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPFeature.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPFeature.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPFeature.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPFeature.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPInInterceptor.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPInInterceptor.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPInInterceptor.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPInInterceptor.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPOutInterceptor.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPOutInterceptor.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPOutInterceptor.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/transports/common/src/main/java/org/apache/cxf/transport/common/gzip/GZIPOutInterceptor.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMSUtils.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMSUtils.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMSUtils.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/JMSUtils.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spec/JMSSpecConstants.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spec/JMSSpecConstants.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spec/JMSSpecConstants.java
(original)
+++ cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/java/org/apache/cxf/transport/jms/spec/JMSSpecConstants.java
Fri Dec 17 07:50:34 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/branches/2.3.x-fixes/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd (original)
+++ cxf/branches/2.3.x-fixes/rt/transports/jms/src/main/resources/schemas/wsdl/jms.xsd Fri
Dec 17 07:50:34 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"/>

Modified: cxf/branches/2.3.x-fixes/systests/ws-specs/src/test/java/org/apache/cxf/systest/ws/rm/ServerPersistenceTest.java
URL: http://svn.apache.org/viewvc/cxf/branches/2.3.x-fixes/systests/ws-specs/src/test/java/org/apache/cxf/systest/ws/rm/ServerPersistenceTest.java?rev=1050299&r1=1050298&r2=1050299&view=diff
==============================================================================
--- cxf/branches/2.3.x-fixes/systests/ws-specs/src/test/java/org/apache/cxf/systest/ws/rm/ServerPersistenceTest.java
(original)
+++ cxf/branches/2.3.x-fixes/systests/ws-specs/src/test/java/org/apache/cxf/systest/ws/rm/ServerPersistenceTest.java
Fri Dec 17 07:50:34 2010
@@ -156,8 +156,7 @@ public class ServerPersistenceTest exten
         
         out.getOutboundMessages().clear();
         in.getInboundMessages().clear();
-        
-        
+            
         responses[3] = greeter.greetMeAsync("four");
         verifyRetransmissionQueue();
         
@@ -240,7 +239,7 @@ public class ServerPersistenceTest exten
   
     
     void verifyRetransmissionQueue() throws Exception {
-        awaitMessages(3, 5, 40000);
+        awaitMessages(3, 5, 60000);
         
         boolean empty = greeterBus.getExtension(RMManager.class).getRetransmissionQueue().isEmpty();
         assertTrue("Retransmission Queue is not empty", empty);



Mime
View raw message