From af72632bc73c9f1983f72f1647236bff3392cab6 Mon Sep 17 00:00:00 2001 From: slaws Date: Wed, 29 Jul 2009 09:36:53 +0000 Subject: TUSCANY-3174 - Turn the test launcher into a unit test git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@798822 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/tuscany/sca/launcher/TestLauncher.java | 106 ------------------ .../manager/test/WorkspaceManagerTestCase.java | 118 +++++++++++++++++++++ 2 files changed, 118 insertions(+), 106 deletions(-) delete mode 100644 branches/sca-java-1.x/itest/workspace-manager/src/main/java/org/apache/tuscany/sca/launcher/TestLauncher.java create mode 100644 branches/sca-java-1.x/itest/workspace-manager/src/test/java/org/apache/tuscany/sca/workspace/manager/test/WorkspaceManagerTestCase.java (limited to 'branches/sca-java-1.x/itest') diff --git a/branches/sca-java-1.x/itest/workspace-manager/src/main/java/org/apache/tuscany/sca/launcher/TestLauncher.java b/branches/sca-java-1.x/itest/workspace-manager/src/main/java/org/apache/tuscany/sca/launcher/TestLauncher.java deleted file mode 100644 index 3e4cd41924..0000000000 --- a/branches/sca-java-1.x/itest/workspace-manager/src/main/java/org/apache/tuscany/sca/launcher/TestLauncher.java +++ /dev/null @@ -1,106 +0,0 @@ -/* - * 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.launcher; - - -import org.apache.tuscany.sca.implementation.xyz.ImplementationXYZFactoryImpl; -import org.apache.tuscany.sca.implementation.xyz.ImplementationXYZProcessor; -import org.apache.tuscany.sca.imprt.xyz.DefaultImportExportXYZFactory; -import org.apache.tuscany.sca.imprt.xyz.ImportXYZProcessor; - -import org.apache.tuscany.sca.contribution.Contribution; -import org.apache.tuscany.sca.contribution.ContributionFactory; -import org.apache.tuscany.sca.contribution.ModelFactoryExtensionPoint; -import org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessorExtensionPoint; -import org.apache.tuscany.sca.contribution.processor.ValidationSchemaExtensionPoint; -import org.apache.tuscany.sca.core.ExtensionPointRegistry; -import org.apache.tuscany.sca.core.UtilityExtensionPoint; -import org.apache.tuscany.sca.monitor.Monitor; -import org.apache.tuscany.sca.monitor.MonitorFactory; -import org.apache.tuscany.sca.monitor.Problem; -import org.apache.tuscany.sca.monitor.Problem.Severity; -import org.apache.tuscany.sca.workspace.Workspace; -import org.apache.tuscany.sca.workspace.manager.WorkspaceManager; -import org.osoa.sca.ServiceRuntimeException; - -public class TestLauncher { - - public final static void main(String[] args) { - - WorkspaceManager workspaceManager = WorkspaceManager.newInstance(); - - addExtensions(workspaceManager); - workspaceManager.start(); - processContributions(workspaceManager); - workspaceManager.stop(); - } - - private static void addExtensions(WorkspaceManager workspaceManager) { - try { - System.out.println("Add extensions"); - ExtensionPointRegistry registry = workspaceManager.getRegistry(); - - // get monitor - UtilityExtensionPoint utilities = registry.getExtensionPoint(UtilityExtensionPoint.class); - MonitorFactory monitorFactory = utilities.getUtility(MonitorFactory.class); - Monitor monitor = monitorFactory.createMonitor(); - - // create validation schema - // are schema required - ValidationSchemaExtensionPoint schemas = registry.getExtensionPoint(ValidationSchemaExtensionPoint.class); - schemas.addSchema(TestLauncher.class.getClassLoader().getResource("implementation-xyz.xsd").toString()); - schemas.addSchema(TestLauncher.class.getClassLoader().getResource("import-xyz.xsd").toString()); - - // create model factories - ModelFactoryExtensionPoint modelFactories = registry.getExtensionPoint(ModelFactoryExtensionPoint.class); - - modelFactories.addFactory(new ImplementationXYZFactoryImpl()); - modelFactories.addFactory(new DefaultImportExportXYZFactory()); - - // Create artifact processors - StAXArtifactProcessorExtensionPoint artifactProcessors = - registry.getExtensionPoint(StAXArtifactProcessorExtensionPoint.class); - - artifactProcessors.addArtifactProcessor(new ImplementationXYZProcessor(modelFactories, - monitor)); - artifactProcessors.addArtifactProcessor(new ImportXYZProcessor(modelFactories, - monitor)); - - } catch (Exception ex) { - ex.printStackTrace(); - } - } - - private static void processContributions(WorkspaceManager workspaceManager){ - try { - System.out.println("Process contribution"); - - Workspace workspace = workspaceManager.createWorkspace(); - Contribution contribution = workspaceManager.readContribution("contrib1", "./target/classes/contrib1"); - workspaceManager.addContributionToWorkspace(workspace, contribution); - workspaceManager.resolveWorkspace(workspace); - - // do whatever you need to do with workspace and its resolved contributions - - } catch (Exception ex) { - ex.printStackTrace(); - } - } -} diff --git a/branches/sca-java-1.x/itest/workspace-manager/src/test/java/org/apache/tuscany/sca/workspace/manager/test/WorkspaceManagerTestCase.java b/branches/sca-java-1.x/itest/workspace-manager/src/test/java/org/apache/tuscany/sca/workspace/manager/test/WorkspaceManagerTestCase.java new file mode 100644 index 0000000000..d325f404c9 --- /dev/null +++ b/branches/sca-java-1.x/itest/workspace-manager/src/test/java/org/apache/tuscany/sca/workspace/manager/test/WorkspaceManagerTestCase.java @@ -0,0 +1,118 @@ +/* + * 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.workspace.manager.test; + +import static org.junit.Assert.assertEquals; + + +import org.apache.tuscany.sca.contribution.Contribution; +import org.apache.tuscany.sca.contribution.ModelFactoryExtensionPoint; +import org.apache.tuscany.sca.contribution.processor.StAXArtifactProcessorExtensionPoint; +import org.apache.tuscany.sca.contribution.processor.ValidationSchemaExtensionPoint; +import org.apache.tuscany.sca.core.ExtensionPointRegistry; +import org.apache.tuscany.sca.core.UtilityExtensionPoint; +import org.apache.tuscany.sca.implementation.xyz.ImplementationXYZFactoryImpl; +import org.apache.tuscany.sca.implementation.xyz.ImplementationXYZProcessor; +import org.apache.tuscany.sca.imprt.xyz.DefaultImportExportXYZFactory; +import org.apache.tuscany.sca.imprt.xyz.ImportXYZProcessor; +import org.apache.tuscany.sca.monitor.Monitor; +import org.apache.tuscany.sca.monitor.MonitorFactory; +import org.apache.tuscany.sca.workspace.Workspace; +import org.apache.tuscany.sca.workspace.manager.WorkspaceManager; +import org.junit.After; +import org.junit.Before; +import org.junit.Test; + + +public class WorkspaceManagerTestCase { + + private WorkspaceManager workspaceManager; + + @Before + public void init() { + workspaceManager = WorkspaceManager.newInstance(); + addExtensions(workspaceManager); + workspaceManager.start(); + } + + @Test + public void testHelloWorldCreate() throws Exception { + Workspace workspace = loadWorkspace(workspaceManager); + assertEquals(1, workspace.getContributions().get(0).getDeployables().size()); + } + + private void addExtensions(WorkspaceManager workspaceManager) { + try { + System.out.println("Add extensions"); + ExtensionPointRegistry registry = workspaceManager.getRegistry(); + + // get monitor + UtilityExtensionPoint utilities = registry.getExtensionPoint(UtilityExtensionPoint.class); + MonitorFactory monitorFactory = utilities.getUtility(MonitorFactory.class); + Monitor monitor = monitorFactory.createMonitor(); + + // create validation schema + // are schema required + ValidationSchemaExtensionPoint schemas = registry.getExtensionPoint(ValidationSchemaExtensionPoint.class); + schemas.addSchema(WorkspaceManagerTestCase.class.getClassLoader().getResource("implementation-xyz.xsd").toString()); + schemas.addSchema(WorkspaceManagerTestCase.class.getClassLoader().getResource("import-xyz.xsd").toString()); + + // create model factories + ModelFactoryExtensionPoint modelFactories = registry.getExtensionPoint(ModelFactoryExtensionPoint.class); + + modelFactories.addFactory(new ImplementationXYZFactoryImpl()); + modelFactories.addFactory(new DefaultImportExportXYZFactory()); + + // Create artifact processors + StAXArtifactProcessorExtensionPoint artifactProcessors = + registry.getExtensionPoint(StAXArtifactProcessorExtensionPoint.class); + + artifactProcessors.addArtifactProcessor(new ImplementationXYZProcessor(modelFactories, + monitor)); + artifactProcessors.addArtifactProcessor(new ImportXYZProcessor(modelFactories, + monitor)); + + } catch (Exception ex) { + ex.printStackTrace(); + } + } + + private Workspace loadWorkspace(WorkspaceManager workspaceManager){ + try { + System.out.println("Process contribution"); + + Workspace workspace = workspaceManager.createWorkspace(); + Contribution contribution = workspaceManager.readContribution("contrib1", "./target/classes/contrib1"); + workspaceManager.addContributionToWorkspace(workspace, contribution); + workspaceManager.resolveWorkspace(workspace); + + return workspace; + + } catch (Exception ex) { + ex.printStackTrace(); + } + + return null; + } + + @After + public void end() { + workspaceManager.stop(); + } +} -- cgit v1.2.3