NIFI-5011: Fixed threading bug in TestFileSystemRepository

This closes #2578.

Signed-off-by: Mark Payne <markap14@hotmail.com>
This commit is contained in:
Mark Payne 2018-03-23 14:33:53 -04:00
parent 758e44682f
commit 03f4c0fc47
1 changed files with 12 additions and 6 deletions

View File

@ -148,14 +148,20 @@ public class TestFileSystemRepository {
String message = "The value of nifi.content.repository.archive.cleanup.frequency property " String message = "The value of nifi.content.repository.archive.cleanup.frequency property "
+ "is set to '1 millis' which is below the allowed minimum of 1 second (1000 milliseconds). " + "is set to '1 millis' which is below the allowed minimum of 1 second (1000 milliseconds). "
+ "Minimum value of 1 sec will be used as scheduling interval for archive cleanup task."; + "Minimum value of 1 sec will be used as scheduling interval for archive cleanup task.";
for (ILoggingEvent event : testAppender.list) {
String actualMessage = event.getFormattedMessage(); // Must synchronize on testAppender, because the call to append() is synchronized and this synchronize
if (actualMessage.equals(message)) { // keyword guards testAppender.list. Since we are accessing testAppender.list, we must do so in a thread-safe manner.
assertEquals(event.getLevel(), Level.WARN); synchronized (testAppender) {
messageFound = true; for (ILoggingEvent event : testAppender.list) {
break; String actualMessage = event.getFormattedMessage();
if (actualMessage.equals(message)) {
assertEquals(event.getLevel(), Level.WARN);
messageFound = true;
break;
}
} }
} }
assertTrue(messageFound); assertTrue(messageFound);
} }