KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > net > sourceforge > cruisecontrol > LogFileTest


1 /********************************************************************************
2  * CruiseControl, a Continuous Integration Toolkit
3  * Copyright (c) 2001, ThoughtWorks, Inc.
4  * 651 W Washington Ave. Suite 600
5  * Chicago, IL 60661 USA
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * + Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  *
15  * + Redistributions in binary form must reproduce the above
16  * copyright notice, this list of conditions and the following
17  * disclaimer in the documentation and/or other materials provided
18  * with the distribution.
19  *
20  * + Neither the name of ThoughtWorks, Inc., CruiseControl, nor the
21  * names of its contributors may be used to endorse or promote
22  * products derived from this software without specific prior
23  * written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
29  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  ********************************************************************************/

37 package net.sourceforge.cruisecontrol;
38
39 import junit.framework.TestCase;
40
41 import java.io.File JavaDoc;
42 import java.io.FileWriter JavaDoc;
43 import java.io.Serializable JavaDoc;
44
45 /**
46  * @author <a HREF="mailto:hak@2mba.dk">Hack Kampbjorn</a>
47  */

48 public class LogFileTest extends TestCase {
49     private File JavaDoc logDir;
50     private File JavaDoc log1;
51     private File JavaDoc log2;
52     private File JavaDoc log3;
53
54     public void setUp() {
55         logDir = new File JavaDoc("testresults/");
56         if (!logDir.exists()) {
57             assertTrue("Failed to create test result dir", logDir.mkdir());
58         }
59         log1 = new File JavaDoc(logDir, "log20040903010203.xml");
60         log2 = new File JavaDoc(logDir, "log20040905010203Lsuccessful-build-file.1.xml");
61         log3 = new File JavaDoc(logDir, "log20051021103500.xml.gz");
62     }
63
64     public void tearDown() {
65         log1.delete();
66         log2.delete();
67         log3.delete();
68         logDir.delete();
69
70         log1 = null;
71         log2 = null;
72         log3 = null;
73         logDir = null;
74     }
75
76     public void testGetLatestLog() throws Exception JavaDoc {
77         writeFile(log1, "");
78         writeFile(log2, "");
79         writeFile(log3, "");
80
81         File JavaDoc result = LogFile.getLatestLogFile(logDir).getFile();
82         assertEquals(log3.getName(), result.getName());
83     }
84
85     public void testIsCompressed() throws Exception JavaDoc {
86         writeFile(log1, "");
87         writeFile(log2, "");
88         writeFile(log3, "");
89
90         assertFalse(new LogFile(log1).isCompressed());
91         assertFalse(new LogFile(log2).isCompressed());
92         assertTrue(new LogFile(log3).isCompressed());
93     }
94
95     public void testGetLatestSuccessfulLog() throws Exception JavaDoc {
96         writeFile(log1, "");
97         writeFile(log2, "");
98         writeFile(log3, "");
99
100         File JavaDoc result = LogFile.getLatestSuccessfulLogFile(logDir).getFile();
101         assertEquals(log2, result);
102     }
103
104     public void testSerializable() throws Exception JavaDoc {
105         writeFile(log1, "");
106
107         assertTrue("LogFile class must be serializable for Metrics Tab (charting) to work",
108                 Serializable JavaDoc.class.isAssignableFrom(LogFile.class));
109     }
110
111     private void writeFile(File JavaDoc file, String JavaDoc body) throws Exception JavaDoc {
112         FileWriter JavaDoc writer = new FileWriter JavaDoc(file);
113         writer.write(body);
114         writer.close();
115     }
116 }
117
Popular Tags