You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@tuscany.apache.org by an...@apache.org on 2008/08/06 12:10:25 UTC

svn commit: r683209 - in /tuscany/java/sca/itest/jms-selectors: ./ src/ src/main/ src/main/java/ src/main/java/org/ src/main/java/org/apache/ src/main/java/org/apache/tuscany/ src/main/java/org/apache/tuscany/sca/ src/main/java/org/apache/tuscany/sca/b...

Author: antelder
Date: Wed Aug  6 03:10:23 2008
New Revision: 683209

URL: http://svn.apache.org/viewvc?rev=683209&view=rev
Log:
Add itest for jms msg selectors

Added:
    tuscany/java/sca/itest/jms-selectors/   (with props)
    tuscany/java/sca/itest/jms-selectors/pom.xml
    tuscany/java/sca/itest/jms-selectors/src/
    tuscany/java/sca/itest/jms-selectors/src/main/
    tuscany/java/sca/itest/jms-selectors/src/main/java/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/ClientImpl.java
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorService.java
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl1.java
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl2.java
    tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl3.java
    tuscany/java/sca/itest/jms-selectors/src/main/resources/
    tuscany/java/sca/itest/jms-selectors/src/main/resources/jndi.properties
    tuscany/java/sca/itest/jms-selectors/src/main/resources/selectors/
    tuscany/java/sca/itest/jms-selectors/src/main/resources/selectors/selectors.composite
    tuscany/java/sca/itest/jms-selectors/src/test/
    tuscany/java/sca/itest/jms-selectors/src/test/java/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/jms/
    tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/jms/SelectorsTestCase.java

Propchange: tuscany/java/sca/itest/jms-selectors/
------------------------------------------------------------------------------
--- svn:ignore (added)
+++ svn:ignore Wed Aug  6 03:10:23 2008
@@ -0,0 +1,19 @@
+target
+work
+dojo
+*.iws
+*.ipr
+*.iml
+derby.log
+maven.log
+build.xml
+build-dependency.xml
+velocity.log*
+junit*.properties
+surefire*.properties
+.project
+.classpath
+.settings
+.deployables
+.wtpmodules
+.externalToolBuilders

Added: tuscany/java/sca/itest/jms-selectors/pom.xml
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/pom.xml?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/pom.xml (added)
+++ tuscany/java/sca/itest/jms-selectors/pom.xml Wed Aug  6 03:10:23 2008
@@ -0,0 +1,93 @@
+<?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.    
+-->
+<project>
+    <modelVersion>4.0.0</modelVersion>
+    <parent>
+        <groupId>org.apache.tuscany.sca</groupId>
+        <artifactId>tuscany-itest</artifactId>
+        <version>1.4-SNAPSHOT</version>
+        <relativePath>../../pom.xml</relativePath>
+    </parent>
+    <artifactId>itest-jms-selectors</artifactId>
+    <name>Apache Tuscany SCA JMS Tests for selectors</name>
+
+    <repositories>
+       <repository>
+          <id>apache.incubator</id>
+          <url>http://people.apache.org/repo/m2-incubating-repository</url>
+       </repository>
+    </repositories>
+
+    <dependencies>
+        
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-sca-api</artifactId>
+            <version>1.4-SNAPSHOT</version>
+        </dependency>        
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-host-embedded</artifactId>
+            <version>1.4-SNAPSHOT</version>
+            <scope>runtime</scope>
+        </dependency> 
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-implementation-java-runtime</artifactId>
+            <version>1.4-SNAPSHOT</version>
+            <scope>runtime</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-binding-jms-runtime</artifactId>
+            <version>1.4-SNAPSHOT</version>
+        </dependency>
+
+        <dependency>
+            <groupId>junit</groupId>
+            <artifactId>junit</artifactId>
+            <version>4.2</version>
+            <scope>test</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>org.apache.tuscany.sca</groupId>
+            <artifactId>tuscany-node2-impl</artifactId>
+            <version>1.4-SNAPSHOT</version>
+            <scope>test</scope>
+        </dependency>
+
+        <!--  uses ActiveMQ 5.1 as 4.1 Session.createQueue does not work using
+              a temporary queue name -->
+        <dependency>
+            <groupId>org.apache.activemq</groupId>
+            <artifactId>activemq-core</artifactId>
+            <version>5.1.0</version>
+        </dependency>
+                
+    </dependencies>
+
+    <build>
+       <finalName>${artifactId}</finalName>
+    </build>
+</project>

