diff --git a/doc/testing.html b/doc/testing.html
index 1ef3038d194..9d90d13e357 100644
--- a/doc/testing.html
+++ b/doc/testing.html
@@ -200,6 +200,8 @@ TEST FAILURE
Retry failed tests up to a set number of times, until they pass. This allows to pass the tests with intermittent failures. Defaults to 0.
REPEAT_COUNT
Repeat the tests up to a set number of times, stopping at first failure. This helps to reproduce intermittent test failures. Defaults to 0.
+REPORT
+Use this report style when reporting test results (sent to JTReg as -report
). Defaults to executed
.
Gtest keywords
REPEAT
The number of times to repeat the tests (--gtest_repeat
).
diff --git a/doc/testing.md b/doc/testing.md
index 5cac75ca2c8..634c240aeda 100644
--- a/doc/testing.md
+++ b/doc/testing.md
@@ -456,6 +456,11 @@ Repeat the tests up to a set number of times, stopping at first failure.
This helps to reproduce intermittent test failures.
Defaults to 0.
+#### REPORT
+
+Use this report style when reporting test results (sent to JTReg as `-report`).
+Defaults to `executed`.
+
### Gtest keywords
#### REPEAT
diff --git a/make/RunTests.gmk b/make/RunTests.gmk
index c9ee216a722..edf294eaba9 100644
--- a/make/RunTests.gmk
+++ b/make/RunTests.gmk
@@ -196,11 +196,12 @@ $(eval $(call SetTestOpt,JAVA_OPTIONS,JTREG))
$(eval $(call SetTestOpt,JOBS,JTREG))
$(eval $(call SetTestOpt,TIMEOUT_FACTOR,JTREG))
$(eval $(call SetTestOpt,FAILURE_HANDLER_TIMEOUT,JTREG))
+$(eval $(call SetTestOpt,REPORT,JTREG))
$(eval $(call ParseKeywordVariable, JTREG, \
SINGLE_KEYWORDS := JOBS TIMEOUT_FACTOR FAILURE_HANDLER_TIMEOUT \
TEST_MODE ASSERT VERBOSE RETAIN MAX_MEM RUN_PROBLEM_LISTS \
- RETRY_COUNT REPEAT_COUNT MAX_OUTPUT $(CUSTOM_JTREG_SINGLE_KEYWORDS), \
+ RETRY_COUNT REPEAT_COUNT MAX_OUTPUT REPORT $(CUSTOM_JTREG_SINGLE_KEYWORDS), \
STRING_KEYWORDS := OPTIONS JAVA_OPTIONS VM_OPTIONS KEYWORDS \
EXTRA_PROBLEM_LISTS LAUNCHER_OPTIONS \
$(CUSTOM_JTREG_STRING_KEYWORDS), \
@@ -745,6 +746,7 @@ define SetupRunJtregTestBody
JTREG_RUN_PROBLEM_LISTS ?= false
JTREG_RETRY_COUNT ?= 0
JTREG_REPEAT_COUNT ?= 0
+ JTREG_REPORT ?= executed
ifneq ($$(JTREG_RETRY_COUNT), 0)
ifneq ($$(JTREG_REPEAT_COUNT), 0)
@@ -854,6 +856,7 @@ define SetupRunJtregTestBody
-dir:$$(JTREG_TOPDIR) \
-reportDir:$$($1_TEST_RESULTS_DIR) \
-workDir:$$($1_TEST_SUPPORT_DIR) \
+ -report:$$$${JTREG_REPORT_ITERATION} \
$$$${JTREG_STATUS} \
$$(JTREG_OPTIONS) \
$$(JTREG_FAILURE_HANDLER_OPTIONS) \
@@ -865,6 +868,7 @@ define SetupRunJtregTestBody
ifneq ($$(JTREG_RETRY_COUNT), 0)
$1_COMMAND_LINE := \
+ export JTREG_REPORT_ITERATION=$$(JTREG_REPORT); \
for i in {0..$$(JTREG_RETRY_COUNT)}; do \
if [ "$$$$i" != 0 ]; then \
$$(PRINTF) "\nRetrying Jtreg run. Attempt: $$$$i\n"; \
@@ -874,11 +878,11 @@ define SetupRunJtregTestBody
break; \
fi; \
export JTREG_STATUS="-status:error,fail"; \
+ export JTREG_REPORT_ITERATION="all-executed"; \
done
- endif
-
- ifneq ($$(JTREG_REPEAT_COUNT), 0)
+ else ifneq ($$(JTREG_REPEAT_COUNT), 0)
$1_COMMAND_LINE := \
+ export JTREG_REPORT_ITERATION=$$(JTREG_REPORT); \
for i in {1..$$(JTREG_REPEAT_COUNT)}; do \
$$(PRINTF) "\nRepeating Jtreg run: $$$$i out of $$(JTREG_REPEAT_COUNT)\n"; \
$$($1_COMMAND_LINE); \
@@ -887,6 +891,10 @@ define SetupRunJtregTestBody
break; \
fi; \
done
+ else
+ $1_COMMAND_LINE := \
+ export JTREG_REPORT_ITERATION=$$(JTREG_REPORT); \
+ $$($1_COMMAND_LINE);
endif
run-test-$1: pre-run-test clean-workdir-$1