/*
* Copyright 2014 Higher Frequency Trading
*
* http://www.higherfrequencytrading.com
*
* Licensed 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 net.openhft.chronicle.logger.log4j1;
import net.openhft.chronicle.Chronicle;
import net.openhft.chronicle.ExcerptTailer;
import net.openhft.chronicle.logger.ChronicleLog;
import net.openhft.chronicle.logger.ChronicleLogEvent;
import net.openhft.chronicle.logger.ChronicleLogHelper;
import net.openhft.chronicle.logger.ChronicleLogLevel;
import net.openhft.chronicle.tools.ChronicleTools;
import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import static org.junit.Assert.*;
public class Log4j1IndexedChronicleTest extends Log4j1TestBase {
// *************************************************************************
//
// *************************************************************************
@Test
public void testBinaryIndexedChronicleAppenderConfig() throws IOException {
final String loggerName = "config-binary-indexed-chronicle";
final String appenderName = "CONFIG-BINARY-INDEXED-CHRONICLE";
final org.apache.log4j.Logger logger = org.apache.log4j.Logger.getLogger(loggerName);
assertNotNull(logger);
final org.apache.log4j.Appender appender = logger.getAppender(appenderName);
assertNotNull(appender);
assertTrue(appender instanceof BinaryIndexedChronicleAppender);
BinaryIndexedChronicleAppender ba = (BinaryIndexedChronicleAppender)appender;
assertEquals(128, ba.getChronicleConfig().getIndexBlockSize());
}
@Test
public void testTextIndexedChronicleAppenderConfig() throws IOException {
final String loggerName = "config-text-indexed-chronicle";
final String appenderName = "CONFIG-TEXT-INDEXED-CHRONICLE";
final org.apache.log4j.Logger logger = org.apache.log4j.Logger.getLogger(loggerName);
assertNotNull(logger);
final org.apache.log4j.Appender appender = logger.getAppender(appenderName);
assertNotNull(appender);
assertTrue(appender instanceof TextIndexedChronicleAppender);
TextIndexedChronicleAppender ba = (TextIndexedChronicleAppender)appender;
assertEquals(128, ba.getChronicleConfig().getIndexBlockSize());
assertNotNull(ba.getDateFormat());
}
// *************************************************************************
// BINARY
// *************************************************************************
@Test
public void testIndexedBinaryAppender() throws IOException {
final String testId = "binary-indexed-chronicle";
final String threadId = testId + "-th";
final long timestamp = System.currentTimeMillis();
final Logger logger = LoggerFactory.getLogger(testId);
Thread.currentThread().setName(threadId);
for(ChronicleLogLevel level : LOG_LEVELS) {
log(logger,level,"level is {}",level);
}
final Chronicle chronicle = getIndexedChronicle(testId);
final ExcerptTailer tailer = chronicle.createTailer().toStart();
ChronicleLogEvent evt = null;
for(ChronicleLogLevel level : LOG_LEVELS) {
assertTrue(tailer.nextIndex());
evt = ChronicleLogHelper.decodeBinary(tailer);
assertNotNull(evt);
assertEquals(evt.getVersion(), ChronicleLog.VERSION);
assertTrue(evt.getTimeStamp() >= timestamp);
assertEquals(level,evt.getLevel());
assertEquals(threadId, evt.getThreadName());
assertEquals(testId, evt.getLoggerName());
assertEquals("level is " + level, evt.getMessage());
assertNotNull(evt.getArgumentArray());
assertEquals(0, evt.getArgumentArray().length);
tailer.finish();
}
logger.debug("Throwable test 1",new UnsupportedOperationException());
logger.debug("Throwable test 2",new UnsupportedOperationException("Exception message"));
assertTrue(tailer.nextIndex());
evt = ChronicleLogHelper.decodeBinary(tailer);
assertEquals("Throwable test 1",evt.getMessage());
assertNotNull(evt.getThrowable());
assertTrue(evt.getThrowable() instanceof UnsupportedOperationException);
assertNull(evt.getThrowable().getMessage());
assertTrue(tailer.nextIndex());
evt = ChronicleLogHelper.decodeBinary(tailer);
assertEquals("Throwable test 2",evt.getMessage());
assertNotNull(evt.getThrowable());
assertTrue(evt.getThrowable() instanceof UnsupportedOperationException);
assertEquals("Exception message", evt.getThrowable().getMessage());
tailer.close();
chronicle.close();
ChronicleTools.deleteOnExit(basePath(testId));
}
@Test
public void testIndexedTextAppender() throws IOException {
final String testId = "text-indexed-chronicle";
final String threadId = testId + "-th";
final Logger logger = LoggerFactory.getLogger(testId);
Thread.currentThread().setName(threadId);
for(ChronicleLogLevel level : LOG_LEVELS) {
log(logger,level,"level is {}",level);
}
Chronicle chronicle = getIndexedChronicle(testId);
ExcerptTailer tailer = chronicle.createTailer().toStart();
ChronicleLogEvent evt = null;
for(ChronicleLogLevel level : LOG_LEVELS) {
assertTrue(tailer.nextIndex());
evt = ChronicleLogHelper.decodeText(tailer);
assertNotNull(evt);
assertEquals(level,evt.getLevel());
assertEquals(threadId, evt.getThreadName());
assertEquals(testId, evt.getLoggerName());
assertEquals("level is " + level, evt.getMessage());
assertNotNull(evt.getArgumentArray());
assertEquals(0, evt.getArgumentArray().length);
tailer.finish();
}
logger.debug("Throwable test",new UnsupportedOperationException());
logger.debug("Throwable test",new UnsupportedOperationException("Exception message"));
assertTrue(tailer.nextIndex());
evt = ChronicleLogHelper.decodeText(tailer);
assertNotNull(evt);
assertEquals(threadId, evt.getThreadName());
assertEquals(testId, evt.getLoggerName());
assertTrue(evt.getMessage().contains("Throwable test"));
assertTrue(evt.getMessage().contains(UnsupportedOperationException.class.getName()));
assertTrue(evt.getMessage().contains(this.getClass().getName()));
assertNotNull(evt.getArgumentArray());
assertEquals(0, evt.getArgumentArray().length);
assertNull(evt.getThrowable());
assertTrue(tailer.nextIndex());
evt = ChronicleLogHelper.decodeText(tailer);assertNotNull(evt);
assertEquals(threadId, evt.getThreadName());
assertEquals(testId, evt.getLoggerName());
assertTrue(evt.getMessage().contains("Throwable test"));
assertTrue(evt.getMessage().contains("Exception message"));
assertTrue(evt.getMessage().contains(UnsupportedOperationException.class.getName()));
assertTrue(evt.getMessage().contains(this.getClass().getName()));
assertNotNull(evt.getArgumentArray());
assertEquals(0, evt.getArgumentArray().length);
assertNull(evt.getThrowable());
tailer.close();
chronicle.close();
ChronicleTools.deleteOnExit(basePath(testId));
}
}