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