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

io.qameta.allure.maven.AllureBulkMojo Maven / Gradle / Ivy

There is a newer version: 2.15.2
Show newest version
package io.qameta.allure.maven;

import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;

import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.List;

/**
 * @author Dmitry Baev [email protected]
 *         Date: 04.08.15
 */
@Mojo(name = "bulk", defaultPhase = LifecyclePhase.SITE, inheritByDefault = false)
public class AllureBulkMojo extends AllureGenerateMojo {

    /**
     * The comma-separated list of additional input directories. As long as
     * unix path can contains commas it is bad way to specify few input
     * directories. The main usage of this parameter is some scripts
     * to generate aggregated report. This parameter will be used only
     * in "bulk" mojo.
     */
    @Parameter(property = "allure.results.inputDirectories")
    private String inputDirectories;

    @Override
    protected List getInputDirectories() {
        List results = new ArrayList<>();
        for (String dir : inputDirectories.split(",")) {
            Path path = Paths.get(dir).toAbsolutePath();
            if (isDirectoryExists(path)) {
                results.add(path);
                getLog().info("Found results directory " + path);
            } else {
                getLog().warn("Directory " + path + " not found.");
            }
        }

        return results;
    }

    @Override
    protected String getMojoName() {
        return "bulk";
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy