From e7876b05dbd348b317f3b4548bf37959cdee6fba Mon Sep 17 00:00:00 2001 From: Ulli Hafner Date: Sat, 30 Mar 2024 12:25:41 +0100 Subject: [PATCH] Skip logging of exceptions if the limit has been reached. --- .../java/edu/hm/hafner/util/FilteredLog.java | 4 ++- .../edu/hm/hafner/util/FilteredLogTest.java | 34 +++++++++++++------ 2 files changed, 27 insertions(+), 11 deletions(-) diff --git a/src/main/java/edu/hm/hafner/util/FilteredLog.java b/src/main/java/edu/hm/hafner/util/FilteredLog.java index 2f99bff5..b297dbaa 100644 --- a/src/main/java/edu/hm/hafner/util/FilteredLog.java +++ b/src/main/java/edu/hm/hafner/util/FilteredLog.java @@ -162,7 +162,9 @@ public void logException(final Exception exception, final String format, final O lock.lock(); try { - errorMessages.addAll(Arrays.asList(ExceptionUtils.getRootCauseStackTrace(exception))); + if (lines <= maxLines) { + errorMessages.addAll(Arrays.asList(ExceptionUtils.getRootCauseStackTrace(exception))); + } } finally { lock.unlock(); diff --git a/src/test/java/edu/hm/hafner/util/FilteredLogTest.java b/src/test/java/edu/hm/hafner/util/FilteredLogTest.java index d6b3b7db..bf485bb4 100644 --- a/src/test/java/edu/hm/hafner/util/FilteredLogTest.java +++ b/src/test/java/edu/hm/hafner/util/FilteredLogTest.java @@ -51,28 +51,42 @@ void shouldLogAllErrors() { void shouldSkipAdditionalErrors() { FilteredLog filteredLog = create5ErrorsLogWithTitle(StringUtils.EMPTY); - assertThat(filteredLog).hasOnlyErrorMessages("1", "2", "3", "4", "5", - " ... skipped logging of 2 additional errors ..."); + verifyFiveErrorMessages(filteredLog); } @Test void shouldSkipAdditionalErrorsWithTitle() { FilteredLog filteredLog = create5ErrorsLogWithTitle(TITLE); - assertThat(filteredLog).hasOnlyErrorMessages(TITLE, "1", "2", "3", "4", "5", + assertThat(filteredLog).hasErrorMessages(TITLE); + + verifyFiveErrorMessages(filteredLog); + } + + private void verifyFiveErrorMessages(final FilteredLog filteredLog) { + assertThat(filteredLog).hasErrorMessages( + "1", "2", "3", "4", "5", + "java.lang.IllegalStateException: 1", + "java.lang.IllegalStateException: 2", + "java.lang.IllegalStateException: 3", + "java.lang.IllegalStateException: 4", + "java.lang.IllegalStateException: 5", " ... skipped logging of 2 additional errors ..."); + + assertThat(filteredLog).doesNotHaveErrorMessages( + "6", + "java.lang.IllegalStateException: 6", + "7", + "java.lang.IllegalStateException: 7"); } private FilteredLog create5ErrorsLogWithTitle(final String title) { var filteredLog = new FilteredLog(title, 5); - filteredLog.logError("1"); - filteredLog.logError("2"); - filteredLog.logError("3"); - filteredLog.logError("4"); - filteredLog.logError("5"); - filteredLog.logError("6"); - filteredLog.logError("7"); + for (int i = 1; i < 8; i++) { + var number = String.valueOf(i); + filteredLog.logException(new IllegalStateException(number), number); + } assertThat(filteredLog.size()).isEqualTo(7);