Merge "Queue yang model"
[controller.git] / opendaylight / config / logback-config / src / test / java / org / opendaylight / controller / config / yang / logback / config / LogbackWithXmlConfigModuleTest.java
1 /*
2  * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.controller.config.yang.logback.config;
9
10 import static org.junit.Assert.assertEquals;
11
12 import java.io.File;
13 import java.io.IOException;
14 import java.lang.management.ManagementFactory;
15 import java.util.List;
16
17 import javax.management.InstanceAlreadyExistsException;
18 import javax.management.InstanceNotFoundException;
19 import javax.management.JMX;
20 import javax.management.ObjectName;
21
22 import org.apache.commons.io.FileUtils;
23 import org.junit.Before;
24 import org.junit.Test;
25 import org.opendaylight.controller.config.manager.impl.AbstractConfigTest;
26 import org.opendaylight.controller.config.manager.impl.factoriesresolver.HardcodedModuleFactoriesResolver;
27 import org.opendaylight.controller.config.util.ConfigTransactionJMXClient;
28 import org.slf4j.LoggerFactory;
29
30 import com.google.common.collect.Lists;
31
32 import ch.qos.logback.classic.LoggerContext;
33 import ch.qos.logback.classic.joran.JoranConfigurator;
34 import ch.qos.logback.core.joran.spi.JoranException;
35
36 public class LogbackWithXmlConfigModuleTest extends AbstractConfigTest {
37
38     private LogbackModuleFactory factory;
39     private LoggerContext lc;
40
41     @Before
42     public void setUp() throws JoranException, IOException {
43
44         factory = new LogbackModuleFactory();
45         super.initConfigTransactionManagerImpl(new HardcodedModuleFactoriesResolver(factory));
46
47         lc = (LoggerContext) LoggerFactory.getILoggerFactory();
48         JoranConfigurator configurator = new JoranConfigurator();
49         lc.reset();
50         configurator.setContext(lc);
51         configurator.doConfigure("src/test/resources/simple_config_logback.xml");
52         File f = new File("target/it");
53         if (f.exists())
54             FileUtils.cleanDirectory(f);
55     }
56
57     /**
58      * Tests configuration of Logger factory.
59      */
60     @Test
61     public void test() throws InstanceAlreadyExistsException, InstanceNotFoundException {
62
63         ConfigTransactionJMXClient transaction = configRegistryClient.createTransaction();
64         ObjectName nameCreated = transaction.createModule(factory.getImplementationName(), "singleton");
65
66         LogbackModuleMXBean bean = transaction.newMXBeanProxy(nameCreated, LogbackModuleMXBean.class);
67
68         assertEquals(1, bean.getConsoleAppenderTO().size());
69
70         assertEquals(1, bean.getRollingFileAppenderTO().size());
71
72         transaction.commit();
73
74         transaction = configRegistryClient.createTransaction();
75
76         nameCreated = transaction.lookupConfigBean(factory.getImplementationName(), "singleton");
77
78         bean = JMX.newMXBeanProxy(platformMBeanServer, nameCreated, LogbackModuleMXBean.class);
79
80         assertEquals(1, bean.getConsoleAppenderTO().size());
81         assertEquals(1, bean.getRollingFileAppenderTO().size());
82
83     }
84
85     /**
86      * Tests filtering loggers. Loggers inherited from ROOT logger and duplicate
87      * loggers should be removed.
88      */
89     @Test
90     public void testAllLoggers() throws InstanceAlreadyExistsException, InstanceNotFoundException {
91         ConfigTransactionJMXClient transaction = configRegistryClient.createTransaction();
92         transaction.createModule(factory.getImplementationName(), "singleton");
93
94         transaction.commit();
95
96         transaction = configRegistryClient.createTransaction();
97
98         LogbackModuleMXBean bean = JMX.newMXBeanProxy(ManagementFactory.getPlatformMBeanServer(),
99                 transaction.lookupConfigBean("logback", "singleton"), LogbackModuleMXBean.class);
100
101         assertEquals(5, bean.getLoggerTO().size());
102     }
103
104     /**
105      * Add new logger using FileAppender
106      */
107     @Test
108     public void testAddNewLogger() throws InstanceAlreadyExistsException, InstanceNotFoundException {
109
110         ConfigTransactionJMXClient transaction = configRegistryClient.createTransaction();
111         ObjectName nameCreated = transaction.createModule(factory.getImplementationName(), "singleton");
112         LogbackModuleMXBean bean = transaction.newMXBeanProxy(nameCreated, LogbackModuleMXBean.class);
113
114         assertEquals(5, bean.getLoggerTO().size());
115
116         List<LoggerTO> loggers = Lists.newArrayList(bean.getLoggerTO());
117         LoggerTO logger = new LoggerTO();
118         logger.setAppenders(Lists.newArrayList("FILE"));
119         logger.setLevel("INFO");
120         logger.setLoggerName("fileLogger");
121         loggers.add(logger);
122         bean.setLoggerTO(loggers);
123
124         transaction.commit();
125
126         transaction = configRegistryClient.createTransaction();
127         nameCreated = transaction.lookupConfigBean(factory.getImplementationName(), "singleton");
128         bean = JMX.newMXBeanProxy(platformMBeanServer, nameCreated, LogbackModuleMXBean.class);
129
130         assertEquals(6, bean.getLoggerTO().size());
131     }
132
133 }