aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/org/junit/internal/builders/AnnotatedBuilder.java
blob: 8ed9ca79860649eee35e0f827f0332d18dd5132e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/**
 * 
 */
package org.junit.internal.builders;

import org.junit.runner.RunWith;
import org.junit.runner.Runner;
import org.junit.runners.model.InitializationError;
import org.junit.runners.model.RunnerBuilder;

public class AnnotatedBuilder extends RunnerBuilder {
	private static final String CONSTRUCTOR_ERROR_FORMAT= "Custom runner class %s should have a public constructor with signature %s(Class testClass)";

	private RunnerBuilder fSuiteBuilder;

	public AnnotatedBuilder(RunnerBuilder suiteBuilder) {
		fSuiteBuilder= suiteBuilder;
	}

	@Override
	public Runner runnerForClass(Class<?> testClass) throws Exception {
		RunWith annotation= testClass.getAnnotation(RunWith.class);
		if (annotation != null)
			return buildRunner(annotation.value(), testClass);
		return null;
	}

	public Runner buildRunner(Class<? extends Runner> runnerClass,
			Class<?> testClass) throws Exception {
		try {
			return runnerClass.getConstructor(Class.class).newInstance(
					new Object[] { testClass });
		} catch (NoSuchMethodException e) {
			try {
				return runnerClass.getConstructor(Class.class,
						RunnerBuilder.class).newInstance(
						new Object[] { testClass, fSuiteBuilder });
			} catch (NoSuchMethodException e2) {
				String simpleName= runnerClass.getSimpleName();
				throw new InitializationError(String.format(
						CONSTRUCTOR_ERROR_FORMAT, simpleName, simpleName));
			}
		}
	}
}