/*
* Copyright 2013 the original author or authors.
*
* Licensed 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.gradle.api.tasks.testing;
import org.gradle.api.Incubating;
import org.gradle.api.tasks.Input;
import java.util.Set;
/**
* Allows filtering tests for execution. Some examples:
*
* <pre autoTested=''>
* apply plugin: 'java'
*
* test {
* filter {
* //specific test method
* includeTestsMatching "org.gradle.SomeTest.someSpecificFeature"
*
* //specific test method, use wildcard for packages
* includeTestsMatching "*SomeTest.someSpecificFeature"
*
* //specific test class
* includeTestsMatching "org.gradle.SomeTest"
*
* //specific test class, wildcard for packages
* includeTestsMatching "*.SomeTest"
*
* //all classes in package, recursively
* includeTestsMatching "com.gradle.tooling.*"
*
* //all integration tests, by naming convention
* includeTestsMatching "*IntegTest"
*
* //only ui tests from integration tests, by some naming convention
* includeTestsMatching "*IntegTest*ui"
*
* //specific test class and test method
* includeTest "org.gradle.SomeTest", "someTestMethod"
* }
* }
*
* </pre>
*
* @since 1.10
*/
@Incubating
public interface TestFilter {
/**
* Appends a test name pattern to the filter. Wildcard '*' is supported, either test method name or class name is supported. Examples of test names: "com.foo.FooTest.someMethod",
* "com.foo.FooTest", "*FooTest*", "com.foo*". See examples in the docs for {@link TestFilter}.
*
* @param testNamePattern test name pattern to include, can be class or method name, can contain wildcard '*'
* @return this filter object
*/
TestFilter includeTestsMatching(String testNamePattern);
/**
* Returns the included test name patterns. They can be class or method names and may contain wildcard '*'. Test name patterns can be appended via {@link #includeTestsMatching(String)} or set via
* {@link #setIncludePatterns(String...)}.
*
* @return included test name patterns
*/
@Input
Set<String> getIncludePatterns();
/**
* Sets the test name patterns to be included in the filter. Wildcard '*' is supported. Replaces any existing test name patterns.
*
* @param testNamePatterns class or method name patterns to set, may contain wildcard '*'
* @return this filter object
*/
TestFilter setIncludePatterns(String... testNamePatterns);
/**
* Add a test method specified by test class name and method name.
*
* @param className the class name of the test to execute
* @param methodName the method name of the test to execute. Can be null.
* @return this filter object
*/
TestFilter includeTest(String className, String methodName);
/**
* Let the test task fail if a filter configuration was provided but no test matched the given configuration.
* @param failOnNoMatchingTests whether a test task should fail if no test is matching the filter configuration.
* */
void setFailOnNoMatchingTests(boolean failOnNoMatchingTests);
/**
* Returns whether the task should fail if no matching tests where found.
* The default is true.
*/
@Input
boolean isFailOnNoMatchingTests();
}