You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@tuscany.apache.org by jm...@apache.org on 2007/01/02 20:09:25 UTC

svn commit: r491900 - in /incubator/tuscany/java/sca/kernel/spi/src: main/java/org/apache/tuscany/spi/extension/CompositeComponentExtension.java test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java

Author: jmarino
Date: Tue Jan  2 11:09:24 2007
New Revision: 491900

URL: http://svn.apache.org/viewvc?view=rev&rev=491900
Log:
support default service in composite extension point

Added:
    incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java   (with props)
Modified:
    incubator/tuscany/java/sca/kernel/spi/src/main/java/org/apache/tuscany/spi/extension/CompositeComponentExtension.java

Modified: incubator/tuscany/java/sca/kernel/spi/src/main/java/org/apache/tuscany/spi/extension/CompositeComponentExtension.java
URL: http://svn.apache.org/viewvc/incubator/tuscany/java/sca/kernel/spi/src/main/java/org/apache/tuscany/spi/extension/CompositeComponentExtension.java?view=diff&rev=491900&r1=491899&r2=491900
==============================================================================
--- incubator/tuscany/java/sca/kernel/spi/src/main/java/org/apache/tuscany/spi/extension/CompositeComponentExtension.java (original)
+++ incubator/tuscany/java/sca/kernel/spi/src/main/java/org/apache/tuscany/spi/extension/CompositeComponentExtension.java Tue Jan  2 11:09:24 2007
@@ -249,6 +249,12 @@
     }
 
     public Service getService(String name) {
+        if (name == null) {
+            if (services.size() != 1) {
+                return null;
+            }
+            return services.get(0);
+        }
         SCAObject object = children.get(name);
         if (object instanceof Service) {
             return (Service) object;
@@ -257,6 +263,12 @@
     }
 
     public Service getSystemService(String name) {
+        if (name == null) {
+            if (systemServices.size() != 1) {
+                return null;
+            }
+            return systemServices.get(0);
+        }
         SCAObject object = systemChildren.get(name);
         if (object instanceof Service) {
             return (Service) object;

Added: incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java
URL: http://svn.apache.org/viewvc/incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java?view=auto&rev=491900
==============================================================================
--- incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java (added)
+++ incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java Tue Jan  2 11:09:24 2007
@@ -0,0 +1,99 @@
+/*
+ * 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.spi.extension;
+
+import java.util.Collections;
+
+import org.apache.tuscany.spi.component.CompositeComponent;
+import org.apache.tuscany.spi.component.ScopeContainer;
+import org.apache.tuscany.spi.component.Service;
+import org.apache.tuscany.spi.component.TargetInvokerCreationException;
+import org.apache.tuscany.spi.model.Operation;
+import org.apache.tuscany.spi.wire.InboundWire;
+import org.apache.tuscany.spi.wire.TargetInvoker;
+
+import junit.framework.TestCase;
+import org.easymock.EasyMock;
+
+/**
+ * @version $Rev$ $Date$
+ */
+public class CompositeComponentExtensionTestCase extends TestCase {
+    private CompositeComponent composite;
+
+    public void testDefaultService() throws Exception {
+        Service service = EasyMock.createMock(Service.class);
+        EasyMock.expect(service.getName()).andReturn("service").atLeastOnce();
+        EasyMock.expect(service.isSystem()).andReturn(false).atLeastOnce();
+        service.getServiceBindings();
+        EasyMock.expectLastCall().andReturn(Collections.emptyList()).atLeastOnce();
+        EasyMock.replay(service);
+        composite.register(service);
+        assertEquals(service, composite.getService(null));
+        assertNull(composite.getSystemService(null));
+    }
+
+    public void testSystemService() throws Exception {
+        Service service = EasyMock.createMock(Service.class);
+        EasyMock.expect(service.getName()).andReturn("service").atLeastOnce();
+        EasyMock.expect(service.isSystem()).andReturn(true).atLeastOnce();
+        service.getServiceBindings();
+        EasyMock.expectLastCall().andReturn(Collections.emptyList()).atLeastOnce();
+        EasyMock.replay(service);
+        composite.register(service);
+        assertNull(composite.getService(null));
+        assertEquals(service, composite.getSystemService(null));
+    }
+
+    public void testMoreThanOneServiceGetDefault() throws Exception {
+        Service service1 = EasyMock.createMock(Service.class);
+        EasyMock.expect(service1.getName()).andReturn("service1").atLeastOnce();
+        EasyMock.expect(service1.isSystem()).andReturn(false).atLeastOnce();
+        service1.getServiceBindings();
+        EasyMock.expectLastCall().andReturn(Collections.emptyList()).atLeastOnce();
+        EasyMock.replay(service1);
+
+        Service service2 = EasyMock.createMock(Service.class);
+        EasyMock.expect(service2.getName()).andReturn("service2").atLeastOnce();
+        EasyMock.expect(service2.isSystem()).andReturn(false).atLeastOnce();
+        service2.getServiceBindings();
+        EasyMock.expectLastCall().andReturn(Collections.emptyList()).atLeastOnce();
+        EasyMock.replay(service2);
+
+        composite.register(service1);
+        composite.register(service2);
+        assertNull(composite.getService(null));
+        assertNull(composite.getSystemService(null));
+    }
+
+    protected void setUp() throws Exception {
+        super.setUp();
+        composite = new CompositeComponentExtension("foo", null, null, null) {
+
+            public TargetInvoker createTargetInvoker(String targetName, Operation operation, InboundWire callbackWire)
+                throws TargetInvokerCreationException {
+                throw new UnsupportedOperationException();
+            }
+
+            public void setScopeContainer(ScopeContainer scopeContainer) {
+                throw new UnsupportedOperationException();
+            }
+        };
+    }
+}

Propchange: incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: incubator/tuscany/java/sca/kernel/spi/src/test/java/org/apache/tuscany/spi/extension/CompositeComponentExtensionTestCase.java
------------------------------------------------------------------------------
    svn:keywords = Rev Date



---------------------------------------------------------------------
To unsubscribe, e-mail: tuscany-commits-unsubscribe@ws.apache.org
For additional commands, e-mail: tuscany-commits-help@ws.apache.org