Author: gnodet
Date: Tue Sep 5 12:18:08 2006
New Revision: 440447
URL: http://svn.apache.org/viewvc?view=rev&rev=440447
Log:
Fix http provider when using sync transactions
Added:
incubator/servicemix/trunk/servicemix-http/src/test/java/org/apache/servicemix/http/HttpTxTest.java
Modified:
incubator/servicemix/trunk/servicemix-http/src/main/java/org/apache/servicemix/http/processors/ProviderProcessor.java
Modified:
incubator/servicemix/trunk/servicemix-http/src/main/java/org/apache/servicemix/http/processors/ProviderProcessor.java
URL:
http://svn.apache.org/viewvc/incubator/servicemix/trunk/servicemix-http/src/main/java/org/apache/servicemix/http/processors/ProviderProcessor.java?view=diff&rev=440447&r1=440446&r2=440447
==============================================================================
---
incubator/servicemix/trunk/servicemix-http/src/main/java/org/apache/servicemix/http/processors/ProviderProcessor.java
(original)
+++
incubator/servicemix/trunk/servicemix-http/src/main/java/org/apache/servicemix/http/processors/ProviderProcessor.java
Tue Sep 5 12:18:08 2006
@@ -101,6 +101,7 @@
}
return;
}
+ boolean txSync = exchange.isTransacted() &&
Boolean.TRUE.equals(exchange.getProperty(JbiConstants.SEND_SYNC));
NormalizedMessage nm = exchange.getMessage("in");
if (nm == null) {
throw new IllegalStateException("Exchange has no input message");
@@ -162,7 +163,11 @@
fault.setProperty(JbiConstants.PROTOCOL_HEADERS,
getHeaders(method));
soapHelper.getJBIMarshaler().toNMS(fault, soapMessage);
exchange.setFault(fault);
- channel.send(exchange);
+ if (txSync) {
+ channel.sendSync(exchange);
+ } else {
+ channel.send(exchange);
+ }
return;
} else {
throw new Exception("Invalid status response: " +
response);
@@ -179,9 +184,13 @@
msg.setProperty(JbiConstants.PROTOCOL_HEADERS,
getHeaders(method));
soapHelper.getJBIMarshaler().toNMS(msg, soapMessage);
((InOut) exchange).setOutMessage(msg);
- methods.put(exchange.getExchangeId(), method);
- channel.send(exchange);
- close = false;
+ if (txSync) {
+ channel.sendSync(exchange);
+ } else {
+ methods.put(exchange.getExchangeId(), method);
+ channel.send(exchange);
+ close = false;
+ }
} else if (exchange instanceof InOptionalOut) {
if (method.getResponseContentLength() == 0) {
exchange.setStatus(ExchangeStatus.DONE);
@@ -196,9 +205,13 @@
msg.setProperty(JbiConstants.PROTOCOL_HEADERS,
getHeaders(method));
soapHelper.getJBIMarshaler().toNMS(msg, soapMessage);
((InOptionalOut) exchange).setOutMessage(msg);
- methods.put(exchange.getExchangeId(), method);
- channel.send(exchange);
- close = false;
+ if (txSync) {
+ channel.sendSync(exchange);
+ } else {
+ methods.put(exchange.getExchangeId(), method);
+ channel.send(exchange);
+ close = false;
+ }
}
} else {
exchange.setStatus(ExchangeStatus.DONE);
Added:
incubator/servicemix/trunk/servicemix-http/src/test/java/org/apache/servicemix/http/HttpTxTest.java
URL:
http://svn.apache.org/viewvc/incubator/servicemix/trunk/servicemix-http/src/test/java/org/apache/servicemix/http/HttpTxTest.java?view=auto&rev=440447
==============================================================================
---
incubator/servicemix/trunk/servicemix-http/src/test/java/org/apache/servicemix/http/HttpTxTest.java
(added)
+++
incubator/servicemix/trunk/servicemix-http/src/test/java/org/apache/servicemix/http/HttpTxTest.java
Tue Sep 5 12:18:08 2006
@@ -0,0 +1,158 @@
+/*
+ * 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.servicemix.http;
+
+import java.net.URI;
+
+import javax.jbi.messaging.InOut;
+import javax.transaction.TransactionManager;
+import javax.xml.namespace.QName;
+
+import junit.framework.TestCase;
+
+import org.apache.activemq.broker.BrokerService;
+import org.apache.geronimo.transaction.context.GeronimoTransactionManager;
+import org.apache.geronimo.transaction.context.TransactionContextManager;
+import org.apache.geronimo.transaction.manager.TransactionManagerImpl;
+import org.apache.geronimo.transaction.manager.XidFactoryImpl;
+import org.apache.servicemix.client.DefaultServiceMixClient;
+import org.apache.servicemix.client.Destination;
+import org.apache.servicemix.components.util.EchoComponent;
+import org.apache.servicemix.jbi.container.JBIContainer;
+import org.apache.servicemix.jbi.jaxp.StringSource;
+import org.apache.servicemix.jbi.nmr.flow.Flow;
+import org.apache.servicemix.jbi.nmr.flow.jca.JCAFlow;
+import org.apache.servicemix.jbi.nmr.flow.seda.SedaFlow;
+import org.apache.servicemix.tck.ExchangeCompletedListener;
+
+public class HttpTxTest extends TestCase {
+
+ private ExchangeCompletedListener listener;
+ private JBIContainer jbi;
+ private TransactionManager tm;
+ private BrokerService broker;
+
+ protected void setUp() throws Exception {
+ broker = new BrokerService();
+ broker.setUseJmx(false);
+ broker.setPersistent(false);
+ broker.addConnector("tcp://localhost:61616");
+ broker.start();
+
+ TransactionManagerImpl exTransactionManager = new
TransactionManagerImpl(600, new XidFactoryImpl(), null, null);
+ TransactionContextManager transactionContextManager = new
TransactionContextManager(exTransactionManager, exTransactionManager);
+ tm = (TransactionManager) new
GeronimoTransactionManager(transactionContextManager);
+
+ JCAFlow jcaFlow = new JCAFlow();
+ jcaFlow.setTransactionContextManager(transactionContextManager);
+
+ jbi = new JBIContainer();
+ jbi.setFlows(new Flow[] { new SedaFlow(), jcaFlow });
+ jbi.setEmbedded(true);
+ jbi.setUseMBeanServer(false);
+ jbi.setCreateMBeanServer(false);
+ jbi.setTransactionManager(tm);
+ jbi.setAutoEnlistInTransaction(true);
+ listener = new ExchangeCompletedListener();
+ jbi.addListener(listener);
+ jbi.init();
+ jbi.start();
+ }
+
+ protected void tearDown() throws Exception {
+ listener.assertExchangeCompleted();
+ jbi.shutDown();
+ broker.stop();
+ }
+
+ public void testSync() throws Exception {
+ EchoComponent echo = new EchoComponent();
+ echo.setService(new QName("urn:test", "echo"));
+ echo.setEndpoint("echo");
+ jbi.activateComponent(echo, "echo");
+
+ HttpEndpoint ep0 = new HttpEndpoint();
+ ep0.setService(new QName("urn:test", "s0"));
+ ep0.setEndpoint("ep0");
+ ep0.setLocationURI("http://localhost:8192/ep1/");
+ ep0.setRoleAsString("provider");
+ ep0.setSoap(true);
+
+ HttpEndpoint ep1 = new HttpEndpoint();
+ ep1.setService(new QName("urn:test", "s1"));
+ ep1.setEndpoint("ep1");
+ ep1.setTargetService(new QName("urn:test", "echo"));
+ ep1.setLocationURI("http://localhost:8192/ep1/");
+ ep1.setRoleAsString("consumer");
+ ep1.setDefaultMep(URI.create("http://www.w3.org/2004/08/wsdl/in-out"));
+ ep1.setSoap(true);
+
+ HttpSpringComponent http = new HttpSpringComponent();
+ http.setEndpoints(new HttpEndpoint[] { ep0, ep1 });
+ jbi.activateComponent(http, "http");
+
+ DefaultServiceMixClient client = new DefaultServiceMixClient(jbi);
+ Destination d = client.createDestination("service:urn:test:s0");
+ InOut me = d.createInOutExchange();
+ me.getInMessage().setContent(new StringSource("<hello>world</hello>"));
+
+ tm.begin();
+ boolean ok = client.sendSync(me);
+ assertTrue(ok);
+ client.done(me);
+ tm.commit();
+ }
+
+ public void testAsync() throws Exception {
+ EchoComponent echo = new EchoComponent();
+ echo.setService(new QName("urn:test", "echo"));
+ echo.setEndpoint("echo");
+ jbi.activateComponent(echo, "echo");
+
+ HttpEndpoint ep0 = new HttpEndpoint();
+ ep0.setService(new QName("urn:test", "s0"));
+ ep0.setEndpoint("ep0");
+ ep0.setLocationURI("http://localhost:8192/ep1/");
+ ep0.setRoleAsString("provider");
+ ep0.setSoap(true);
+
+ HttpEndpoint ep1 = new HttpEndpoint();
+ ep1.setService(new QName("urn:test", "s1"));
+ ep1.setEndpoint("ep1");
+ ep1.setTargetService(new QName("urn:test", "echo"));
+ ep1.setLocationURI("http://localhost:8192/ep1/");
+ ep1.setRoleAsString("consumer");
+ ep1.setDefaultMep(URI.create("http://www.w3.org/2004/08/wsdl/in-out"));
+ ep1.setSoap(true);
+
+ HttpSpringComponent http = new HttpSpringComponent();
+ http.setEndpoints(new HttpEndpoint[] { ep0, ep1 });
+ jbi.activateComponent(http, "http");
+
+ DefaultServiceMixClient client = new DefaultServiceMixClient(jbi);
+ Destination d = client.createDestination("service:urn:test:s0");
+ InOut me = d.createInOutExchange();
+ me.getInMessage().setContent(new StringSource("<hello>world</hello>"));
+
+ tm.begin();
+ client.send(me);
+ tm.commit();
+ me = (InOut) client.receive();
+ client.done(me);
+ }
+
+}