669 lines
31 KiB
Diff
669 lines
31 KiB
Diff
From 9fd0241b1ceb623332f8827df99270b54763efc8 Mon Sep 17 00:00:00 2001
|
|
From: Jan Sievers <jan.sievers@sap.com>
|
|
Date: Tue, 4 Sep 2012 16:02:52 +0200
|
|
Subject: [PATCH] POC 386481 update maven surefire to latest version 2.15
|
|
|
|
while SUREFIRE-825 and SUREFIRE-876 are fixed,
|
|
there are several new problems:
|
|
|
|
1. The junit47 provider is broken again (probably
|
|
due to junit bug https://bugs.eclipse.org/bugs/show_bug.cgi?id=318299
|
|
2. the internal structure of surefire chnaged significantly
|
|
(new jars need to be pulled into OSGi, the Surefire
|
|
booter/starter API changed, directory scanning must now
|
|
be done in the TestMojo already
|
|
3. The most sever issue here is that we don't have the dependencies
|
|
of surefire under control and what used to be more or less self-contained
|
|
(surefire-api and surefire-booter) now drags in lots of dependencies
|
|
which we don't really want to wrap in OSGi. I only added those actually
|
|
needed by what we are using, the correct list of dependent jars would
|
|
be much longer.
|
|
|
|
Change-Id: Ibcb439a24add880c4cdafe67b42e29ca3cb14ff1
|
|
---
|
|
.../META-INF/MANIFEST.MF | 2 +-
|
|
.../build.properties | 2 +-
|
|
.../META-INF/MANIFEST.MF | 2 +-
|
|
.../build.properties | 2 +-
|
|
.../META-INF/MANIFEST.MF | 7 +-
|
|
.../build.properties | 3 +-
|
|
.../org.eclipse.tycho.surefire.junit47/pom.xml | 10 ++
|
|
.../junitcore/OsgiEnabledJUnitCoreProvider.java | 126 ---------------------
|
|
.../junitcore/OsgiEnabledJUnitCoreRunListener.java | 100 ----------------
|
|
.../META-INF/MANIFEST.MF | 6 +-
|
|
.../org.eclipse.tycho.surefire.osgibooter/pom.xml | 10 ++
|
|
.../surefire/osgibooter/OsgiSurefireBooter.java | 36 +++---
|
|
.../osgibooter/TychoClasspathConfiguration.java | 35 ++++--
|
|
tycho-surefire/pom.xml | 2 +-
|
|
tycho-surefire/tycho-surefire-plugin/pom.xml | 5 +
|
|
.../java/org/eclipse/tycho/surefire/TestMojo.java | 29 ++++-
|
|
.../surefire/provider/impl/JUnit47Provider.java | 2 +-
|
|
17 files changed, 116 insertions(+), 263 deletions(-)
|
|
delete mode 100644 tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreProvider.java
|
|
delete mode 100644 tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreRunListener.java
|
|
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit/META-INF/MANIFEST.MF b/tycho-surefire/org.eclipse.tycho.surefire.junit/META-INF/MANIFEST.MF
|
|
index dbe883b..35bc312 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit/META-INF/MANIFEST.MF
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit/META-INF/MANIFEST.MF
|
|
@@ -7,5 +7,5 @@ Fragment-Host: org.eclipse.tycho.surefire.osgibooter;bundle-version="0.14.0"
|
|
Bundle-RequiredExecutionEnvironment: J2SE-1.5,
|
|
JavaSE-1.6
|
|
Require-Bundle: org.junit;bundle-version="[3.8.0,4.0.0)"
|
|
-Bundle-ClassPath: jars/surefire-junit3-2.10.jar
|
|
+Bundle-ClassPath: jars/surefire-junit3-2.15.jar
|
|
Bundle-Vendor: %providerName
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit/build.properties b/tycho-surefire/org.eclipse.tycho.surefire.junit/build.properties
|
|
index 499ce76..fe88b19 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit/build.properties
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit/build.properties
|
|
@@ -9,5 +9,5 @@
|
|
# Sonatype Inc. - initial API and implementation
|
|
###############################################################################
|
|
bin.includes = META-INF/,\
|
|
- jars/surefire-junit3-2.10.jar,\
|
|
+ jars/,\
|
|
plugin.properties
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit4/META-INF/MANIFEST.MF b/tycho-surefire/org.eclipse.tycho.surefire.junit4/META-INF/MANIFEST.MF
|
|
index 7498728..19c7ebb 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit4/META-INF/MANIFEST.MF
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit4/META-INF/MANIFEST.MF
|
|
@@ -6,7 +6,7 @@ Bundle-Version: 0.18.0
|
|
Fragment-Host: org.eclipse.tycho.surefire.osgibooter;bundle-version="0.14.0"
|
|
Bundle-RequiredExecutionEnvironment: J2SE-1.5,
|
|
JavaSE-1.6
|
|
-Bundle-ClassPath: jars/surefire-junit4-2.10.jar
|
|
+Bundle-ClassPath: jars/surefire-junit4-2.15.jar
|
|
Import-Package: junit.framework;version="3.0.0",
|
|
org.junit;version="4.0.0",
|
|
org.junit.runner;version="4.0.0",
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit4/build.properties b/tycho-surefire/org.eclipse.tycho.surefire.junit4/build.properties
|
|
index b787149..fe88b19 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit4/build.properties
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit4/build.properties
|
|
@@ -9,5 +9,5 @@
|
|
# Sonatype Inc. - initial API and implementation
|
|
###############################################################################
|
|
bin.includes = META-INF/,\
|
|
- jars/surefire-junit4-2.10.jar,\
|
|
+ jars/,\
|
|
plugin.properties
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit47/META-INF/MANIFEST.MF b/tycho-surefire/org.eclipse.tycho.surefire.junit47/META-INF/MANIFEST.MF
|
|
index 024acb7..33d777b 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit47/META-INF/MANIFEST.MF
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit47/META-INF/MANIFEST.MF
|
|
@@ -6,11 +6,14 @@ Bundle-Version: 0.18.0
|
|
Fragment-Host: org.eclipse.tycho.surefire.osgibooter;bundle-version="0.16.0"
|
|
Bundle-RequiredExecutionEnvironment: J2SE-1.5
|
|
Bundle-ClassPath: .,
|
|
- jars/surefire-junit47-2.10.jar
|
|
+ jars/surefire-junit47-2.15.jar,
|
|
+ jars/common-junit48-2.15.jar,
|
|
+ jars/surefire-grouper-2.15.jar
|
|
Import-Package: junit.framework;version="3.0.0",
|
|
org.junit;version="[4.7,5)",
|
|
org.junit.runner;version="[4.7,5)",
|
|
org.junit.runner.notification;version="[4.7,5)",
|
|
org.junit.runners;version="[4.7,5)",
|
|
- org.junit.runners.model;version="[4.7,5)"
|
|
+ org.junit.runners.model;version="[4.7,5)",
|
|
+ org.junit.runner.manipulation;version="[4.7,5)"
|
|
Bundle-Vendor: %providerName
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit47/build.properties b/tycho-surefire/org.eclipse.tycho.surefire.junit47/build.properties
|
|
index 716961d..2589258 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit47/build.properties
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit47/build.properties
|
|
@@ -10,8 +10,7 @@
|
|
###############################################################################
|
|
bin.includes = .,\
|
|
META-INF/,\
|
|
- jars/surefire-junit47-2.10.jar,\
|
|
+ jars/,\
|
|
plugin.properties,\
|
|
about.html,\
|
|
about_files/
|
|
-source.. = src/
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit47/pom.xml b/tycho-surefire/org.eclipse.tycho.surefire.junit47/pom.xml
|
|
index d5abf73..6a6eaa2 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit47/pom.xml
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.junit47/pom.xml
|
|
@@ -44,6 +44,16 @@
|
|
<artifactId>surefire-junit47</artifactId>
|
|
<version>${surefire-version}</version>
|
|
</artifactItem>
|
|
+ <artifactItem>
|
|
+ <groupId>org.apache.maven.surefire</groupId>
|
|
+ <artifactId>common-junit48</artifactId>
|
|
+ <version>${surefire-version}</version>
|
|
+ </artifactItem>
|
|
+ <artifactItem>
|
|
+ <groupId>org.apache.maven.surefire</groupId>
|
|
+ <artifactId>surefire-grouper</artifactId>
|
|
+ <version>${surefire-version}</version>
|
|
+ </artifactItem>
|
|
</artifactItems>
|
|
</configuration>
|
|
</execution>
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreProvider.java b/tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreProvider.java
|
|
deleted file mode 100644
|
|
index eaa8dc4..0000000
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreProvider.java
|
|
+++ /dev/null
|
|
@@ -1,126 +0,0 @@
|
|
-package org.apache.maven.surefire.junitcore;
|
|
-
|
|
-/*
|
|
- * 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.
|
|
- */
|
|
-
|
|
-import java.util.Iterator;
|
|
-import java.util.List;
|
|
-import java.util.Map;
|
|
-import java.util.concurrent.ConcurrentHashMap;
|
|
-
|
|
-import org.apache.maven.surefire.common.junit4.JUnit4RunListenerFactory;
|
|
-import org.apache.maven.surefire.common.junit4.JUnit4TestChecker;
|
|
-import org.apache.maven.surefire.providerapi.AbstractProvider;
|
|
-import org.apache.maven.surefire.providerapi.ProviderParameters;
|
|
-import org.apache.maven.surefire.report.ConsoleLogger;
|
|
-import org.apache.maven.surefire.report.ConsoleOutputCapture;
|
|
-import org.apache.maven.surefire.report.ConsoleOutputReceiver;
|
|
-import org.apache.maven.surefire.report.ReporterException;
|
|
-import org.apache.maven.surefire.report.ReporterFactory;
|
|
-import org.apache.maven.surefire.report.RunListener;
|
|
-import org.apache.maven.surefire.suite.RunResult;
|
|
-import org.apache.maven.surefire.testset.TestSetFailedException;
|
|
-import org.apache.maven.surefire.util.DirectoryScanner;
|
|
-import org.apache.maven.surefire.util.ScannerFilter;
|
|
-import org.apache.maven.surefire.util.TestsToRun;
|
|
-
|
|
-/**
|
|
- * This class is a workaround for surefire bug {@link http://jira.codehaus.org/browse/SUREFIRE-876 }. It's a copy of
|
|
- * {@link JUnitCoreProvider} with the only change to use OsgiEnabledJUnitCoreRunListener instead of
|
|
- * JUnitCoreRunListener. TODO remove and use {@link JUnitCoreProvider} instead when surefire release with proposed
|
|
- * bugfix is available.
|
|
- *
|
|
- * @author Kristian Rosenvold
|
|
- * @author Jan Sievers (SAP)
|
|
- */
|
|
-public class OsgiEnabledJUnitCoreProvider
|
|
- extends AbstractProvider
|
|
-{
|
|
- private final ClassLoader testClassLoader;
|
|
-
|
|
- private final DirectoryScanner directoryScanner;
|
|
-
|
|
- private final JUnitCoreParameters jUnitCoreParameters;
|
|
-
|
|
- private final ScannerFilter scannerFilter;
|
|
-
|
|
- private final List<org.junit.runner.notification.RunListener> customRunListeners;
|
|
-
|
|
- private final ProviderParameters providerParameters;
|
|
-
|
|
- private TestsToRun testsToRun;
|
|
-
|
|
-
|
|
- public OsgiEnabledJUnitCoreProvider( ProviderParameters providerParameters )
|
|
- {
|
|
- this.providerParameters = providerParameters;
|
|
- this.testClassLoader = providerParameters.getTestClassLoader();
|
|
- this.directoryScanner = providerParameters.getDirectoryScanner();
|
|
- this.jUnitCoreParameters = new JUnitCoreParameters( providerParameters.getProviderProperties() );
|
|
- this.scannerFilter = new JUnit4TestChecker( testClassLoader );
|
|
- customRunListeners = JUnit4RunListenerFactory.
|
|
- createCustomListeners( providerParameters.getProviderProperties().getProperty( "listener" ) );
|
|
-
|
|
- }
|
|
-
|
|
- public Boolean isRunnable()
|
|
- {
|
|
- return Boolean.TRUE;
|
|
- }
|
|
-
|
|
- public Iterator getSuites()
|
|
- {
|
|
- testsToRun = scanClassPath();
|
|
- return testsToRun.iterator();
|
|
- }
|
|
-
|
|
- public RunResult invoke( Object forkTestSet )
|
|
- throws TestSetFailedException, ReporterException
|
|
- {
|
|
- final String message = "Concurrency config is " + jUnitCoreParameters.toString() + "\n";
|
|
- final ReporterFactory reporterFactory = providerParameters.getReporterFactory();
|
|
-
|
|
- final ConsoleLogger consoleLogger = providerParameters.getConsoleLogger();
|
|
- consoleLogger.info( message );
|
|
-
|
|
- if ( testsToRun == null )
|
|
- {
|
|
- testsToRun = forkTestSet == null ? scanClassPath() : TestsToRun.fromClass( (Class) forkTestSet );
|
|
- }
|
|
- final Map<String, TestSet> testSetMap = new ConcurrentHashMap<String, TestSet>();
|
|
-
|
|
- RunListener listener = ConcurrentReporterManager.createInstance( testSetMap, reporterFactory,
|
|
- jUnitCoreParameters.isParallelClasses(),
|
|
- jUnitCoreParameters.isParallelBoth(),
|
|
- consoleLogger );
|
|
-
|
|
- ConsoleOutputCapture.startCapture( (ConsoleOutputReceiver) listener );
|
|
-
|
|
- org.junit.runner.notification.RunListener jUnit4RunListener = new OsgiEnabledJUnitCoreRunListener( listener, testSetMap );
|
|
- customRunListeners.add( 0, jUnit4RunListener );
|
|
-
|
|
- JUnitCoreWrapper.execute( testsToRun, jUnitCoreParameters, customRunListeners );
|
|
- return reporterFactory.close();
|
|
- }
|
|
-
|
|
- private TestsToRun scanClassPath()
|
|
- {
|
|
- return directoryScanner.locateTestClasses( testClassLoader, scannerFilter );
|
|
- }
|
|
-}
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreRunListener.java b/tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreRunListener.java
|
|
deleted file mode 100644
|
|
index fb6bede..0000000
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.junit47/src/org/apache/maven/surefire/junitcore/OsgiEnabledJUnitCoreRunListener.java
|
|
+++ /dev/null
|
|
@@ -1,100 +0,0 @@
|
|
-package org.apache.maven.surefire.junitcore;
|
|
-/*
|
|
- * 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.
|
|
- */
|
|
-
|
|
-import java.util.ArrayList;
|
|
-import java.util.Map;
|
|
-import org.apache.maven.surefire.common.junit4.JUnit4RunListener;
|
|
-import org.apache.maven.surefire.report.RunListener;
|
|
-
|
|
-import org.junit.runner.Description;
|
|
-import org.junit.runner.Result;
|
|
-
|
|
-/**
|
|
- * This class is a workaround or surefire bug
|
|
- * {@link http://jira.codehaus.org/browse/SUREFIRE-876 }
|
|
- *
|
|
- * TODO remove when surefire release with proposed bugfix is available
|
|
- */
|
|
-public class OsgiEnabledJUnitCoreRunListener
|
|
- extends JUnit4RunListener
|
|
-{
|
|
- private final Map<String, TestSet> classMethodCounts;
|
|
-
|
|
- /**
|
|
- * @param reporter the report manager to log testing events to
|
|
- * @param classMethodCounts A map of methods
|
|
- */
|
|
- public OsgiEnabledJUnitCoreRunListener( RunListener reporter, Map<String, TestSet> classMethodCounts )
|
|
- {
|
|
- super( reporter );
|
|
- this.classMethodCounts = classMethodCounts;
|
|
- }
|
|
-
|
|
- /**
|
|
- * Called right before any tests from a specific class are run.
|
|
- *
|
|
- * @see org.junit.runner.notification.RunListener#testRunStarted(org.junit.runner.Description)
|
|
- */
|
|
- public void testRunStarted( Description description )
|
|
- throws Exception
|
|
- {
|
|
- fillTestCountMap( description );
|
|
- reporter.testSetStarting( null ); // Not entirely meaningful as we can see
|
|
- }
|
|
-
|
|
- @Override
|
|
- public void testRunFinished( Result result )
|
|
- throws Exception
|
|
- {
|
|
- reporter.testSetCompleted( null );
|
|
- }
|
|
-
|
|
- private void fillTestCountMap( Description description )
|
|
- {
|
|
- final ArrayList<Description> children = description.getChildren();
|
|
-
|
|
- TestSet testSet = new TestSet( description );
|
|
- String itemTestClassName = null;
|
|
- for ( Description item : children )
|
|
- {
|
|
- if ( item.isTest() && item.getMethodName() != null )
|
|
- {
|
|
- testSet.incrementTestMethodCount();
|
|
- if ( itemTestClassName == null )
|
|
- {
|
|
- itemTestClassName = item.getClassName();
|
|
- }
|
|
- }
|
|
- else if ( item.getChildren().size() > 0 )
|
|
- {
|
|
- fillTestCountMap( item );
|
|
- }
|
|
- else
|
|
- {
|
|
- classMethodCounts.put( item.getClassName(), testSet );
|
|
- }
|
|
- }
|
|
- if ( itemTestClassName != null )
|
|
- {
|
|
- classMethodCounts.put( itemTestClassName, testSet );
|
|
- }
|
|
- }
|
|
-
|
|
-}
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/META-INF/MANIFEST.MF b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/META-INF/MANIFEST.MF
|
|
index e75a51f..1c12e19 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/META-INF/MANIFEST.MF
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/META-INF/MANIFEST.MF
|
|
@@ -4,8 +4,10 @@ Require-Bundle: org.eclipse.osgi;bundle-version="3.2.2",
|
|
org.eclipse.core.runtime;bundle-version="3.2.0"
|
|
Eclipse-AutoStart: true
|
|
Bundle-ClassPath: .,
|
|
- jars/surefire-booter-2.10.jar,
|
|
- jars/surefire-api-2.10.jar
|
|
+ jars/surefire-booter-2.15.jar,
|
|
+ jars/surefire-api-2.15.jar,
|
|
+ jars/maven-surefire-common-2.15.jar,
|
|
+ jars/plexus-utils-3.0.jar
|
|
Bundle-Version: 0.18.1
|
|
Bundle-Name: Tycho Surefire OSGi Booter Eclipse Application (Incubation)
|
|
Bundle-ManifestVersion: 2
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/pom.xml b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/pom.xml
|
|
index 20d5b39..651282f 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/pom.xml
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/pom.xml
|
|
@@ -52,6 +52,16 @@
|
|
<artifactId>surefire-booter</artifactId>
|
|
<version>${surefire-version}</version>
|
|
</artifactItem>
|
|
+ <artifactItem>
|
|
+ <groupId>org.apache.maven.surefire</groupId>
|
|
+ <artifactId>maven-surefire-common</artifactId>
|
|
+ <version>${surefire-version}</version>
|
|
+ </artifactItem>
|
|
+ <artifactItem>
|
|
+ <groupId>org.codehaus.plexus</groupId>
|
|
+ <artifactId>plexus-utils</artifactId>
|
|
+ <version>3.0</version>
|
|
+ </artifactItem>
|
|
</artifactItems>
|
|
</configuration>
|
|
</execution>
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/OsgiSurefireBooter.java b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/OsgiSurefireBooter.java
|
|
index 791221b..09bf329 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/OsgiSurefireBooter.java
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/OsgiSurefireBooter.java
|
|
@@ -18,20 +18,25 @@ import java.io.IOException;
|
|
import java.net.URL;
|
|
import java.util.ArrayList;
|
|
import java.util.Arrays;
|
|
+import java.util.Collections;
|
|
import java.util.Enumeration;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Properties;
|
|
import java.util.Set;
|
|
|
|
+import org.apache.maven.plugin.surefire.StartupReportConfiguration;
|
|
+import org.apache.maven.plugin.surefire.report.DefaultReporterFactory;
|
|
import org.apache.maven.surefire.booter.ClassLoaderConfiguration;
|
|
+import org.apache.maven.surefire.booter.ForkedBooter;
|
|
import org.apache.maven.surefire.booter.ProviderConfiguration;
|
|
+import org.apache.maven.surefire.booter.ProviderFactory;
|
|
import org.apache.maven.surefire.booter.StartupConfiguration;
|
|
-import org.apache.maven.surefire.booter.StartupReportConfiguration;
|
|
-import org.apache.maven.surefire.booter.SurefireStarter;
|
|
import org.apache.maven.surefire.report.ReporterConfiguration;
|
|
+import org.apache.maven.surefire.report.ReporterFactory;
|
|
import org.apache.maven.surefire.suite.RunResult;
|
|
import org.apache.maven.surefire.testset.DirectoryScannerParameters;
|
|
+import org.apache.maven.surefire.testset.RunOrderParameters;
|
|
import org.apache.maven.surefire.testset.TestRequest;
|
|
import org.apache.maven.surefire.util.RunOrder;
|
|
import org.eclipse.core.runtime.CoreException;
|
|
@@ -55,7 +60,7 @@ public class OsgiSurefireBooter {
|
|
List<String> includes = getIncludesExcludes(testProps.getProperty("includes"));
|
|
List<String> excludes = getIncludesExcludes(testProps.getProperty("excludes"));
|
|
|
|
- String forkMode = "never";
|
|
+ boolean forkRequested = true;
|
|
boolean inForkedVM = true;
|
|
boolean trimStacktrace = true;
|
|
boolean useSystemClassloader = false;
|
|
@@ -64,26 +69,31 @@ public class OsgiSurefireBooter {
|
|
boolean printSummary = true;
|
|
boolean disableXmlReport = false;
|
|
ClassLoader testClassLoader = getBundleClassLoader(plugin);
|
|
- ClassLoader surefireClassLoader = SurefireStarter.class.getClassLoader();
|
|
+ ClassLoader surefireClassLoader = ForkedBooter.class.getClassLoader();
|
|
|
|
TychoClasspathConfiguration classPathConfig = new TychoClasspathConfiguration(testClassLoader,
|
|
surefireClassLoader);
|
|
StartupConfiguration startupConfiguration = new StartupConfiguration(provider, classPathConfig,
|
|
- new ClassLoaderConfiguration(useSystemClassloader, useManifestOnlyJar), forkMode, inForkedVM);
|
|
+ new ClassLoaderConfiguration(useSystemClassloader, useManifestOnlyJar), forkRequested, inForkedVM);
|
|
DirectoryScannerParameters dirScannerParams = new DirectoryScannerParameters(testClassesDir, includes,
|
|
- excludes, failIfNoTests, RunOrder.FILESYSTEM);
|
|
+ excludes, Collections.emptyList(), failIfNoTests, RunOrder.FILESYSTEM.toString());
|
|
ReporterConfiguration reporterConfig = new ReporterConfiguration(reportsDir, trimStacktrace);
|
|
TestRequest testRequest = new TestRequest(null, testClassesDir, null);
|
|
- ProviderConfiguration providerConfiguration = new ProviderConfiguration(dirScannerParams, failIfNoTests,
|
|
- reporterConfig, null, testRequest, extractProviderProperties(testProps), null);
|
|
+ ProviderConfiguration providerConfiguration = new ProviderConfiguration(dirScannerParams,
|
|
+ new RunOrderParameters((String) null, null), failIfNoTests, reporterConfig, null, testRequest,
|
|
+ extractProviderProperties(testProps), null, false);
|
|
StartupReportConfiguration startupReportConfig = new StartupReportConfiguration(useFile, printSummary,
|
|
StartupReportConfiguration.PLAIN_REPORT_FORMAT, redirectTestOutputToFile, disableXmlReport, reportsDir,
|
|
- trimStacktrace);
|
|
- SurefireStarter surefireStarter = new SurefireStarter(startupConfiguration, providerConfiguration,
|
|
- startupReportConfig);
|
|
+ trimStacktrace, null, "TESTHASH", false);
|
|
|
|
- RunResult result = surefireStarter.runSuitesInProcess();
|
|
- return result.getForkedProcessCode();
|
|
+ RunResult result = ProviderFactory.invokeProvider(null, classPathConfig.createMergedClassLoader(),
|
|
+ createReporterFactory(startupReportConfig), providerConfiguration, false, startupConfiguration, true);
|
|
+
|
|
+ return result.getFailsafeCode() == null ? 0 : result.getFailsafeCode();
|
|
+ }
|
|
+
|
|
+ private static ReporterFactory createReporterFactory(StartupReportConfiguration startupReportConfig) {
|
|
+ return new DefaultReporterFactory(startupReportConfig);
|
|
}
|
|
|
|
/*
|
|
diff --git a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/TychoClasspathConfiguration.java b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/TychoClasspathConfiguration.java
|
|
index c94d3ea..fc606b0 100644
|
|
--- a/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/TychoClasspathConfiguration.java
|
|
+++ b/tycho-surefire/org.eclipse.tycho.surefire.osgibooter/src/main/java/org/eclipse/tycho/surefire/osgibooter/TychoClasspathConfiguration.java
|
|
@@ -25,18 +25,35 @@ public class TychoClasspathConfiguration extends ClasspathConfiguration {
|
|
}
|
|
|
|
@Override
|
|
- public ClassLoader createSurefireClassLoader(ClassLoader parent) throws SurefireExecutionException {
|
|
- return surefireClassLoader;
|
|
+ public ClassLoader createMergedClassLoader() throws SurefireExecutionException {
|
|
+ return new MergedClassLoader(null, new ClassLoader[] { testClassLoader, surefireClassLoader });
|
|
}
|
|
|
|
- @Override
|
|
- public ClassLoader createTestClassLoader() throws SurefireExecutionException {
|
|
- return testClassLoader;
|
|
- }
|
|
+ private class MergedClassLoader extends ClassLoader {
|
|
+
|
|
+ private ClassLoader[] delegateClassLoaders;
|
|
+
|
|
+ public MergedClassLoader(ClassLoader parent, ClassLoader[] delegateClassLoaders) {
|
|
+ super(parent);
|
|
+ this.delegateClassLoaders = delegateClassLoaders;
|
|
+ }
|
|
+
|
|
+ @Override
|
|
+ public Class<?> loadClass(String name) throws ClassNotFoundException {
|
|
+ return findClass(name);
|
|
+ }
|
|
+
|
|
+ @Override
|
|
+ protected Class<?> findClass(String name) throws ClassNotFoundException {
|
|
+ for (ClassLoader delegate : delegateClassLoaders) {
|
|
+ try {
|
|
+ return delegate.loadClass(name);
|
|
+ } catch (ClassNotFoundException e) {
|
|
+ }
|
|
+ }
|
|
+ throw new ClassNotFoundException();
|
|
+ }
|
|
|
|
- @Override
|
|
- public ClassLoader createTestClassLoader(boolean childDelegation) throws SurefireExecutionException {
|
|
- return testClassLoader;
|
|
}
|
|
|
|
}
|
|
diff --git a/tycho-surefire/pom.xml b/tycho-surefire/pom.xml
|
|
index 7dd7c41..1945406 100644
|
|
--- a/tycho-surefire/pom.xml
|
|
+++ b/tycho-surefire/pom.xml
|
|
@@ -26,7 +26,7 @@
|
|
<name>Tycho Surefire Parent (Incubation)</name>
|
|
|
|
<properties>
|
|
- <surefire-version>2.10</surefire-version>
|
|
+ <surefire-version>2.15</surefire-version>
|
|
</properties>
|
|
|
|
<modules>
|
|
diff --git a/tycho-surefire/tycho-surefire-plugin/pom.xml b/tycho-surefire/tycho-surefire-plugin/pom.xml
|
|
index 5d496d3..2d5d245 100644
|
|
--- a/tycho-surefire/tycho-surefire-plugin/pom.xml
|
|
+++ b/tycho-surefire/tycho-surefire-plugin/pom.xml
|
|
@@ -96,5 +96,10 @@
|
|
<artifactId>surefire-api</artifactId>
|
|
<version>${surefire-version}</version>
|
|
</dependency>
|
|
+ <dependency>
|
|
+ <groupId>org.apache.maven.surefire</groupId>
|
|
+ <artifactId>maven-surefire-common</artifactId>
|
|
+ <version>${surefire-version}</version>
|
|
+ </dependency>
|
|
</dependencies>
|
|
</project>
|
|
diff --git a/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/TestMojo.java b/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/TestMojo.java
|
|
index 5ac5427..340f562 100644
|
|
--- a/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/TestMojo.java
|
|
+++ b/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/TestMojo.java
|
|
@@ -18,6 +18,7 @@ import java.io.IOException;
|
|
import java.net.MalformedURLException;
|
|
import java.util.ArrayList;
|
|
import java.util.Arrays;
|
|
+import java.util.Collections;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Properties;
|
|
@@ -33,9 +34,10 @@ import org.apache.maven.model.Dependency;
|
|
import org.apache.maven.plugin.AbstractMojo;
|
|
import org.apache.maven.plugin.MojoExecutionException;
|
|
import org.apache.maven.plugin.MojoFailureException;
|
|
+import org.apache.maven.plugin.surefire.util.DirectoryScanner;
|
|
import org.apache.maven.project.MavenProject;
|
|
import org.apache.maven.repository.RepositorySystem;
|
|
-import org.apache.maven.surefire.suite.RunResult;
|
|
+import org.apache.maven.surefire.util.DefaultScanResult;
|
|
import org.apache.maven.toolchain.Toolchain;
|
|
import org.apache.maven.toolchain.ToolchainManager;
|
|
import org.codehaus.plexus.util.FileUtils;
|
|
@@ -737,6 +739,27 @@ public class TestMojo extends AbstractMojo {
|
|
providerProperties.put("perCoreThreadCount", String.valueOf(perCoreThreadCount));
|
|
providerProperties.put("useUnlimitedThreads", String.valueOf(useUnlimitedThreads));
|
|
}
|
|
+
|
|
+ List<String> defaultIncludes = Arrays.asList("**/Test*.class", "**/*Test.class", "**/*TestCase.class");
|
|
+ List<String> defaultExcludes = Arrays.asList("**/Abstract*Test.class", "**/Abstract*TestCase.class", "**/*$*");
|
|
+ List<String> includeList;
|
|
+ if (test != null) {
|
|
+ String test = this.test;
|
|
+ test = test.replace('.', '/');
|
|
+ test = test.endsWith(".class") ? test : test + ".class";
|
|
+ test = test.startsWith("**/") ? test : "**/" + test;
|
|
+ includeList = Collections.singletonList(test);
|
|
+ } else if (testClass != null) {
|
|
+ includeList = Collections.singletonList(testClass.replace('.', '/') + ".class");
|
|
+ } else if (includes != null) {
|
|
+ includeList = includes;
|
|
+ } else {
|
|
+ includeList = defaultIncludes;
|
|
+ }
|
|
+ DirectoryScanner scanner = new DirectoryScanner(testClassesDirectory, includeList, excludes != null ? excludes
|
|
+ : defaultExcludes, Collections.<String> emptyList());
|
|
+ DefaultScanResult scanResult = scanner.scan();
|
|
+ scanResult.writeTo(providerProperties);
|
|
for (Map.Entry entry : providerProperties.entrySet()) {
|
|
surefireProps.put("__provider." + entry.getKey(), entry.getValue());
|
|
}
|
|
@@ -783,7 +806,7 @@ public class TestMojo extends AbstractMojo {
|
|
case 0:
|
|
getLog().info("All tests passed!");
|
|
break;
|
|
- case RunResult.NO_TESTS:
|
|
+ case 254/* RunResult.NO_TESTS */:
|
|
String message = "No tests found.";
|
|
if (failIfNoTests) {
|
|
throw new MojoFailureException(message);
|
|
@@ -791,7 +814,7 @@ public class TestMojo extends AbstractMojo {
|
|
getLog().warn(message);
|
|
}
|
|
break;
|
|
- case RunResult.FAILURE:
|
|
+ case 255/* RunResult.FAILURE */:
|
|
String errorMessage = "There are test failures.\n\nPlease refer to " + reportsDirectory
|
|
+ " for the individual test results.";
|
|
if (testFailureIgnore) {
|
|
diff --git a/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/provider/impl/JUnit47Provider.java b/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/provider/impl/JUnit47Provider.java
|
|
index 8358883..625b6fc 100644
|
|
--- a/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/provider/impl/JUnit47Provider.java
|
|
+++ b/tycho-surefire/tycho-surefire-plugin/src/main/java/org/eclipse/tycho/surefire/provider/impl/JUnit47Provider.java
|
|
@@ -44,7 +44,7 @@ public class JUnit47Provider extends AbstractJUnitProvider {
|
|
}
|
|
|
|
public String getSurefireProviderClassName() {
|
|
- return "org.apache.maven.surefire.junitcore.OsgiEnabledJUnitCoreProvider";
|
|
+ return "org.apache.maven.surefire.junitcore.JUnitCoreProvider";
|
|
}
|
|
|
|
public Version getVersion() {
|
|
--
|
|
1.8.1.4
|
|
|