[slf4j-dev] svn commit: r581 - in slf4j/trunk: src/java/org/slf4j/impl tests/src/java/org/slf4j/impl

ceki at slf4j.org ceki at slf4j.org
Mon May 1 21:02:39 CEST 2006


Author: ceki
Date: Mon May  1 21:02:37 2006
New Revision: 581

Added:
   slf4j/trunk/tests/src/java/org/slf4j/impl/Log4JLoggerAdapterLoggerNameTest.java
Modified:
   slf4j/trunk/src/java/org/slf4j/impl/JDK14LoggerAdapter.java
Log:
fixing bug #20. work in progress

Modified: slf4j/trunk/src/java/org/slf4j/impl/JDK14LoggerAdapter.java
==============================================================================
--- slf4j/trunk/src/java/org/slf4j/impl/JDK14LoggerAdapter.java	(original)
+++ slf4j/trunk/src/java/org/slf4j/impl/JDK14LoggerAdapter.java	Mon May  1 21:02:37 2006
@@ -461,6 +461,8 @@
    */
   private void log(Level level, String msg, Throwable t) {
     LogRecord record = new LogRecord(level, msg);
+    record.set
+    record.setLoggerName(getName());
     record.setThrown(t);
     fillCallerData(record);
     logger.log(record);

Added: slf4j/trunk/tests/src/java/org/slf4j/impl/Log4JLoggerAdapterLoggerNameTest.java
==============================================================================
--- (empty file)
+++ slf4j/trunk/tests/src/java/org/slf4j/impl/Log4JLoggerAdapterLoggerNameTest.java	Mon May  1 21:02:37 2006
@@ -0,0 +1,98 @@
+/*
+ * Copyright (c) 2004-2005 SLF4J.ORG
+ * Copyright (c) 2004-2005 QOS.ch
+ *
+ * All rights reserved.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining
+ * a copy of this software and associated documentation files (the
+ * "Software"), to  deal in  the Software without  restriction, including
+ * without limitation  the rights to  use, copy, modify,  merge, publish,
+ * distribute, and/or sell copies of  the Software, and to permit persons
+ * to whom  the Software is furnished  to do so, provided  that the above
+ * copyright notice(s) and this permission notice appear in all copies of
+ * the  Software and  that both  the above  copyright notice(s)  and this
+ * permission notice appear in supporting documentation.
+ *
+ * THE  SOFTWARE IS  PROVIDED  "AS  IS", WITHOUT  WARRANTY  OF ANY  KIND,
+ * EXPRESS OR  IMPLIED, INCLUDING  BUT NOT LIMITED  TO THE  WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR  A PARTICULAR PURPOSE AND NONINFRINGEMENT
+ * OF  THIRD PARTY  RIGHTS. IN  NO EVENT  SHALL THE  COPYRIGHT  HOLDER OR
+ * HOLDERS  INCLUDED IN  THIS  NOTICE BE  LIABLE  FOR ANY  CLAIM, OR  ANY
+ * SPECIAL INDIRECT  OR CONSEQUENTIAL DAMAGES, OR  ANY DAMAGES WHATSOEVER
+ * RESULTING FROM LOSS  OF USE, DATA OR PROFITS, WHETHER  IN AN ACTION OF
+ * CONTRACT, NEGLIGENCE  OR OTHER TORTIOUS  ACTION, ARISING OUT OF  OR IN
+ * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ *
+ * Except as  contained in  this notice, the  name of a  copyright holder
+ * shall not be used in advertising or otherwise to promote the sale, use
+ * or other dealings in this Software without prior written authorization
+ * of the copyright holder.
+ *
+ */
+
+package org.slf4j.impl;
+
+import java.util.logging.Handler;
+import java.util.logging.LogRecord;
+import java.util.logging.Logger;
+
+import junit.framework.TestCase;
+
+public class Log4JLoggerAdapterLoggerNameTest extends TestCase {
+  private MockHandler mockHandler;
+
+  protected void setUp() throws Exception {
+    super.setUp();
+    Logger logger = Logger.getLogger("TEST");
+    mockHandler = new MockHandler();
+    removeHandlers(logger);
+    logger.addHandler(mockHandler);
+  }
+
+  protected void tearDown() throws Exception {
+    removeHandlers(Logger.getLogger("TEST"));
+    super.tearDown();
+  }
+
+  public void testLoggerNameusingJdkLogging() throws Exception {
+    Logger.getLogger("TEST").info("test message");
+    assertCorrectLoggerName();
+
+  }
+
+  public void testLoggerNameUsingSlf4j() throws Exception {
+    JDK14LoggerFactory factory = new JDK14LoggerFactory();
+    org.slf4j.Logger logger = factory.getLogger("TEST");
+    logger.info("test message");
+    assertCorrectLoggerName();
+  }
+
+  private void removeHandlers(Logger logger) {
+    logger.setUseParentHandlers(false);
+    Handler[] handlers = logger.getHandlers();
+    for (int i = 0; i < handlers.length; i++) {
+      logger.removeHandler(handlers[i]);
+    }
+  }
+
+  private void assertCorrectLoggerName() {
+    assertNotNull("no log record", mockHandler.record);
+    assertNotNull("missing logger name", mockHandler.record.getLoggerName());
+  }
+
+  private class MockHandler extends java.util.logging.Handler {
+    public LogRecord record;
+
+    public void close() throws SecurityException {
+    }
+
+    public void flush() {
+    }
+
+    public void publish(LogRecord record) {
+      this.record = record;
+    }
+
+  }
+}
\ No newline at end of file



More information about the slf4j-dev mailing list