From f0797f0026f729fa612930fbd0acefc5343a0fe6 Mon Sep 17 00:00:00 2001 From: nash Date: Mon, 22 Nov 2010 09:49:22 +0000 Subject: Copy 1.6.1-RC2 tag as 1.6.1 git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1037648 13f79535-47bb-0310-9956-ffa450edef68 --- .../test/osgi/runtime/impl/EquinoxTestRuntime.java | 92 ++++++++++++ .../test/osgi/runtime/impl/FelixTestRuntime.java | 163 +++++++++++++++++++++ .../test/osgi/runtime/impl/OSGiTestRuntime.java | 163 +++++++++++++++++++++ 3 files changed, 418 insertions(+) create mode 100644 sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/EquinoxTestRuntime.java create mode 100644 sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/FelixTestRuntime.java create mode 100644 sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/OSGiTestRuntime.java (limited to 'sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi') diff --git a/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/EquinoxTestRuntime.java b/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/EquinoxTestRuntime.java new file mode 100644 index 0000000000..2e3137239e --- /dev/null +++ b/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/EquinoxTestRuntime.java @@ -0,0 +1,92 @@ +/* + * 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.test.osgi.runtime.impl; + +import java.lang.reflect.Method; + +import org.osgi.framework.BundleContext; + +public class EquinoxTestRuntime extends OSGiTestRuntime { + + + private static BundleContext bundleContext; + + private static EquinoxTestRuntime instance; + + private static Class eclipseStarterClass; + + public static OSGiTestRuntime getInstance() throws Exception { + if (instance == null) { + eclipseStarterClass = EquinoxTestRuntime.class.getClassLoader().loadClass("org.eclipse.core.runtime.adaptor.EclipseStarter"); + EquinoxTestRuntime runtime = new EquinoxTestRuntime(); + instance = runtime; + } + return instance; + } + + + protected BundleContext startRuntime() throws Exception { + + if (bundleContext != null) + return bundleContext; + + Method startupMethod = eclipseStarterClass.getMethod("startup", String [].class, Runnable.class); + + System.setProperty("org.osgi.framework.system.packages", getSystemPackages()); + // Equinox version 3.2 upwards have a startup method which returns BundleContext + bundleContext = (BundleContext) startupMethod.invoke(null, + new String[] {/*"-clean", */"-console", "-configuration", "target/configuration"}, + null ); + + return bundleContext; + + } + + @Override + public BundleContext getBundleContext() { + return bundleContext; + } + + @Override + protected void setBundleContext(BundleContext bundleContext) { + super.setBundleContext(bundleContext); + EquinoxTestRuntime.bundleContext = bundleContext; + } + + @Override + public void shutdown() throws Exception { + + if (bundleContext == null) + return; + bundleContext = null; + instance = null; + if (eclipseStarterClass != null) { + Method shutdownMethod = eclipseStarterClass.getMethod("shutdown"); + try { + shutdownMethod.invoke(eclipseStarterClass); + } catch (Exception e) { + // Ignore errors. + } + } + super.shutdown(); + } + + + +} diff --git a/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/FelixTestRuntime.java b/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/FelixTestRuntime.java new file mode 100644 index 0000000000..0dafffdb8c --- /dev/null +++ b/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/FelixTestRuntime.java @@ -0,0 +1,163 @@ +/* + * 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.test.osgi.runtime.impl; + +import java.io.File; +import java.lang.reflect.Constructor; +import java.lang.reflect.Method; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.Properties; + +import org.osgi.framework.Bundle; +import org.osgi.framework.BundleActivator; +import org.osgi.framework.BundleContext; + +public class FelixTestRuntime extends OSGiTestRuntime implements BundleActivator { + + private static BundleContext bundleContext; + + private static FelixTestRuntime instance; + + private static Bundle felix; + + + public static OSGiTestRuntime getInstance() throws Exception { + if (instance == null) { + + FelixTestRuntime runtime = new FelixTestRuntime(); + instance = runtime; + } + return instance; + } + + +// private void deleteDirectory(File dir) { +// File[] files = dir.listFiles(); +// for (int i = 0; i < files.length; i++) { +// if (files[i].isDirectory()) +// deleteDirectory(files[i]); +// else { +// files[i].delete(); +// } +// } +// dir.delete(); +// +// } + +// private void deleteProfile() { +// String profileDirName = System.getProperty("felix.cache.profiledir"); +// if (profileDirName == null) profileDirName = ".felix"; +// File profileDir = new File(profileDirName); +// if (profileDir.isDirectory()) +// deleteDirectory(profileDir); +// else +// profileDir.delete(); +// } + + protected BundleContext startRuntime() throws Exception { + + if (bundleContext != null) + return bundleContext; + + ClassLoader cl = this.getClass().getClassLoader(); + Class felixMainClass = cl.loadClass("org.apache.felix.main.Main"); + Class felixClass = cl.loadClass("org.apache.felix.framework.Felix"); + Method propsMethod = felixMainClass.getMethod("loadConfigProperties"); + Properties props = (Properties)propsMethod.invoke(null); + + //deleteProfile(); + // Create profile directory + String profileDirName = System.getProperty("felix.cache.profiledir"); + if (profileDirName == null) profileDirName = ".felix"; + File profileDir = new File(profileDirName); + profileDir.mkdir(); + + props.put("felix.cache.profiledir", profileDir.getAbsolutePath()); + props.put("felix.embedded.execution", "true"); + String systemPackages = getSystemPackages() + + ", org.apache.felix.main"; + + + props.put("org.osgi.framework.system.packages", systemPackages); + + Constructor felixConstructor = felixClass.getConstructor(Map.class, List.class); + List activators = new ArrayList(); + + Class autoActivatorClass = cl.loadClass("org.apache.felix.main.AutoActivator"); + Constructor autoActivatorConstructor = autoActivatorClass.getConstructor(Map.class); + BundleActivator autoActivator = (BundleActivator)autoActivatorConstructor.newInstance(props); + activators.add(autoActivator); + felix = (Bundle)felixConstructor.newInstance(props, activators); + felix.start(); + bundleContext = felix.getBundleContext(); + + return bundleContext; + + } + + public void start(BundleContext context) throws Exception { + + bundleContext = context; + synchronized (this) { + this.notify(); + } + } + + public void stop(BundleContext context) throws Exception { + bundleContext = null; + } + + + + @Override + public BundleContext getBundleContext() { + return bundleContext; + } + + @Override + protected void setBundleContext(BundleContext bundleContext) { + super.setBundleContext(bundleContext); + FelixTestRuntime.bundleContext = bundleContext; + } + + + @Override + public void shutdown() throws Exception { + + if (bundleContext == null) + return; + + bundleContext = null; + instance = null; + + felix.stop(); + int retries = 50; + synchronized (felix) { + while (retries-- > 0 && felix.getState() != Bundle.UNINSTALLED) { + felix.wait(100); + } + } + + super.shutdown(); + } + + +} diff --git a/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/OSGiTestRuntime.java b/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/OSGiTestRuntime.java new file mode 100644 index 0000000000..6356718fe5 --- /dev/null +++ b/sca-java-1.x/tags/1.6.1/itest/osgi-tuscany/osgi-tuscany-test/src/main/java/org/apache/tuscany/sca/test/osgi/runtime/impl/OSGiTestRuntime.java @@ -0,0 +1,163 @@ +/* + * 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.test.osgi.runtime.impl; + +import java.lang.reflect.Method; + +import org.osgi.framework.BundleContext; +import org.osgi.framework.BundleException; + +public abstract class OSGiTestRuntime { + + public abstract BundleContext getBundleContext(); + + protected abstract BundleContext startRuntime() throws Exception; + + private static OSGiTestRuntime instance; + + private BundleContext bundleContext; + + + /** + * System property org.apache.tuscany.implementation.osgi.runtime.OSGiRuntime can be set to the + * name of the OSGiRuntime class (eg. EquinoxRuntime). If set, start this runtime and return the + * system bundlecontext. If not set, start Felix from the classpath. + * + * @throws BundleException + */ + public synchronized static OSGiTestRuntime findRuntime() throws Exception { + if (instance != null) { + return instance; + } + String runtimeClassName = System.getProperty(OSGiTestRuntime.class.getName()); + + if (instance != null) + return instance; + + if (runtimeClassName != null) { + try { + Class runtimeClass = OSGiTestRuntime.class.getClassLoader().loadClass(runtimeClassName); + Method method = runtimeClass.getMethod("getInstance"); + instance = (OSGiTestRuntime) method.invoke(null); + return instance; + + } catch (Exception e) { + throw new BundleException("Could not start OSGi runtime " + runtimeClassName, e); + } + } + + try { + instance = EquinoxTestRuntime.getInstance(); + } catch (Throwable e) { + instance = FelixTestRuntime.getInstance(); + } + + return instance; + + } + + + public synchronized static OSGiTestRuntime getRuntime() throws Exception { + + instance = findRuntime(); + + if (instance != null) { + + if (instance.bundleContext == null) { + instance.startRuntime(); + instance.bundleContext = instance.getBundleContext(); + } + return instance; + } + return instance; + } + + + public void shutdown() throws Exception { + + bundleContext = null; + if (this == instance) + instance = null; + } + + protected void setBundleContext(BundleContext bundleContext) { + this.bundleContext = bundleContext; + } + + + /** + * @return the instance + */ + public synchronized static void stop() throws Exception { + if (instance != null) { + instance.shutdown(); + instance = null; + } + } + + + /** + * @return the list of packages to be exported by the system bundle + */ + protected String getSystemPackages() { + String systemPackages = + "org.osgi.framework; version=1.3.0," + + "org.osgi.service.packageadmin; version=1.2.0, " + + "org.osgi.service.startlevel; version=1.0.0, " + + "org.osgi.service.url; version=1.0.0, " + + "org.osgi.util.tracker; version=1.3.2, " + + "javax.xml, " + + "javax.xml.datatype, " + + "javax.xml.namespace, " + + "javax.xml.parsers, " + + "javax.xml.transform, " + + "javax.xml.transform.dom, " + + "javax.xml.transform.sax, " + + "javax.xml.transform.stream, " + + "javax.xml.validation, " + + "javax.xml.xpath, " + + "javax.sql," + + "org.w3c.dom, " + + "org.w3c.dom.bootstrap, " + + "org.w3c.dom.ls, " + + "org.xml.sax, " + + "org.xml.sax.ext, " + + "org.xml.sax.helpers, " + + "javax.security.auth, " + + "javax.security.auth.login, " + + "javax.security.auth.callback, " + + "javax.security.cert, " + + "javax.naming, " + + "javax.naming.spi, " + + "javax.naming.directory, " + + "javax.management, " + + "javax.imageio, " + + "sun.misc, " + + "javax.net, " + + "javax.net.ssl, " + + "javax.crypto, " + + "javax.rmi, " + + "javax.transaction, " + + "javax.transaction.xa"; + + return systemPackages; + + } + +} -- cgit v1.2.3