17ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu/** 27ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * Copyright (c) 2004-2011 QOS.ch 388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * All rights reserved. 47ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * Permission is hereby granted, free of charge, to any person obtaining 688c4c456766193e012eb890e2208473d99b91f83Ceki 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, 988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * distribute, sublicense, and/or sell copies of the Software, and to 1088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * permit persons to whom the Software is furnished to do so, subject to 1188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * the following conditions: 127ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 1388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * The above copyright notice and this permission notice shall be 1488c4c456766193e012eb890e2208473d99b91f83Ceki 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 1888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 1988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 2088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 2188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 2288c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 237ba0605dc97fb81bde8311510d27b3ccba170008Ceki Gulcu * 2488c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu */ 2588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcupackage org.slf4j.cal10n_dummy; 2688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 2788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport java.util.Locale; 2888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 2988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport junit.framework.TestCase; 3088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3188c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport org.apache.log4j.spi.LoggingEvent; 3288c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport org.slf4j.cal10n.LocLogger; 3388c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport org.slf4j.cal10n.LocLoggerFactory; 3488c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport org.slf4j.dummyExt.ListAppender; 3588c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3688c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport ch.qos.cal10n.IMessageConveyor; 3788c4c456766193e012eb890e2208473d99b91f83Ceki Gulcuimport ch.qos.cal10n.MessageConveyor; 3888c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 3988c4c456766193e012eb890e2208473d99b91f83Ceki Gulcupublic class LocLoggerTest extends TestCase { 4088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu 4131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu ListAppender listAppender; 4231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu org.apache.log4j.Logger log4jRoot; 4331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 4431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu IMessageConveyor imc = new MessageConveyor(Locale.UK); 4531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu LocLoggerFactory llFactory_uk = new LocLoggerFactory(imc); 4631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 4731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu final static String EXPECTED_FILE_NAME = "LocLoggerTest.java"; 4831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 4931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public LocLoggerTest(String name) { 5031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super(name); 5131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 5231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 5331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void setUp() throws Exception { 5431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.setUp(); 5531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 5631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu // start from a clean slate for each test 5731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 5831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu listAppender = new ListAppender(); 5931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu listAppender.extractLocationInfo = true; 6031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu log4jRoot = org.apache.log4j.Logger.getRootLogger(); 6131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu log4jRoot.addAppender(listAppender); 6231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu log4jRoot.setLevel(org.apache.log4j.Level.TRACE); 6331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 6431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 6531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu void verify(LoggingEvent le, String expectedMsg) { 6631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertEquals(expectedMsg, le.getMessage()); 6731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu assertEquals(EXPECTED_FILE_NAME, le.getLocationInformation().getFileName()); 6831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 6931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 7031212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void tearDown() throws Exception { 7131212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu super.tearDown(); 7231212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 7331212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 7431212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu public void testSmoke() { 7531212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu LocLogger locLogger = llFactory_uk.getLocLogger(this.getClass()); 7631212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu locLogger.info(Months.JAN); 7731212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu verify((LoggingEvent) listAppender.list.get(0), "January"); 7831212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu 7931212435723e2dfd5d6716d1f6a7b0e66a1e6b38Ceki Gulcu } 8088c4c456766193e012eb890e2208473d99b91f83Ceki Gulcu} 81