Added: tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/ClientImpl.java
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/ClientImpl.java?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/ClientImpl.java (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/ClientImpl.java Wed Aug  6 03:10:23 2008
@@ -0,0 +1,41 @@
+/*
+ * 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.tuscany.sca.binding.jms;
+
+import org.osoa.sca.annotations.Reference;
+import org.osoa.sca.annotations.Service;
+
+/**
+ * This class implements the OneWay service.
+ */
+@Service(SelectorService.class)
+public class ClientImpl implements SelectorService {
+
+    private SelectorService serviceA;
+
+    @Reference
+    public void setServiceA(SelectorService service) {
+        this.serviceA = service;
+    }
+
+    public void sayHello(String name) {
+        serviceA.sayHello(name);
+    }
+
+}

Added: tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorService.java
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorService.java?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorService.java (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorService.java Wed Aug  6 03:10:23 2008
@@ -0,0 +1,29 @@
+/*
+ * 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.tuscany.sca.binding.jms;
+
+import org.osoa.sca.annotations.OneWay;
+import org.osoa.sca.annotations.Remotable;
+
+@Remotable
+public interface SelectorService {
+    
+    @OneWay
+    void sayHello(String name);
+}

Added: tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl1.java
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl1.java?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl1.java (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl1.java Wed Aug  6 03:10:23 2008
@@ -0,0 +1,40 @@
+/*
+ * 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.tuscany.sca.binding.jms;
+
+import java.util.ArrayList;
+import java.util.List;
+
+public class SelectorServiceImpl1 implements SelectorService {
+
+    public static Object lock = new Object();
+    public static List<String> names = new ArrayList<String>();
+    
+    public void sayHello(String name) {
+        System.out.println("SelectorServiceImpl1 " + name);
+        SelectorServiceImpl1.names.add(name);
+        if (names.size() == 2) {
+            synchronized (SelectorServiceImpl1.lock) {
+                SelectorServiceImpl1.lock.notify();
+            }
+        }
+    }
+
+}

Added: tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl2.java
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl2.java?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl2.java (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl2.java Wed Aug  6 03:10:23 2008
@@ -0,0 +1,38 @@
+/*
+ * 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.tuscany.sca.binding.jms;
+
+public class SelectorServiceImpl2 implements SelectorService {
+
+    public static Object lock = new Object();
+    public static String name;
+    
+    public void sayHello(String name) {
+        if (SelectorServiceImpl2.name != null) {
+            throw new IllegalStateException("name already set");
+        }
+        System.out.println("SelectorServiceImpl2 " + name);
+        SelectorServiceImpl2.name = name;
+        synchronized (SelectorServiceImpl2.lock) {
+            SelectorServiceImpl2.lock.notify();
+        }
+    }
+
+}

Added: tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl3.java
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl3.java?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl3.java (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/java/org/apache/tuscany/sca/binding/jms/SelectorServiceImpl3.java Wed Aug  6 03:10:23 2008
@@ -0,0 +1,38 @@
+/*
+ * 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.tuscany.sca.binding.jms;
+
+public class SelectorServiceImpl3 implements SelectorService {
+
+    public static Object lock = new Object();
+    public static String name;
+    
+    public void sayHello(String name) {
+        if (SelectorServiceImpl3.name != null) {
+            throw new IllegalStateException("name already set");
+        }
+        System.out.println("SelectorServiceImpl3 " + name);
+        SelectorServiceImpl3.name = name;
+        synchronized (SelectorServiceImpl3.lock) {
+            SelectorServiceImpl3.lock.notify();
+        }
+    }
+
+}

Added: tuscany/java/sca/itest/jms-selectors/src/main/resources/jndi.properties
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/resources/jndi.properties?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/resources/jndi.properties (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/resources/jndi.properties Wed Aug  6 03:10:23 2008
@@ -0,0 +1,38 @@
+## ---------------------------------------------------------------------------
+## 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.
+## ---------------------------------------------------------------------------
+
+# START SNIPPET: jndi
+
+java.naming.factory.initial = org.apache.activemq.jndi.ActiveMQInitialContextFactory
+
+# use the following property to configure the default connector
+java.naming.provider.url = vm://localhost?broker.persistent=false&broker.useJmx=false
+
+# use the following property to specify the JNDI name the connection factory
+# should appear as. 
+#connectionFactoryNames = connectionFactory, queueConnectionFactory, topicConnectionFactry
+connectionFactoryNames = ConnectionFactory, ConnectionFactory2
+
+# register some queues in JNDI using the form
+# queue.[jndiName] = [physicalName]
+
+# register some topics in JNDI using the form
+# topic.[jndiName] = [physicalName]
+#topic.MyTopic = example.MyTopic
+topic.ServiceTopic = ServiceTopic
+
+# END SNIPPET: jndi

Added: tuscany/java/sca/itest/jms-selectors/src/main/resources/selectors/selectors.composite
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/main/resources/selectors/selectors.composite?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/main/resources/selectors/selectors.composite (added)
+++ tuscany/java/sca/itest/jms-selectors/src/main/resources/selectors/selectors.composite Wed Aug  6 03:10:23 2008
@@ -0,0 +1,68 @@
+<?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://jms"
+           xmlns:itest="http://jms"
+           name="DefinitionsTests">
+
+    <component name="Client1">
+        <implementation.java class="org.apache.tuscany.sca.binding.jms.ClientImpl"/>
+        <reference name="serviceA">
+           <binding.jms uri="jms:ServiceTopic" >
+              <headers JMSType="type1" />
+           </binding.jms>
+        </reference>
+    </component>
+
+    <component name="Client2">
+        <implementation.java class="org.apache.tuscany.sca.binding.jms.ClientImpl"/>
+        <reference name="serviceA">
+           <binding.jms uri="jms:ServiceTopic" >
+              <headers JMSType="type2" />
+           </binding.jms>
+        </reference>
+    </component>
+
+    <component name="Service1">
+        <implementation.java class="org.apache.tuscany.sca.binding.jms.SelectorServiceImpl1"/>
+        <service name="SelectorService">
+            <binding.jms uri="jms:ServiceTopic" />
+        </service> 
+    </component>       
+
+    <component name="Service2">
+        <implementation.java class="org.apache.tuscany.sca.binding.jms.SelectorServiceImpl2"/>
+        <service name="SelectorService">
+            <binding.jms uri="jms:ServiceTopic" >
+               <subscriptionHeaders JMSSelector="JMSType = 'type1'"/>
+            </binding.jms>
+        </service> 
+    </component>       
+
+    <component name="Service3">
+        <implementation.java class="org.apache.tuscany.sca.binding.jms.SelectorServiceImpl3"/>
+        <service name="SelectorService">
+            <binding.jms uri="jms:ServiceTopic" >
+               <subscriptionHeaders JMSSelector="JMSType = 'type2'"/>
+            </binding.jms>
+        </service> 
+    </component>       
+
+</composite>

Added: tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/jms/SelectorsTestCase.java
URL: http://svn.apache.org/viewvc/tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/jms/SelectorsTestCase.java?rev=683209&view=auto
==============================================================================
--- tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/jms/SelectorsTestCase.java (added)
+++ tuscany/java/sca/itest/jms-selectors/src/test/java/org/apache/tuscany/sca/binding/jms/SelectorsTestCase.java Wed Aug  6 03:10:23 2008
@@ -0,0 +1,75 @@
+/*
+ * 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.tuscany.sca.binding.jms;
+
+import static org.junit.Assert.assertEquals;
+
+import org.apache.tuscany.sca.host.embedded.SCADomain;
+import org.junit.After;
+import org.junit.Before;
+import org.junit.Test;
+
+/**
+ */
+public class SelectorsTestCase {
+
+    private static SCADomain scaDomain;
+
+    @Before
+    public void init() {
+        scaDomain = SCADomain.newInstance("http://localhost", "/", "selectors/selectors.composite");
+    }
+
+    @Test
+    public void testSayHello() throws Exception {
+        SelectorService client1 = scaDomain.getService(SelectorService.class, "Client1");
+        SelectorService client2 = scaDomain.getService(SelectorService.class, "Client2");
+
+        client1.sayHello("petra");
+        client2.sayHello("beate");
+
+        // wait for up to 5 seconds but should wake up as soon as done
+        synchronized(SelectorServiceImpl2.lock) {
+            if (SelectorServiceImpl2.name == null) {
+                SelectorServiceImpl2.lock.wait(5000);
+            }
+        }
+        synchronized(SelectorServiceImpl3.lock) {
+            if (SelectorServiceImpl3.name == null) {
+                SelectorServiceImpl3.lock.wait(5000);
+            }
+        }
+        synchronized(SelectorServiceImpl1.lock) {
+            if (SelectorServiceImpl1.names.size() != 2) {
+                SelectorServiceImpl1.lock.wait(5000);
+            }
+        }
+
+        assertEquals("petra", SelectorServiceImpl2.name);
+        assertEquals("beate", SelectorServiceImpl3.name);
+        assertEquals(2, SelectorServiceImpl1.names.size());
+    }
+
+    @After
+    public void end() {
+        if (scaDomain != null) {
+            scaDomain.close();
+        }
+    }
+}