/********************************************************************************
* CruiseControl, a Continuous Integration Toolkit
* Copyright (c) 2007, ThoughtWorks, Inc.
* 200 E. Randolph, 25th Floor
* Chicago, IL 60601 USA
* 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 of ThoughtWorks, Inc., CruiseControl, 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 REGENTS 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 net.sourceforge.cruisecontrol.dashboard;
import junit.framework.TestCase;
import java.io.InputStream;
import java.io.FileInputStream;
import java.util.zip.GZIPInputStream;
import net.sourceforge.cruisecontrol.dashboard.testhelpers.DataUtils;
public class LogFileTest extends TestCase {
public void testShouldReturnFileInputStreamWhenUnzippedLogFile() throws Exception {
InputStream in = DataUtils.getPassingBuildLbuildAsFile().getInputStream();
assertTrue("Should be a FileInputStream.", in instanceof FileInputStream);
}
public void testShouldReturnGZipInputStreamWhenZippedLogFile() throws Exception {
InputStream in = DataUtils.getZippedBuildAsFile().getInputStream();
assertTrue("Should be a GZIPInputStream.", in instanceof GZIPInputStream);
}
public void testShouldComputeBuildDateTimeFromPassedLogFileName() throws Exception {
LogFile logFile = DataUtils.getPassingBuildLbuildAsFile();
assertEquals("2005-12-09 12:21.03", logFile.getDateTime());
}
public void testShouldComputeBuildDateTimeFromFailedLogFileName() throws Exception {
LogFile logFile = DataUtils.getFailedBuildLbuildAsFile();
assertEquals("2005-12-09 12:21.04", logFile.getDateTime());
}
public void testShouldThrowExceptionWhenInvalidLogFileName() throws Exception {
assertInvalidFileName("12320050312121003L1.xml");
assertInvalidFileName("12320050312121003.xml");
assertInvalidFileName("log200503121210.xml");
assertInvalidFileName("log.xml");
assertInvalidFileName("logL1.xml");
}
public void testShouldComputeLabelFromPassedLogFileName() throws Exception {
LogFile logFile = DataUtils.getPassingBuildLbuildAsFile();
assertEquals("build.489", logFile.getLabel());
LogFile zippedLogFile = new LogFile(DataUtils.PASSING_BUILD_LBUILD_0_XML + ".gz");
assertEquals("build.489", zippedLogFile.getLabel());
}
public void testShouldHaveEmptyLabelFromFailedLogFileName() throws Exception {
LogFile logFile = DataUtils.getFailedBuildLbuildAsFile();
assertEquals("", logFile.getLabel());
LogFile zippedLogFile = new LogFile(DataUtils.FAILING_BUILD_XML + ".gz");
assertEquals("", zippedLogFile.getLabel());
}
private void assertInvalidFileName(String invalidLogFileName) {
try {
new LogFile(invalidLogFileName);
fail("Should not be able to create invalid log file " + invalidLogFileName);
} catch (IllegalArgumentException e) {
assertEquals("Invalid logfile name: " + invalidLogFileName, e.getMessage());
}
}
}