summaryrefslogtreecommitdiffstats
path: root/sandbox/lresende/sca-2.x/itest/performance/src/test
diff options
context:
space:
mode:
Diffstat (limited to 'sandbox/lresende/sca-2.x/itest/performance/src/test')
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogLocalTest.java52
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteJsonRPCTest.java48
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteWsTest.java48
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/LoadTestCase.java129
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-local.composite51
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-jsonrpc.composite55
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-ws.composite55
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/resources/log4j.properties28
-rw-r--r--sandbox/lresende/sca-2.x/itest/performance/src/test/resources/logging.properties37
9 files changed, 503 insertions, 0 deletions
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogLocalTest.java b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogLocalTest.java
new file mode 100644
index 0000000000..9914995e04
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogLocalTest.java
@@ -0,0 +1,52 @@
+/*
+ * 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.performance;
+
+import junit.framework.TestCase;
+
+import org.apache.tuscany.sca.node.Node;
+import org.junit.Assert;
+import org.junit.Test;
+
+import services.Catalog;
+
+/**
+ * @version $Rev$ $Date$
+ */
+public class CatalogLocalTest extends TestCase {
+ public static String COMPOSITE = "catalog-local.composite";
+
+ private Node node;
+
+ public CatalogLocalTest() {
+ super();
+ }
+
+ public CatalogLocalTest(String name, Node node) {
+ super(name);
+ this.node = node;
+ }
+
+ @Test
+ public void testCatalog() throws Exception {
+ Catalog catalogService = node.getService(Catalog.class, "CatalogAggregator");
+ Assert.assertEquals(6, catalogService.get().length);
+ }
+}
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteJsonRPCTest.java b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteJsonRPCTest.java
new file mode 100644
index 0000000000..cfebd1c52b
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteJsonRPCTest.java
@@ -0,0 +1,48 @@
+/*
+ * 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.performance;
+
+import junit.framework.TestCase;
+
+import org.apache.tuscany.sca.node.Node;
+import org.junit.Assert;
+import org.junit.Test;
+
+import services.Catalog;
+
+/**
+ * @version $Rev$ $Date$
+ */
+public class CatalogRemoteJsonRPCTest extends TestCase {
+ public static String COMPOSITE = "catalog-remote-jsonrpc.composite";
+
+ private Node node;
+
+ public CatalogRemoteJsonRPCTest(String name, Node node) {
+ super(name);
+ this.node = node;
+ }
+
+ @Test
+ public void testCatalog() throws Exception {
+ Catalog catalogService = node.getService(Catalog.class, "CatalogAggregator");
+ Assert.assertEquals(6, catalogService.get().length);
+ }
+}
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteWsTest.java b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteWsTest.java
new file mode 100644
index 0000000000..075789a327
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/CatalogRemoteWsTest.java
@@ -0,0 +1,48 @@
+/*
+ * 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.performance;
+
+import junit.framework.TestCase;
+
+import org.apache.tuscany.sca.node.Node;
+import org.junit.Assert;
+import org.junit.Test;
+
+import services.Catalog;
+
+/**
+ * @version $Rev$ $Date$
+ */
+public class CatalogRemoteWsTest extends TestCase {
+ public static String COMPOSITE = "catalog-remote-ws.composite";
+
+ private Node node;
+
+ public CatalogRemoteWsTest(String name, Node node) {
+ super(name);
+ this.node = node;
+ }
+
+ @Test
+ public void testCatalog() throws Exception {
+ Catalog catalogService = node.getService(Catalog.class, "CatalogAggregator");
+ Assert.assertEquals(6, catalogService.get().length);
+ }
+}
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/LoadTestCase.java b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/LoadTestCase.java
new file mode 100644
index 0000000000..57648a7137
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/java/org/apache/tuscany/sca/performance/LoadTestCase.java
@@ -0,0 +1,129 @@
+/*
+ * 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.performance;
+
+import java.text.NumberFormat;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.tuscany.sca.node.Contribution;
+import org.apache.tuscany.sca.node.ContributionLocationHelper;
+import org.apache.tuscany.sca.node.Node;
+import org.apache.tuscany.sca.node.NodeFactory;
+import org.junit.Test;
+
+import com.clarkware.junitperf.ConstantTimer;
+import com.clarkware.junitperf.LoadTest;
+import com.clarkware.junitperf.Timer;
+
+public class LoadTestCase {
+ private static int USERS = 50;
+ private static int ITERATIONS = 10;
+ private static Timer TIMER = new ConstantTimer(10);
+
+ protected static synchronized Node initializeTuscanyRuntime(String composite) {
+ System.out.println(">>> initializing Tuscany Runtime....");
+
+ /*
+ Node node = null;
+
+ NodeFactory factory = NodeFactory.getInstance();
+
+ String location = ContributionLocationHelper.getContributionLocation(LoadTestCase.class);
+
+ ContributionConfiguration contributionConfiguration =
+ factory.createContributionConfiguration()
+ .addDeploymentComposite(composite)
+ .setURI("c")
+ .setLocation(location);
+
+ NodeConfiguration configuration =
+ factory.createNodeConfiguration()
+ //.setDomainURI("tuscany:performance")
+ .addContribution(contributionConfiguration);
+
+ node = factory.createNode(configuration);
+ node.start();
+ */
+
+ /**/
+ long startTime = 0;
+ long endTime = 0;
+ long duration = 0;
+
+ Node node = null;
+
+ startTime = System.nanoTime();
+
+ String location = ContributionLocationHelper.getContributionLocation(LoadTestCase.class);
+ node = NodeFactory.newInstance().createNode(composite, new Contribution("c", location));
+ node.start();
+
+ endTime = System.nanoTime();
+ duration = TimeUnit.MILLISECONDS.convert(endTime - startTime, TimeUnit.NANOSECONDS);
+
+ System.out.println(">>> >>> Runtime initialization: " +
+ NumberFormat.getInstance().format(duration) + " ms");
+
+ /**/
+
+ return node;
+ }
+
+ public static junit.framework.Test localTests() {
+ System.out.println("#### Local Tests");
+ Node node = initializeTuscanyRuntime(CatalogLocalTest.COMPOSITE);
+ junit.framework.Test testCase = new CatalogLocalTest("testCatalog", node);
+ junit.framework.Test loadTest = new LoadTest(testCase, USERS, ITERATIONS, TIMER);
+ //node.stop();
+ return loadTest;
+ }
+
+ public static junit.framework.Test jsonTests() {
+ System.out.println("#### JSON-RPC Remote Tests");
+ Node node = initializeTuscanyRuntime(CatalogRemoteJsonRPCTest.COMPOSITE);
+ junit.framework.Test testCase = new CatalogRemoteJsonRPCTest("testCatalog", node);
+ junit.framework.Test loadTest = new LoadTest(testCase, USERS, ITERATIONS, TIMER);
+ //node.stop();
+ return loadTest;
+ }
+
+ public static junit.framework.Test wsTests() {
+ System.out.println("#### WS Remote Tests");
+ Node node = initializeTuscanyRuntime(CatalogRemoteWsTest.COMPOSITE);
+ junit.framework.Test testCase = new CatalogRemoteJsonRPCTest("testCatalog", node );
+ junit.framework.Test loadTest = new LoadTest(testCase, USERS, ITERATIONS, TIMER);
+ //node.stop();
+ return loadTest;
+ }
+
+ @Test
+ public void run() throws Exception {
+ junit.textui.TestRunner.run(localTests());
+ junit.textui.TestRunner.run(jsonTests());
+ junit.textui.TestRunner.run(wsTests());
+ }
+
+
+ public static void main(String[] args) throws Exception {
+ LoadTestCase loadTest = new LoadTestCase();
+ loadTest.run();
+ }
+
+}
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-local.composite b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-local.composite
new file mode 100644
index 0000000000..707bc5ae32
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-local.composite
@@ -0,0 +1,51 @@
+<?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://docs.oasis-open.org/ns/opencsa/sca/200912"
+ xmlns:tuscany="http://tuscany.apache.org/xmlns/sca/1.1"
+ targetNamespace="http://store"
+ name="catalog-local">
+
+ <component name="CatalogAggregator">
+ <implementation.java class="services.sca.CatalogAggregatorImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog"/>
+ </service>
+ <reference name="fruitsCatalog" target="FruitsCatalog">
+ <interface.java interface="services.Catalog"/>
+ </reference>
+ <reference name="vegetablesCatalog" target="VegetablesCatalog">
+ <interface.java interface="services.Catalog"/>
+ </reference>
+ </component>
+
+ <component name="FruitsCatalog">
+ <implementation.java class="services.sca.FruitsCatalogImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog"/>
+ </service>
+ </component>
+
+ <component name="VegetablesCatalog">
+ <implementation.java class="services.sca.FruitsCatalogImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog"/>
+ </service>
+ </component>
+</composite>
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-jsonrpc.composite b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-jsonrpc.composite
new file mode 100644
index 0000000000..545b9d7b10
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-jsonrpc.composite
@@ -0,0 +1,55 @@
+<?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://docs.oasis-open.org/ns/opencsa/sca/200912"
+ xmlns:tuscany="http://tuscany.apache.org/xmlns/sca/1.1"
+ targetNamespace="http://store"
+ name="catalog-remote-jsonrpc">
+
+ <component name="CatalogAggregator">
+ <implementation.java class="services.sca.CatalogAggregatorImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ </service>
+ <reference name="fruitsCatalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <tuscany:binding.jsonrpc uri="http://localhost:8085/FruitsCatalog"/>
+ </reference>
+ <reference name="vegetablesCatalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <tuscany:binding.jsonrpc uri="http://localhost:8085/VegetableCatalog" />
+ </reference>
+ </component>
+
+ <component name="FruitsCatalog">
+ <implementation.java class="services.sca.FruitsCatalogImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <tuscany:binding.jsonrpc uri="http://localhost:8085/FruitsCatalog" />
+ </service>
+ </component>
+
+ <component name="VegetablesCatalog">
+ <implementation.java class="services.sca.FruitsCatalogImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <tuscany:binding.jsonrpc uri="http://localhost:8085/VegetableCatalog" />
+ </service>
+ </component>
+</composite>
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-ws.composite b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-ws.composite
new file mode 100644
index 0000000000..5ad7789e84
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/catalog-remote-ws.composite
@@ -0,0 +1,55 @@
+<?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://docs.oasis-open.org/ns/opencsa/sca/200912"
+ xmlns:tuscany="http://tuscany.apache.org/xmlns/sca/1.1"
+ targetNamespace="http://store"
+ name="catalog-remote-ws">
+
+ <component name="CatalogAggregator">
+ <implementation.java class="services.sca.CatalogAggregatorImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ </service>
+ <reference name="fruitsCatalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <binding.ws uri="http://localhost:8086/FruitsCatalog"/>
+ </reference>
+ <reference name="vegetablesCatalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <binding.ws uri="http://localhost:8086/VegetableCatalog"/>
+ </reference>
+ </component>
+
+ <component name="FruitsCatalog">
+ <implementation.java class="services.sca.FruitsCatalogImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <binding.ws uri="http://localhost:8086/FruitsCatalog"/>
+ </service>
+ </component>
+
+ <component name="VegetablesCatalog">
+ <implementation.java class="services.sca.FruitsCatalogImpl"/>
+ <service name="Catalog">
+ <interface.java interface="services.Catalog" remotable="true"/>
+ <binding.ws uri="http://localhost:8086/VegetableCatalog"/>
+ </service>
+ </component>
+</composite>
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/log4j.properties b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/log4j.properties
new file mode 100644
index 0000000000..05e7450068
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/log4j.properties
@@ -0,0 +1,28 @@
+#
+#
+# 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.
+#
+#
+
+# Configure the console as our one appender
+log4j.appender.A1=org.apache.log4j.ConsoleAppender
+log4j.appender.A1.layout=org.apache.log4j.PatternLayout
+log4j.appender.A1.layout.ConversionPattern=%d{HH:mm:ss,SSS} %-5p [%c] - %m%n
+
+#tuscany debug messages
+log4j.category.org.apache.tuscany=DEBUG,A1
diff --git a/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/logging.properties b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/logging.properties
new file mode 100644
index 0000000000..d7f03147b2
--- /dev/null
+++ b/sandbox/lresende/sca-2.x/itest/performance/src/test/resources/logging.properties
@@ -0,0 +1,37 @@
+#
+#
+# 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.
+#
+#
+# A default java.util.logging configuration.
+# (All App Engine logging is through java.util.logging by default).
+#
+# To use this configuration, copy it into your application's WEB-INF
+# folder and add the following to your appengine-web.xml:
+#
+# <system-properties>
+# <property name="java.util.logging.config.file" value="WEB-INF/logging.properties"/>
+# </system-properties>
+#
+
+# Set the default logging level for all loggers to WARNING
+.level = DEBUG
+
+#tuscany debug messages
+org.apache.tuscany.level = DEBUG
+