
io.qameta.allure.timeline.TimelinePlugin Maven / Gradle / Ivy
package io.qameta.allure.timeline;
import io.qameta.allure.Aggregator;
import io.qameta.allure.context.JacksonContext;
import io.qameta.allure.core.Configuration;
import io.qameta.allure.core.LaunchResults;
import io.qameta.allure.entity.LabelName;
import io.qameta.allure.entity.TestResult;
import io.qameta.allure.tree.TestResultTree;
import io.qameta.allure.tree.Tree;
import java.io.IOException;
import java.io.OutputStream;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Collection;
import java.util.List;
import static io.qameta.allure.tree.TreeUtils.groupByLabels;
/**
* Plugin that generates data for Timeline tab.
*
* @since 2.0
*/
public class TimelinePlugin implements Aggregator {
@Override
public void aggregate(final Configuration configuration,
final List launchesResults,
final Path outputDirectory) throws IOException {
final JacksonContext jacksonContext = configuration.requireContext(JacksonContext.class);
final Path dataFolder = Files.createDirectories(outputDirectory.resolve("data"));
final Path dataFile = dataFolder.resolve("timeline.json");
try (OutputStream os = Files.newOutputStream(dataFile)) {
jacksonContext.getValue().writeValue(os, getData(launchesResults));
}
}
@SuppressWarnings("PMD.DefaultPackage")
/* default */ Tree getData(final List launchResults) {
// @formatter:off
final Tree timeline = new TestResultTree(
"timeline",
testResult -> groupByLabels(testResult, LabelName.HOST, LabelName.THREAD)
);
// @formatter:on
launchResults.stream()
.map(LaunchResults::getResults)
.flatMap(Collection::stream)
.forEach(timeline::add);
return timeline;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy