diff --git a/log4j-core-test/src/test/java/org/apache/logging/log4j/core/appender/AsyncAppenderTest.java b/log4j-core-test/src/test/java/org/apache/logging/log4j/core/appender/AsyncAppenderTest.java index e693d2ca15ff..dda884d9c40d 100644 --- a/log4j-core-test/src/test/java/org/apache/logging/log4j/core/appender/AsyncAppenderTest.java +++ b/log4j-core-test/src/test/java/org/apache/logging/log4j/core/appender/AsyncAppenderTest.java @@ -173,4 +173,11 @@ public void testShutdownTimeout(final LoggerContext context) { context.getLogger("Logger").info("This is a test"); context.stop(); } + + @Test + @LoggerContextSource("log4j-asynch-location.xml") + public void testRequiresLocation(final LoggerContext context) { + final AsyncAppender appender = context.getConfiguration().getAppender("Async"); + assertTrue(appender.requiresLocation()); + } } diff --git a/log4j-core-test/src/test/resources/log4j-asynch-location.xml b/log4j-core-test/src/test/resources/log4j-asynch-location.xml new file mode 100644 index 000000000000..9da5c4702ff8 --- /dev/null +++ b/log4j-core-test/src/test/resources/log4j-asynch-location.xml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + diff --git a/log4j-core/src/main/java/org/apache/logging/log4j/core/appender/AsyncAppender.java b/log4j-core/src/main/java/org/apache/logging/log4j/core/appender/AsyncAppender.java index 463067ae9489..f84870712345 100644 --- a/log4j-core/src/main/java/org/apache/logging/log4j/core/appender/AsyncAppender.java +++ b/log4j-core/src/main/java/org/apache/logging/log4j/core/appender/AsyncAppender.java @@ -47,6 +47,7 @@ import org.apache.logging.log4j.core.config.plugins.PluginElement; import org.apache.logging.log4j.core.config.plugins.validation.constraints.Required; import org.apache.logging.log4j.core.filter.AbstractFilterable; +import org.apache.logging.log4j.core.impl.LocationAware; import org.apache.logging.log4j.core.impl.Log4jLogEvent; import org.apache.logging.log4j.spi.AbstractLogger; @@ -471,4 +472,22 @@ public int getQueueRemainingCapacity() { public int getQueueSize() { return queue.size(); } + + @Override + public boolean requiresLocation() { + if (!includeLocation) { + return false; + } + for (final Appender appender : this.getAppenders()) { + if (appender instanceof LocationAware && ((LocationAware) appender).requiresLocation()) { + return true; + } + } + if (errorAppender != null + && errorAppender.getAppender() instanceof LocationAware + && ((LocationAware) errorAppender.getAppender()).requiresLocation()) { + return true; + } + return false; + } } diff --git a/src/changelog/.2.x.x/3257_fix_AsyncAppender_requiresLocation.xml b/src/changelog/.2.x.x/3257_fix_AsyncAppender_requiresLocation.xml new file mode 100644 index 000000000000..c56c76ee401e --- /dev/null +++ b/src/changelog/.2.x.x/3257_fix_AsyncAppender_requiresLocation.xml @@ -0,0 +1,8 @@ + + + + Fix detection of location requirements in `AsyncAppender`. + \ No newline at end of file