Merge "Resolve Bug:853 - remove groovy from config code generator."
[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 ch.qos.logback.classic.LoggerContext;
11 import ch.qos.logback.classic.joran.JoranConfigurator;
12 import ch.qos.logback.core.joran.spi.JoranException;
13 import com.google.common.collect.Lists;
14 import org.apache.commons.io.FileUtils;
15 import org.junit.Before;
16 import org.junit.Test;
17 import org.opendaylight.controller.config.api.ConflictingVersionException;
18 import org.opendaylight.controller.config.api.ValidationException;
19 import org.opendaylight.controller.config.manager.impl.AbstractConfigTest;
20 import org.opendaylight.controller.config.manager.impl.factoriesresolver.HardcodedModuleFactoriesResolver;
21 import org.opendaylight.controller.config.util.ConfigTransactionJMXClient;
22 import org.slf4j.LoggerFactory;
23
24 import javax.management.InstanceAlreadyExistsException;
25 import javax.management.InstanceNotFoundException;
26 import javax.management.JMX;
27 import javax.management.MalformedObjectNameException;
28 import javax.management.ObjectName;
29 import java.io.File;
30 import java.io.IOException;
31 import java.lang.management.ManagementFactory;
32 import java.util.List;
33
34 import static org.junit.Assert.assertEquals;
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(mockedContext,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      * @throws MalformedObjectNameException
61      */
62     @Test
63     public void test() throws InstanceAlreadyExistsException, InstanceNotFoundException, MalformedObjectNameException, ValidationException, ConflictingVersionException {
64
65         ConfigTransactionJMXClient transaction = configRegistryClient.createTransaction();
66         ObjectName nameRetrieved = transaction.lookupConfigBean(factory.getImplementationName(), LogbackModuleFactory.INSTANCE_NAME);
67
68         LogbackModuleMXBean bean = transaction.newMXBeanProxy(nameRetrieved, LogbackModuleMXBean.class);
69
70         assertEquals(1, bean.getConsoleAppenderTO().size());
71
72         assertEquals(1, bean.getRollingFileAppenderTO().size());
73
74         transaction.commit();
75
76         transaction = configRegistryClient.createTransaction();
77
78         nameRetrieved = transaction.lookupConfigBean(factory.getImplementationName(), "singleton");
79
80         bean = JMX.newMXBeanProxy(platformMBeanServer, nameRetrieved, LogbackModuleMXBean.class);
81
82         assertEquals(1, bean.getConsoleAppenderTO().size());
83         assertEquals(1, bean.getRollingFileAppenderTO().size());
84
85     }
86
87     /**
88      * Tests filtering loggers. Loggers inherited from ROOT logger and duplicate
89      * loggers should be removed.
90      */
91     @Test
92     public void testAllLoggers() throws InstanceAlreadyExistsException, InstanceNotFoundException {
93         ConfigTransactionJMXClient transaction = configRegistryClient.createTransaction();
94
95         LogbackModuleMXBean bean = JMX.newMXBeanProxy(ManagementFactory.getPlatformMBeanServer(),
96                 transaction.lookupConfigBean("logback", "singleton"), LogbackModuleMXBean.class);
97
98         assertEquals(5, bean.getLoggerTO().size());
99     }
100
101     /**
102      * Add new logger using FileAppender
103      *
104      * @throws MalformedObjectNameException
105      */
106     @Test
107     public void testAddNewLogger() throws InstanceAlreadyExistsException, InstanceNotFoundException,
108             MalformedObjectNameException, ValidationException, ConflictingVersionException {
109
110         ConfigTransactionJMXClient transaction = configRegistryClient.createTransaction();
111         ObjectName nameRetrieved = transaction.lookupConfigBean(factory.getImplementationName(), LogbackModuleFactory.INSTANCE_NAME);
112         LogbackModuleMXBean bean = transaction.newMXBeanProxy(nameRetrieved, 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         nameRetrieved = transaction.lookupConfigBean(factory.getImplementationName(), "singleton");
128         bean = JMX.newMXBeanProxy(platformMBeanServer, nameRetrieved, LogbackModuleMXBean.class);
129
130         assertEquals(6, bean.getLoggerTO().size());
131     }
132
133 }