| 1 | package fr.sii.ogham.testing.extension.spock; | |
| 2 | ||
| 3 | import org.spockframework.runtime.extension.AbstractAnnotationDrivenExtension; | |
| 4 | import org.spockframework.runtime.model.FeatureInfo; | |
| 5 | import org.spockframework.runtime.model.MethodInfo; | |
| 6 | import org.spockframework.runtime.model.SpecInfo; | |
| 7 | ||
| 8 | import fr.sii.ogham.testing.extension.common.LogTestInformation; | |
| 9 | ||
| 10 | /** | |
| 11 |  * Register {@link LoggingTestInterceptor} for tests annotated with | |
| 12 |  * {@link LogTestInformation} annotation. | |
| 13 |  *  | |
| 14 |  * @author Aurélien Baudet | |
| 15 |  * | |
| 16 |  */ | |
| 17 | public class LoggingTestExtension extends AbstractAnnotationDrivenExtension<LogTestInformation> { | |
| 18 | ||
| 19 | 	@Override | |
| 20 | 	public void visitSpecAnnotation(LogTestInformation annotation, SpecInfo spec) { | |
| 21 | 		for (FeatureInfo feature : spec.getFeatures()) { | |
| 22 | 2
1. visitSpecAnnotation : negated conditional → NO_COVERAGE 2. visitSpecAnnotation : negated conditional → SURVIVED | 			if (!feature.getFeatureMethod().getReflection().isAnnotationPresent(LogTestInformation.class)) { | 
| 23 | 2
1. visitSpecAnnotation : removed call to fr/sii/ogham/testing/extension/spock/LoggingTestExtension::intercept → SURVIVED 2. visitSpecAnnotation : removed call to fr/sii/ogham/testing/extension/spock/LoggingTestExtension::intercept → NO_COVERAGE | 				intercept(annotation, feature.getFeatureMethod()); | 
| 24 | 			} | |
| 25 | 		} | |
| 26 | 	} | |
| 27 | ||
| 28 | 	@Override | |
| 29 | 	public void visitFixtureAnnotation(LogTestInformation annotation, MethodInfo fixtureMethod) { | |
| 30 | 1
1. visitFixtureAnnotation : removed call to fr/sii/ogham/testing/extension/spock/LoggingTestExtension::intercept → NO_COVERAGE | 		intercept(annotation, fixtureMethod); | 
| 31 | 	} | |
| 32 | ||
| 33 | ||
| 34 | 	private static void intercept(LogTestInformation annotation, MethodInfo methodInfo) { | |
| 35 | 		try { | |
| 36 | 2
1. intercept : removed call to org/spockframework/runtime/model/MethodInfo::addInterceptor → SURVIVED 2. intercept : removed call to org/spockframework/runtime/model/MethodInfo::addInterceptor → NO_COVERAGE | 			methodInfo.addInterceptor(new LoggingTestInterceptor(annotation)); | 
| 37 | 		} catch (InstantiationException | IllegalAccessException e) { | |
| 38 | 			throw new IllegalArgumentException("Failed to create logger instance", e); | |
| 39 | 		} | |
| 40 | 	} | |
| 41 | ||
| 42 | } | |
| Mutations | ||
| 22 | 1.1 2.2 | |
| 23 | 1.1 2.2 | |
| 30 | 1.1 | |
| 36 | 1.1 2.2 |