src.test.org.objectweb.howl.log.ConfigurationTest Maven / Gradle / Ivy
/*
* JOnAS: Java(TM) Open Application Server
* Copyright (C) 2004 Bull S.A.
* All rights reserved.
*
* Contact: [email protected]
*
* This software is licensed under the BSD license.
*
* 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.
*
* 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.
*
* ------------------------------------------------------------------------------
* $Id: ConfigurationTest.java,v 1.11 2005/11/15 19:39:25 girouxm Exp $
* ------------------------------------------------------------------------------
*/
package org.objectweb.howl.log;
import junit.framework.TestCase;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;
import java.util.Enumeration;
import java.util.Properties;
/**
*
* @author Michael Giroux
*/
public class ConfigurationTest extends TestCase
{
Configuration cfg = null;
Properties prop = null;
PrintStream systemErr;
private File baseDir;
private File outDir;
public static void main(String[] args) {
junit.textui.TestRunner.run(ConfigurationTest.class);
}
/*
* Start every test with a new Properties object
*
* @see TestCase#setUp()
*/
protected void setUp() throws Exception {
super.setUp();
String baseDirName = System.getProperty("basedir", ".");
baseDir = new File(baseDirName);
outDir = new File(baseDir, "target/test-resources");
outDir.mkdirs();
systemErr = System.err;
prop = new Properties();
}
/*
* @see TestCase#tearDown()
*/
protected void tearDown() throws Exception {
super.tearDown();
System.setErr(systemErr);
}
/**
* Delete log files for tests that verify behaviour
* against newly created files.
*/
protected void deleteLogFiles()
{
String logDir = cfg.getLogFileDir();
File dir = new File(logDir);
File[] logs = dir.listFiles();
String logFileName = cfg.getLogFileName();
String logFileExt = cfg.getLogFileExt();
// file name pattern for current test
String pattern = "^" + logFileName + "_" + "\\d+\\." + logFileExt;
for (int i=0; iCreates a default Configuration then modifies some properties
* and writes a new property file. Finally, constructs a Configuration
* using the file (just created) and verifies the properties to
* be the ones saved.
*
* @throws LogException
* @throws Exception
*/
public void testConstructFromFile()
throws LogException, Exception
{
// get a default configuration
cfg = new Configuration();
// define properties with non-default values
prop.setProperty("maxLogFiles", Integer.toString(cfg.getMaxLogFiles() + 1));
prop.setProperty("minBuffers", Integer.toString(cfg.getMinBuffers() + 1));
// save the Properties object to a file
File file = new File(outDir, "testConstructFromFileLog.properties");
prop.store(new FileOutputStream(file),"testConstructFromFile test properties");
// construct a new Configuration using the test properties
Configuration cfg2 = new Configuration(file);
// validate the custom values
assertEquals("maxLogFiles", cfg.getMaxLogFiles()+1, cfg2.getMaxLogFiles());
cfg.setMaxLogFiles(cfg2.getMaxLogFiles());
assertEquals("minBuffers", cfg.getMinBuffers()+1, cfg2.getMinBuffers());
cfg.setMinBuffers(cfg2.getMinBuffers());
// validate cfg2
verifyConfiguration(cfg2);
}
/**
* compare a Configuration object with this.cfg .
* @param cfg a Configuration to be compared.
*/
private void verifyConfiguration(Configuration cfg)
{
assertEquals("bufferClassName", this.cfg.getBufferClassName(), cfg.getBufferClassName());
assertEquals("bufferSize", this.cfg.getBufferSize(), cfg.getBufferSize());
assertEquals("checksumEnabled", this.cfg.isChecksumEnabled(), cfg.isChecksumEnabled());
assertEquals("flushSleepTime", this.cfg.getFlushSleepTime(), cfg.getFlushSleepTime());
assertEquals("logFileDir", this.cfg.getLogFileDir(), cfg.getLogFileDir());
assertEquals("logFileExt", this.cfg.getLogFileExt(), cfg.getLogFileExt());
assertEquals("logFileName", this.cfg.getLogFileName(), cfg.getLogFileName());
assertEquals("maxBlocksPerFile", this.cfg.getMaxBlocksPerFile(), cfg.getMaxBlocksPerFile());
assertEquals("minBuffers", this.cfg.getMinBuffers(), cfg.getMinBuffers());
assertEquals("maxBuffers", this.cfg.getMaxBuffers(), cfg.getMaxBuffers());
assertEquals("maxLogFiles", this.cfg.getMaxLogFiles(), cfg.getMaxLogFiles());
assertEquals("threadsWaitingForceThreshold", this.cfg.getThreadsWaitingForceThreshold(), cfg.getThreadsWaitingForceThreshold());
}
public void testConstructFromProperties()
throws LogException, Exception
{
cfg = new Configuration();
prop.setProperty("bufferClassName", cfg.getBufferClassName());
prop.setProperty("logFileDir", cfg.getLogFileDir());
prop.setProperty("logFileExt", cfg.getLogFileExt());
prop.setProperty("logFileName", cfg.getLogFileName());
prop.setProperty("bufferSize", Integer.toString(cfg.getBufferSize())); // BUG 300957
prop.setProperty("flushSleepTime", Integer.toString(cfg.getFlushSleepTime()));
prop.setProperty("flushPartialBuffers", Boolean.toString(cfg.isFlushPartialBuffers()));
prop.setProperty("maxLogFiles", Integer.toString(cfg.getMaxLogFiles()));
prop.setProperty("maxBlocksPerFile", Integer.toString(cfg.getMaxBlocksPerFile()));
prop.setProperty("maxBuffers", Integer.toString(cfg.getMaxBuffers()));
prop.setProperty("minBuffers", Integer.toString(cfg.getMinBuffers()));
prop.setProperty("checksumEnabled", Boolean.toString(cfg.isChecksumEnabled()));
prop.setProperty("threadsWaitingForceThreshold", Integer.toString(cfg.getThreadsWaitingForceThreshold()));
Configuration cfg2 = new Configuration(prop);
verifyConfiguration(cfg2);
}
public void testSetMethods()
throws LogException, Exception
{
cfg = new Configuration();
Configuration cfg3 = new Configuration();
cfg3.setBufferClassName(cfg.getBufferClassName());
cfg3.setLogFileDir(cfg.getLogFileDir());
cfg3.setLogFileExt(cfg.getLogFileExt());
cfg3.setLogFileName(cfg.getLogFileName());
cfg3.setBufferSize(cfg.getBufferSize()); // BUG 300957
cfg3.setMaxBlocksPerFile(cfg.getMaxBlocksPerFile());
cfg3.setMaxLogFiles(cfg.getMaxLogFiles());
cfg3.setMaxBuffers(cfg.getMaxBuffers());
cfg3.setMinBuffers(cfg.getMinBuffers());
cfg3.setChecksumEnabled(cfg.isChecksumEnabled());
cfg3.setFlushSleepTime(cfg.getFlushSleepTime());
cfg3.setThreadsWaitingForceThreshold(cfg.getThreadsWaitingForceThreshold());
cfg3.setFlushPartialBuffers(cfg.isFlushPartialBuffers());
verifyConfiguration(cfg3);
}
public void testLogFileMode()
throws LogException, Exception
{
cfg = new Configuration();
cfg.setLogFileMode("rw");
cfg.setLogFileMode("rwd");
try {
cfg.setLogFileMode("r");
fail(getName() + ": expected LogConfigurationException");
} catch (LogConfigurationException e) {
// ignore error
}
try {
cfg.setLogFileMode("RW");
fail(getName() + ": expected LogConfigurationException");
} catch (LogConfigurationException e) {
// ignore error
}
}
public void testStore() throws Exception
{
cfg = new Configuration();
File file = new File(outDir, getName() + ".properties");
cfg.store(new FileOutputStream(file));
}
public void testCallerPropertiesNotChanged() throws Exception
{
cfg = new Configuration(); // so we can extract a valid property
prop.setProperty("bufferClassName", cfg.getBufferClassName());
// Make a duplicate set of properties for compare later
Properties original = new Properties();
original.setProperty("bufferClassName", cfg.getBufferClassName());
// construct new Configuration using test Properties
cfg = new Configuration(prop);
// make sure we still have exactly one property
assertEquals(1, prop.size());
// modify Configuration object with some new properties
cfg.setBufferSize(cfg.getBufferSize() + 1); // BUG 300957
cfg.setBufferClassName(cfg.getBufferClassName() + "Sink");
// now compare the current and original properties
assertEquals(original.size(), prop.size());
for (Enumeration e = original.keys(); e.hasMoreElements(); )
{
String key = (String) e.nextElement();
assertTrue(prop.containsKey(key));
assertEquals(prop.getProperty(key), original.getProperty(key));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy