17ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu/** 27ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * Copyright (c) 2004-2011 QOS.ch 388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * All rights reserved. 47ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 57ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * Permission is hereby granted, free of charge, to any person obtaining 67ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * a copy of this software and associated documentation files (the 788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * "Software"), to deal in the Software without restriction, including 888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * without limitation the rights to use, copy, modify, merge, publish, 97ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * distribute, sublicense, and/or sell copies of the Software, and to 107ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * permit persons to whom the Software is furnished to do so, subject to 117ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * the following conditions: 127ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 137ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * The above copyright notice and this permission notice shall be 147ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * included in all copies or substantial portions of the Software. 157ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 1688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 1788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 187ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 197ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 207ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 217ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 227ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 2388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * 2488c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu */ 2588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcupackage org.slf4j; 2688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 2788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport java.util.logging.Level; 2888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 2988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport junit.framework.TestCase; 3088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu/** 3288c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * Test whether invoking the SLF4J API causes problems or not. 3388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * 3488c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * @author Ceki Gulcu 3588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * 3688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu */ 3788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcupublic class InvocationTest extends TestCase { 3888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Level oldLevel; 4031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu java.util.logging.Logger root = java.util.logging.Logger.getLogger(""); 4131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 4231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public InvocationTest(String arg0) { 4331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super(arg0); 4431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 4531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 4631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu protected void setUp() throws Exception { 4731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.setUp(); 4831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu oldLevel = root.getLevel(); 4931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu root.setLevel(Level.OFF); 5031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 5131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 5231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu protected void tearDown() throws Exception { 5331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.tearDown(); 5431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu root.setLevel(oldLevel); 5531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 5631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 5731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void test1() { 5831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Logger logger = LoggerFactory.getLogger("test1"); 5931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug("Hello world."); 6031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 6131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 6231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void test2() { 6331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Integer i1 = new Integer(1); 6431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Integer i2 = new Integer(2); 6531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Integer i3 = new Integer(3); 6631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Exception e = new Exception("This is a test exception."); 6731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Logger logger = LoggerFactory.getLogger("test2"); 6831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 6931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug("Hello world 1."); 7031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug("Hello world {}", i1); 7131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug("val={} val={}", i1, i2); 7231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug("val={} val={} val={}", new Object[] { i1, i2, i3 }); 7331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 7431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug("Hello world 2", e); 7531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info("Hello world 2."); 7631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 7731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn("Hello world 3."); 7831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn("Hello world 3", e); 7931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 8031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error("Hello world 4."); 8131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error("Hello world {}", new Integer(3)); 8231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error("Hello world 4.", e); 8331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 8431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 8531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void testNull() { 8631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Logger logger = LoggerFactory.getLogger("testNull"); 8731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug(null); 8831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(null); 8931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn(null); 9031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error(null); 9131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 9231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Exception e = new Exception("This is a test exception."); 9331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug(null, e); 9431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(null, e); 9531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn(null, e); 9631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error(null, e); 9731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 9831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 9931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void testMarker() { 10031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Logger logger = LoggerFactory.getLogger("testMarker"); 10131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu Marker blue = MarkerFactory.getMarker("BLUE"); 10231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug(blue, "hello"); 10331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(blue, "hello"); 10431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn(blue, "hello"); 10531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error(blue, "hello"); 10631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 10731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug(blue, "hello {}", "world"); 10831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(blue, "hello {}", "world"); 10931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn(blue, "hello {}", "world"); 11031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error(blue, "hello {}", "world"); 11131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 11231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.debug(blue, "hello {} and {} ", "world", "universe"); 11331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.info(blue, "hello {} and {} ", "world", "universe"); 11431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.warn(blue, "hello {} and {} ", "world", "universe"); 11531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu logger.error(blue, "hello {} and {} ", "world", "universe"); 11631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 11731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 11831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void testMDC() { 11931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu MDC.put("k", "v"); 12031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertNull(MDC.get("k")); 12131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu MDC.remove("k"); 12231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertNull(MDC.get("k")); 12331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu MDC.clear(); 12431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 12588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu} 126