From 7c39ca214e0180ec33fcce26d2395072724c75c5 Mon Sep 17 00:00:00 2001 From: sskorol Date: Wed, 23 Jun 2021 15:28:45 +0300 Subject: [PATCH] There were several places in code with hardcoded limits for items rendered on charts. It was really inconvenient for the end-user who had to rebuild the entire project to make limits configurable. This fix moves the actual configuration into an Aggregator interface which is implemented by key plugins. Moreover, a user can now control the limits via RESULTS_LIMIT env variable that could be set before report's generation. Note that a newly added method was intentionally made static as some of the APIs that adjust the limits are also static. --- .../allure/category/CategoriesTrendPlugin.java | 3 ++- .../qameta/allure/duration/DurationTrendPlugin.java | 3 ++- .../java/io/qameta/allure/history/HistoryPlugin.java | 2 +- .../io/qameta/allure/history/HistoryTrendPlugin.java | 3 ++- .../io/qameta/allure/retry/RetryTrendPlugin.java | 3 ++- .../src/main/java/io/qameta/allure/Aggregator.java | 12 ++++++++++++ 6 files changed, 21 insertions(+), 5 deletions(-) diff --git a/allure-generator/src/main/java/io/qameta/allure/category/CategoriesTrendPlugin.java b/allure-generator/src/main/java/io/qameta/allure/category/CategoriesTrendPlugin.java index 76ccf63a85..6bf6c79d1c 100644 --- a/allure-generator/src/main/java/io/qameta/allure/category/CategoriesTrendPlugin.java +++ b/allure-generator/src/main/java/io/qameta/allure/category/CategoriesTrendPlugin.java @@ -18,6 +18,7 @@ import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; +import io.qameta.allure.Aggregator; import io.qameta.allure.CommonJsonAggregator; import io.qameta.allure.Constants; import io.qameta.allure.core.LaunchResults; @@ -54,7 +55,7 @@ protected static List getData(final List lau final List data = getHistoryItems(launchesResults); return Stream.concat(Stream.of(item), data.stream()) - .limit(20) + .limit(Aggregator.resultsLimit()) .collect(Collectors.toList()); } diff --git a/allure-generator/src/main/java/io/qameta/allure/duration/DurationTrendPlugin.java b/allure-generator/src/main/java/io/qameta/allure/duration/DurationTrendPlugin.java index ac809b1635..e51a8f345f 100644 --- a/allure-generator/src/main/java/io/qameta/allure/duration/DurationTrendPlugin.java +++ b/allure-generator/src/main/java/io/qameta/allure/duration/DurationTrendPlugin.java @@ -18,6 +18,7 @@ import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; +import io.qameta.allure.Aggregator; import io.qameta.allure.CommonJsonAggregator; import io.qameta.allure.Constants; import io.qameta.allure.core.LaunchResults; @@ -55,7 +56,7 @@ protected Optional parseItem(final ObjectMapper mapper, final final List data = getHistoryItems(launchesResults); return Stream.concat(Stream.of(item), data.stream()) - .limit(20) + .limit(Aggregator.resultsLimit()) .collect(Collectors.toList()); } diff --git a/allure-generator/src/main/java/io/qameta/allure/history/HistoryPlugin.java b/allure-generator/src/main/java/io/qameta/allure/history/HistoryPlugin.java index 7f28ac5f22..27ae530695 100644 --- a/allure-generator/src/main/java/io/qameta/allure/history/HistoryPlugin.java +++ b/allure-generator/src/main/java/io/qameta/allure/history/HistoryPlugin.java @@ -156,7 +156,7 @@ private void updateHistory(final Map history, } final List newItems = Stream.concat(Stream.of(newItem), data.getItems().stream()) - .limit(20) + .limit(Aggregator.resultsLimit()) .collect(Collectors.toList()); result.setNewFailed(isNewFailed(newItems)); result.setFlaky(isFlaky(newItems)); diff --git a/allure-generator/src/main/java/io/qameta/allure/history/HistoryTrendPlugin.java b/allure-generator/src/main/java/io/qameta/allure/history/HistoryTrendPlugin.java index f487bb7b70..0ad22dc47e 100644 --- a/allure-generator/src/main/java/io/qameta/allure/history/HistoryTrendPlugin.java +++ b/allure-generator/src/main/java/io/qameta/allure/history/HistoryTrendPlugin.java @@ -18,6 +18,7 @@ import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; +import io.qameta.allure.Aggregator; import io.qameta.allure.CommonJsonAggregator; import io.qameta.allure.Constants; import io.qameta.allure.core.LaunchResults; @@ -65,7 +66,7 @@ protected Optional parseItem(final ObjectMapper mapper, final final List data = getHistoryItems(launchesResults); return Stream.concat(Stream.of(item), data.stream()) - .limit(20) + .limit(Aggregator.resultsLimit()) .collect(Collectors.toList()); } diff --git a/allure-generator/src/main/java/io/qameta/allure/retry/RetryTrendPlugin.java b/allure-generator/src/main/java/io/qameta/allure/retry/RetryTrendPlugin.java index 4de86c822e..6df4607106 100644 --- a/allure-generator/src/main/java/io/qameta/allure/retry/RetryTrendPlugin.java +++ b/allure-generator/src/main/java/io/qameta/allure/retry/RetryTrendPlugin.java @@ -18,6 +18,7 @@ import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; +import io.qameta.allure.Aggregator; import io.qameta.allure.CommonJsonAggregator; import io.qameta.allure.Constants; import io.qameta.allure.core.LaunchResults; @@ -55,7 +56,7 @@ protected Optional parseItem(final ObjectMapper mapper, final Js final List data = getHistoryItems(launchesResults); return Stream.concat(Stream.of(item), data.stream()) - .limit(20) + .limit(Aggregator.resultsLimit()) .collect(Collectors.toList()); } diff --git a/allure-plugin-api/src/main/java/io/qameta/allure/Aggregator.java b/allure-plugin-api/src/main/java/io/qameta/allure/Aggregator.java index a1f6ab2613..7cd1a73c3a 100644 --- a/allure-plugin-api/src/main/java/io/qameta/allure/Aggregator.java +++ b/allure-plugin-api/src/main/java/io/qameta/allure/Aggregator.java @@ -21,6 +21,7 @@ import java.io.IOException; import java.nio.file.Path; import java.util.List; +import java.util.Optional; /** * Aggregator extension. Can be used to process results and/or generate @@ -31,6 +32,17 @@ @FunctionalInterface public interface Aggregator extends Extension { + /** + * Configure the number of items to be rendered on different charts. + * + * @return RESULTS_LIMIT provided by user, or a default value = 20. + */ + static long resultsLimit() { + return Optional.ofNullable(System.getenv("RESULTS_LIMIT")) + .map(Long::parseLong) + .orElse(20L); + } + /** * Process report data. *