blob: c805037a2c39256858811fde450b964ad7d4e2bd [file] [log] [blame]
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.HashMap;
import java.util.concurrent.ExecutionException;
import org.apache.maven.plugin.surefire.report.DefaultReporterFactory;
import org.apache.maven.surefire.report.ConsoleOutputCapture;
import org.apache.maven.surefire.report.ConsoleOutputReceiver;
import org.apache.maven.surefire.report.DefaultConsoleReporter;
import org.apache.maven.surefire.report.ReporterFactory;
import org.apache.maven.surefire.report.RunListener;
import org.apache.maven.surefire.testset.TestSetFailedException;
import org.junit.runner.Computer;
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
/**
* @author Kristian Rosenvold
*/
public class JUnitCoreTester
{
private final Computer computer;
public JUnitCoreTester()
{
this( new Computer() );
}
public JUnitCoreTester( Computer computer )
{
this.computer = computer;
}
public Result run( boolean parallelClasses, Class<?>... classes )
throws TestSetFailedException, ExecutionException
{
ReporterFactory reporterManagerFactory = DefaultReporterFactory.defaultNoXml();
final HashMap<String, TestSet> classMethodCounts = new HashMap<String, TestSet>();
RunListener reporter =
ConcurrentRunListener.createInstance( classMethodCounts, reporterManagerFactory, parallelClasses, false,
new DefaultConsoleReporter( System.out ) );
ConsoleOutputCapture.startCapture( (ConsoleOutputReceiver) reporter );
JUnitCoreRunListener runListener = new JUnitCoreRunListener( reporter, classMethodCounts );
JUnitCore junitCore = new JUnitCore();
junitCore.addListener( runListener );
final Result run = junitCore.run( computer, classes );
junitCore.removeListener( runListener );
reporterManagerFactory.close();
if ( computer instanceof ConfigurableParallelComputer )
{
( (ConfigurableParallelComputer) computer ).close();
}
return run;
}
}