All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.gradle.api.tasks.testing.testng.TestNGOptions Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2012 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.testng;

import groovy.lang.MissingMethodException;
import groovy.lang.MissingPropertyException;
import groovy.xml.MarkupBuilder;
import org.gradle.api.Incubating;
import org.gradle.api.tasks.Input;
import org.gradle.api.tasks.InputFiles;
import org.gradle.api.tasks.Optional;
import org.gradle.api.tasks.OutputDirectory;
import org.gradle.api.tasks.testing.TestFrameworkOptions;
import org.gradle.internal.ErroringAction;
import org.gradle.internal.IoActions;

import javax.annotation.Nullable;
import java.io.BufferedWriter;
import java.io.File;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;

/**
 * The TestNG specific test options.
 */
public class TestNGOptions extends TestFrameworkOptions {
    public static final String DEFAULT_CONFIG_FAILURE_POLICY = "skip";
    private static final String DEFAULT_PARALLEL_MODE = null;
    private static final int DEFAULT_THREAD_COUNT = -1;

    private File outputDirectory;

    private Set includeGroups = new LinkedHashSet();

    private Set excludeGroups = new LinkedHashSet();

    private String configFailurePolicy = DEFAULT_CONFIG_FAILURE_POLICY;

    private Set listeners = new LinkedHashSet();

    private String parallel = DEFAULT_PARALLEL_MODE;

    private int threadCount = DEFAULT_THREAD_COUNT;

    private boolean useDefaultListeners;

    private String suiteName = "Gradle suite";

    private String testName = "Gradle test";

    private List suiteXmlFiles = new ArrayList();

    private boolean preserveOrder;

    private boolean groupByInstances;

    private transient StringWriter suiteXmlWriter;

    private transient MarkupBuilder suiteXmlBuilder;

    private final File projectDir;

    public TestNGOptions(File projectDir) {
        this.projectDir = projectDir;
    }

    public MarkupBuilder suiteXmlBuilder() {
        suiteXmlWriter = new StringWriter();
        suiteXmlBuilder = new MarkupBuilder(suiteXmlWriter);
        return suiteXmlBuilder;
    }

    /**
     * Add suite files by Strings. Each suiteFile String should be a path relative to the project root.
     */
    public void suites(String... suiteFiles) {
        for (String suiteFile : suiteFiles) {
            suiteXmlFiles.add(new File(TestNGOptions.this.getProjectDir(), suiteFile));
        }
    }

    protected File getProjectDir() {
        return projectDir;
    }

    /**
     * Add suite files by File objects.
     */
    public void suites(File... suiteFiles) {
        suiteXmlFiles.addAll(Arrays.asList(suiteFiles));
    }

    public List getSuites(File testSuitesDir) {
        List suites = new ArrayList();

        suites.addAll(suiteXmlFiles);

        if (suiteXmlBuilder != null) {
            File buildSuiteXml = new File(testSuitesDir.getAbsolutePath(), "build-suite.xml");

            if (buildSuiteXml.exists()) {
                if (!buildSuiteXml.delete()) {
                    throw new RuntimeException("failed to remove already existing build-suite.xml file");
                }
            }

            IoActions.writeTextFile(buildSuiteXml, new ErroringAction() {
                @Override
                protected void doExecute(BufferedWriter writer) throws Exception {
                    writer.write("");
                    writer.newLine();
                    writer.write(getSuiteXml());
                }
            });

            suites.add(buildSuiteXml);
        }

        return suites;
    }

    public TestNGOptions includeGroups(String... includeGroups) {
        this.includeGroups.addAll(Arrays.asList(includeGroups));
        return this;
    }

    public TestNGOptions excludeGroups(String... excludeGroups) {
        this.excludeGroups.addAll(Arrays.asList(excludeGroups));
        return this;
    }

    public TestNGOptions useDefaultListeners() {
        useDefaultListeners = true;
        return this;
    }

    public TestNGOptions useDefaultListeners(boolean useDefaultListeners) {
        this.useDefaultListeners = useDefaultListeners;
        return this;
    }

    public Object propertyMissing(final String name) {
        if (suiteXmlBuilder != null) {
            return suiteXmlBuilder.getMetaClass().getProperty(suiteXmlBuilder, name);
        }

        throw new MissingPropertyException(name, getClass());
    }

    public Object methodMissing(String name, Object args) {
        if (suiteXmlBuilder != null) {
            return suiteXmlBuilder.getMetaClass().invokeMethod(suiteXmlBuilder, name, args);
        }

        throw new MissingMethodException(name, getClass(), (Object[])args);
    }

