/* * * Copyright (c) void.fm * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this list * of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, this * list of conditions and the following disclaimer in the documentation and/or * other materials provided with the distribution. * * Neither the name void.fm nor the names of its contributors may be * used to endorse or promote products derived from this software without specific * prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. * */ package etm.contrib.integration.spring.configuration; import etm.contrib.aggregation.log.CommonsLoggingAggregator; import etm.contrib.aggregation.log.Log4jAggregator; import etm.contrib.renderer.plugin.Log4jDumpOnShutdownPlugin; import etm.contrib.renderer.plugin.SystemOutDumpOnShutdownPlugin; import etm.core.aggregation.BufferedTimedAggregator; import etm.core.aggregation.persistence.PersistentRootAggregator; import etm.core.metadata.AggregatorMetaData; import etm.core.metadata.EtmMonitorMetaData; import etm.core.metadata.PluginMetaData; import etm.core.monitor.EtmMonitor; import etm.core.monitor.NestedMonitor; import etm.core.timer.DefaultTimer; import org.springframework.context.support.ClassPathXmlApplicationContext; import etm.contrib.integration.spring.configuration.mockup.SpringRootAggregator; /** * @author void.fm * @version $Revision$ */ public class RuntimeConfigurationTest extends ConfigurationTestCase { public void testRuntimeFeatures() { ClassPathXmlApplicationContext ctx = getContext("runtime-features.xml"); try { ctx.start(); String[] monitors = ctx.getBeanNamesForType(EtmMonitor.class); assertEquals(1, monitors.length); EtmMonitor monitor = (EtmMonitor) ctx.getBean(monitors[0]); EtmMonitorMetaData etmMonitorMetaData = monitor.getMetaData(); assertEquals(BufferedTimedAggregator.class, etmMonitorMetaData.getAggregatorMetaData().getImplementationClass()); assertEquals(Log4jAggregator.class, etmMonitorMetaData.getAggregatorMetaData().getNestedMetaData().getImplementationClass()); assertEquals(PersistentRootAggregator.class, etmMonitorMetaData.getAggregatorMetaData().getNestedMetaData().getNestedMetaData().getImplementationClass()); assertEquals(DefaultTimer.class, etmMonitorMetaData.getTimerMetaData().getImplementationClass()); } finally { ctx.destroy(); } } public void testRuntimePlugins() { ClassPathXmlApplicationContext ctx = getContext("runtime-plugin.xml"); try { ctx.start(); String[] monitors = ctx.getBeanNamesForType(EtmMonitor.class); assertEquals(1, monitors.length); EtmMonitor monitor = (EtmMonitor) ctx.getBean(monitors[0]); EtmMonitorMetaData etmMonitorMetaData = monitor.getMetaData(); assertEquals(2, etmMonitorMetaData.getPluginMetaData().size()); PluginMetaData pluginOne = (PluginMetaData) etmMonitorMetaData.getPluginMetaData().get(0); assertEquals(Log4jDumpOnShutdownPlugin.class, pluginOne.getImplementationClass()); assertEquals("fooBar", pluginOne.getProperties().get("logName")); PluginMetaData pluginTwo = (PluginMetaData) etmMonitorMetaData.getPluginMetaData().get(1); assertEquals(SystemOutDumpOnShutdownPlugin.class, pluginTwo.getImplementationClass()); } finally { ctx.stop(); } } public void testRuntimeChain() { ClassPathXmlApplicationContext ctx = getContext("runtime-chain.xml"); try { ctx.start(); String[] monitors = ctx.getBeanNamesForType(EtmMonitor.class); assertEquals(1, monitors.length); EtmMonitor monitor = (EtmMonitor) ctx.getBean(monitors[0]); assertEquals(NestedMonitor.class, monitor.getClass()); EtmMonitorMetaData etmMonitorMetaData = monitor.getMetaData(); AggregatorMetaData firstElement = etmMonitorMetaData.getAggregatorMetaData(); assertEquals(BufferedTimedAggregator.class, firstElement.getImplementationClass()); AggregatorMetaData secondElement = firstElement.getNestedMetaData(); assertEquals(CommonsLoggingAggregator.class, secondElement.getImplementationClass()); AggregatorMetaData thirdElement = secondElement.getNestedMetaData(); assertEquals(SpringRootAggregator.class, thirdElement.getImplementationClass()); } finally { ctx.stop(); } } }