001: /********************************************************************************
002: * CruiseControl, a Continuous Integration Toolkit
003: * Copyright (c) 2007, ThoughtWorks, Inc.
004: * 200 E. Randolph, 25th Floor
005: * Chicago, IL 60601 USA
006: * All rights reserved.
007: *
008: * Redistribution and use in source and binary forms, with or without
009: * modification, are permitted provided that the following conditions
010: * are met:
011: *
012: * + Redistributions of source code must retain the above copyright
013: * notice, this list of conditions and the following disclaimer.
014: *
015: * + Redistributions in binary form must reproduce the above
016: * copyright notice, this list of conditions and the following
017: * disclaimer in the documentation and/or other materials provided
018: * with the distribution.
019: *
020: * + Neither the name of ThoughtWorks, Inc., CruiseControl, nor the
021: * names of its contributors may be used to endorse or promote
022: * products derived from this software without specific prior
023: * written permission.
024: *
025: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
026: * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
027: * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
028: * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
029: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
030: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
031: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
032: * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
033: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
034: * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
035: * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
036: ********************************************************************************/package net.sourceforge.cruisecontrol.dashboard.web.command;
037:
038: import junit.framework.TestCase;
039: import net.sourceforge.cruisecontrol.dashboard.BuildSummary;
040: import net.sourceforge.cruisecontrol.dashboard.PreviousResult;
041: import net.sourceforge.cruisecontrol.dashboard.testhelpers.DataUtils;
042:
043: import org.apache.commons.lang.StringUtils;
044:
045: public class CCTrayBuildSummaryAdapterTest extends TestCase {
046:
047: public void testShouldConvertPassedWaiting() throws Exception {
048: BuildSummary summary = new BuildSummary("project1",
049: PreviousResult.PASSED,
050: DataUtils.PASSING_BUILD_LBUILD_0_XML);
051: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
052: "", summary);
053: assertEquals("Sleeping", adapter.getActivity());
054: assertEquals("Success", adapter.getLastBuildStatus());
055: }
056:
057: public void testShouldConvertPassedFailed() throws Exception {
058: BuildSummary summary = new BuildSummary("project1",
059: PreviousResult.FAILED, DataUtils.FAILING_BUILD_XML);
060: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
061: "", summary);
062: assertEquals("Sleeping", adapter.getActivity());
063: assertEquals("Failure", adapter.getLastBuildStatus());
064: }
065:
066: public void testShouldConvertPassedBootstrapping() throws Exception {
067: BuildSummary summary = new BuildSummary("project1",
068: PreviousResult.PASSED,
069: DataUtils.PASSING_BUILD_LBUILD_0_XML);
070: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
071: "", summary);
072: summary.updateStatus("bootstrapping");
073: assertEquals("CheckingModifications", adapter.getActivity());
074: assertEquals("Success", adapter.getLastBuildStatus());
075: }
076:
077: public void testShouldConvertCheckingModifications()
078: throws Exception {
079: BuildSummary summary = new BuildSummary("project1",
080: PreviousResult.PASSED,
081: DataUtils.PASSING_BUILD_LBUILD_0_XML);
082: summary.updateStatus("checking for modifications");
083: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
084: "", summary);
085: assertEquals("CheckingModifications", adapter.getActivity());
086: }
087:
088: public void testShouldConvertBuilding() throws Exception {
089: BuildSummary summary = new BuildSummary("project1",
090: PreviousResult.PASSED,
091: DataUtils.PASSING_BUILD_LBUILD_0_XML);
092: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
093: "", summary);
094: summary.updateStatus("now building since 20070420170000");
095: assertEquals("Building", adapter.getActivity());
096: }
097:
098: public void testShouldProvideDateInCorrectFormat() throws Exception {
099: String passingLogFile = "log20070504145400Lbuild.1.xml";
100: BuildSummary summary = new BuildSummary("project1",
101: PreviousResult.PASSED, passingLogFile);
102: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
103: "", summary);
104: // TODO: We should really return the timzone, too
105: assertEquals("2007-05-04T14:54:00", adapter.getLastBuildTime());
106: }
107:
108: public void testShouldProvideXmlOnCCTrayFormate() throws Exception {
109: String passingLogFile = "log20051209122103Lbuild1.xml";
110: BuildSummary summary = new BuildSummary("project1",
111: PreviousResult.PASSED, passingLogFile);
112: CCTrayBuildSummaryAdapter adapter = new CCTrayBuildSummaryAdapter(
113: "http://localhost:8080/dashboard/", summary);
114: String xml = adapter.toXml();
115: assertTrue(StringUtils.contains(xml, "name=\"project1\""));
116: assertTrue(StringUtils.contains(xml, "activity=\"Sleeping\""));
117: assertTrue(StringUtils.contains(xml,
118: "lastBuildStatus=\"Success\""));
119: assertTrue(StringUtils.contains(xml,
120: "lastBuildLabel=\"build1\""));
121: assertTrue(StringUtils.contains(xml,
122: "lastBuildTime=\"2005-12-09T12:21:03"));
123: assertTrue(StringUtils
124: .contains(xml,
125: "webUrl=\"http://localhost:8080/dashboard/tab/build/detail/project1"));
126:
127: }
128: }
|