    /**
     * The location to write TestNG's output. 

Defaults to the owning test task's location for writing the HTML report. * * @since 1.11 */ @Incubating @OutputDirectory public File getOutputDirectory() { return outputDirectory; } @Incubating public void setOutputDirectory(File outputDirectory) { this.outputDirectory = outputDirectory; } /** * The set of groups to run. */ @Input public Set getIncludeGroups() { return includeGroups; } public void setIncludeGroups(Set includeGroups) { this.includeGroups = includeGroups; } /** * The set of groups to exclude. */ @Input public Set getExcludeGroups() { return excludeGroups; } public void setExcludeGroups(Set excludeGroups) { this.excludeGroups = excludeGroups; } /** * Option for what to do for other tests that use a configuration step when that step fails. Can be "skip" or "continue", defaults to "skip". */ public String getConfigFailurePolicy() { return configFailurePolicy; } public void setConfigFailurePolicy(String configFailurePolicy) { this.configFailurePolicy = configFailurePolicy; } /** * Fully qualified classes that are TestNG listeners (instances of org.testng.ITestListener or org.testng.IReporter). By default, the listeners set is empty. * * Configuring extra listener: *

     * apply plugin: 'java'
     *
     * test {
     *     useTestNG() {
     *         // creates emailable HTML file
     *         // this reporter typically ships with TestNG library
     *         listeners << 'org.testng.reporters.EmailableReporter'
     *     }
     * }
     * 
*/ public Set getListeners() { return listeners; } public void setListeners(Set listeners) { this.listeners = listeners; } /** * The parallel mode to use for running the tests - one of the following modes: methods, tests, classes or instances. * * Not required. * * If not present, parallel mode will not be selected */ @Nullable public String getParallel() { return parallel; } public void setParallel(String parallel) { this.parallel = parallel; } /** * The number of threads to use for this run. Ignored unless the parallel mode is also specified */ public int getThreadCount() { return threadCount; } public void setThreadCount(int threadCount) { this.threadCount = threadCount; } public boolean getUseDefaultListeners() { return useDefaultListeners; } /** * Whether the default listeners and reporters should be used. Since Gradle 1.4 it defaults to 'false' so that Gradle can own the reports generation and provide various improvements. This option * might be useful for advanced TestNG users who prefer the reports generated by the TestNG library. If you cannot live without some specific TestNG reporter please use {@link #listeners} * property. If you really want to use all default TestNG reporters (e.g. generate the old reports): * *
     * apply plugin: 'java'
     *
     * test {
     *     useTestNG() {
     *         // report generation delegated to TestNG library:
     *         useDefaultListeners = true
     *     }
     *
     *     // turn off Gradle's HTML report to avoid replacing the
     *     // reports generated by TestNG library:
     *     reports.html.enabled = false
     * }
     * 
* * Please refer to the documentation of your version of TestNG what are the default listeners. At the moment of writing this documentation, the default listeners are a set of reporters that * generate: TestNG variant of HTML results, TestNG variant of XML results in JUnit format, emailable HTML test report, XML results in TestNG format. */ public boolean isUseDefaultListeners() { return useDefaultListeners; } public void setUseDefaultListeners(boolean useDefaultListeners) { this.useDefaultListeners = useDefaultListeners; } /** * Sets the default name of the test suite, if one is not specified in a suite XML file or in the source code. */ public String getSuiteName() { return suiteName; } public void setSuiteName(String suiteName) { this.suiteName = suiteName; } /** * Sets the default name of the test, if one is not specified in a suite XML file or in the source code. */ public String getTestName() { return testName; } public void setTestName(String testName) { this.testName = testName; } /** * The suiteXmlFiles to use for running TestNG. * * Note: The suiteXmlFiles can be used in conjunction with the suiteXmlBuilder. */ @InputFiles public List getSuiteXmlFiles() { return suiteXmlFiles; } public void setSuiteXmlFiles(List suiteXmlFiles) { this.suiteXmlFiles = suiteXmlFiles; } public boolean getPreserveOrder() { return preserveOrder; } /** * Indicates whether the tests should be run in deterministic order. Preserving the order guarantees that the complete test * (including @BeforeXXX and @AfterXXX) is run in a test thread before the next test is run. * * Not required. * * If not present, the order will not be preserved. */ @Incubating public boolean isPreserveOrder() { return preserveOrder; } @Incubating public void setPreserveOrder(boolean preserveOrder) { this.preserveOrder = preserveOrder; } @Incubating public boolean getGroupByInstances() { return groupByInstances; } /** * Indicates whether the tests should be grouped by instances. Grouping by instances will result in resolving test method dependencies for each instance instead of running the dependees of all * instances before running the dependants. * * Not required. * * If not present, the tests will not be grouped by instances. */ @Incubating public boolean isGroupByInstances() { return groupByInstances; } @Incubating public void setGroupByInstances(boolean groupByInstances) { this.groupByInstances = groupByInstances; } /** * Returns the XML generated using {@link #suiteXmlBuilder()}, if any. * *

This property is read-only and exists merely for up-to-date checking. */ @Input @Optional private String getSuiteXml() { return suiteXmlWriter == null ? null : suiteXmlWriter.toString(); } public StringWriter getSuiteXmlWriter() { return suiteXmlWriter; } public void setSuiteXmlWriter(StringWriter suiteXmlWriter) { this.suiteXmlWriter = suiteXmlWriter; } public MarkupBuilder getSuiteXmlBuilder() { return suiteXmlBuilder; } public void setSuiteXmlBuilder(MarkupBuilder suiteXmlBuilder) { this.suiteXmlBuilder = suiteXmlBuilder; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy