| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache license, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the license for the specific language governing permissions and |
| * limitations under the license. |
| */ |
| package org.apache.logging.log4j.core.appender.routing; |
| |
| import static org.junit.Assert.assertEquals; |
| import static org.junit.Assert.assertNotNull; |
| import static org.junit.Assert.assertTrue; |
| |
| import java.io.File; |
| import java.util.List; |
| |
| import org.apache.logging.log4j.EventLogger; |
| import org.apache.logging.log4j.core.LogEvent; |
| import org.apache.logging.log4j.junit.LoggerContextRule; |
| import org.apache.logging.log4j.message.StructuredDataMessage; |
| import org.apache.logging.log4j.test.appender.ListAppender; |
| import org.junit.After; |
| import org.junit.Before; |
| import org.junit.Rule; |
| import org.junit.Test; |
| import org.junit.rules.RuleChain; |
| |
| /** |
| * Tests Routing appender purge facilities |
| */ |
| public class RoutingAppenderWithPurgingTest { |
| private static final String CONFIG = "log4j-routing-purge.xml"; |
| private static final String IDLE_LOG_FILE1 = "target/routing-purge-idle/routingtest-1.log"; |
| private static final String IDLE_LOG_FILE2 = "target/routing-purge-idle/routingtest-2.log"; |
| private static final String IDLE_LOG_FILE3 = "target/routing-purge-idle/routingtest-3.log"; |
| private static final String MANUAL_LOG_FILE1 = "target/routing-purge-manual/routingtest-1.log"; |
| private static final String MANUAL_LOG_FILE2 = "target/routing-purge-manual/routingtest-2.log"; |
| private static final String MANUAL_LOG_FILE3 = "target/routing-purge-manual/routingtest-3.log"; |
| |
| private ListAppender app; |
| private RoutingAppender routingAppenderIdle; |
| private RoutingAppender routingAppenderIdleWithHangingAppender; |
| private RoutingAppender routingAppenderManual; |
| |
| private final LoggerContextRule loggerContextRule = new LoggerContextRule(CONFIG); |
| |
| @Rule |
| public RuleChain chain = loggerContextRule.withCleanFilesRule(IDLE_LOG_FILE1, IDLE_LOG_FILE2, IDLE_LOG_FILE3, |
| MANUAL_LOG_FILE1, MANUAL_LOG_FILE2, MANUAL_LOG_FILE3); |
| |
| |
| @Before |
| public void setUp() throws Exception { |
| this.app = this.loggerContextRule.getListAppender("List"); |
| this.routingAppenderIdle = this.loggerContextRule.getRequiredAppender("RoutingPurgeIdle", RoutingAppender.class); |
| this.routingAppenderIdleWithHangingAppender = |
| this.loggerContextRule.getRequiredAppender("RoutingPurgeIdleWithHangingAppender", RoutingAppender.class); |
| this.routingAppenderManual = this.loggerContextRule.getRequiredAppender("RoutingPurgeManual", RoutingAppender.class); |
| } |
| |
| @After |
| public void tearDown() throws Exception { |
| this.app.clear(); |
| this.loggerContextRule.getLoggerContext().stop(); |
| } |
| |
| @Test(timeout = 5000) |
| public void routingTest() throws InterruptedException { |
| StructuredDataMessage msg = new StructuredDataMessage("1", "This is a test 1", "Service"); |
| EventLogger.logEvent(msg); |
| final List<LogEvent> list = app.getEvents(); |
| assertNotNull("No events generated", list); |
| assertTrue("Incorrect number of events. Expected 1, got " + list.size(), list.size() == 1); |
| msg = new StructuredDataMessage("2", "This is a test 2", "Service"); |
| EventLogger.logEvent(msg); |
| msg = new StructuredDataMessage("3", "This is a test 3", "Service"); |
| EventLogger.logEvent(msg); |
| final String[] files = {IDLE_LOG_FILE1, IDLE_LOG_FILE2, IDLE_LOG_FILE3, MANUAL_LOG_FILE1, MANUAL_LOG_FILE2, MANUAL_LOG_FILE3}; |
| assertFileExistance(files); |
| |
| assertEquals("Incorrect number of appenders with IdlePurgePolicy.", 3, routingAppenderIdle.getAppenders().size()); |
| assertEquals("Incorrect number of appenders with IdlePurgePolicy with HangingAppender.", |
| 3, routingAppenderIdleWithHangingAppender.getAppenders().size()); |
| assertEquals("Incorrect number of appenders manual purge.", 3, routingAppenderManual.getAppenders().size()); |
| |
| Thread.sleep(3000); |
| EventLogger.logEvent(msg); |
| |
| assertEquals("Incorrect number of appenders with IdlePurgePolicy.", 1, routingAppenderIdle.getAppenders().size()); |
| assertEquals("Incorrect number of appenders with manual purge.", 3, routingAppenderManual.getAppenders().size()); |
| |
| routingAppenderManual.deleteAppender("1"); |
| routingAppenderManual.deleteAppender("2"); |
| routingAppenderManual.deleteAppender("3"); |
| |
| assertEquals("Incorrect number of appenders with IdlePurgePolicy.", 1, routingAppenderIdle.getAppenders().size()); |
| assertEquals("Incorrect number of appenders with manual purge.", 0, routingAppenderManual.getAppenders().size()); |
| |
| msg = new StructuredDataMessage("5", "This is a test 5", "Service"); |
| EventLogger.logEvent(msg); |
| |
| assertEquals("Incorrect number of appenders with manual purge.", 1, routingAppenderManual.getAppenders().size()); |
| |
| routingAppenderManual.deleteAppender("5"); |
| routingAppenderManual.deleteAppender("5"); |
| |
| assertEquals("Incorrect number of appenders with manual purge.", 0, routingAppenderManual.getAppenders().size()); |
| } |
| |
| |
| private void assertFileExistance(final String... files) { |
| for (final String file : files) { |
| assertTrue("File should exist - " + file + " file ", new File(file).exists()); |
| } |
| } |
| } |