summaryrefslogtreecommitdiff
path: root/buildscripts/phing/classes/phing/tasks/ext/simpletest/SimpleTestXmlResultFormatter.php
diff options
context:
space:
mode:
Diffstat (limited to 'buildscripts/phing/classes/phing/tasks/ext/simpletest/SimpleTestXmlResultFormatter.php')
-rw-r--r--buildscripts/phing/classes/phing/tasks/ext/simpletest/SimpleTestXmlResultFormatter.php154
1 files changed, 154 insertions, 0 deletions
diff --git a/buildscripts/phing/classes/phing/tasks/ext/simpletest/SimpleTestXmlResultFormatter.php b/buildscripts/phing/classes/phing/tasks/ext/simpletest/SimpleTestXmlResultFormatter.php
new file mode 100644
index 00000000..66c4ccd8
--- /dev/null
+++ b/buildscripts/phing/classes/phing/tasks/ext/simpletest/SimpleTestXmlResultFormatter.php
@@ -0,0 +1,154 @@
+<?php
+/**
+ * $Id: SimpleTestPlainResultFormatter.php 59 2006-04-28 14:49:47Z mrook $
+ *
+ * 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.
+ *
+ * This software consists of voluntary contributions made by many individuals
+ * and is licensed under the LGPL. For more information please see
+ * <http://phing.info>.
+ */
+
+require_once 'phing/tasks/ext/simpletest/SimpleTestResultFormatter.php';
+
+/**
+ * Prints plain text output of the test to a specified Writer.
+ *
+ * @author Michiel Rook <michiel@trendserver.nl>
+ * @version $Id: SimpleTestPlainResultFormatter.php 59 2006-04-28 14:49:47Z mrook $
+ * @package phing.tasks.ext.simpletest
+ * @since 2.2.0
+ */
+class SimpleTestXmlResultFormatter extends SimpleTestResultFormatter
+{
+ private $results=array();
+ private $currentSuite;
+ private $currentTest;
+ private $methodCounts=0;
+ private $methodTime=0;
+
+ function paintFooter($test_name)
+ {
+ if($test_name=='GroupTest')
+ $this->printXml($test_name);
+ }
+
+ protected function printXml($test_name)
+ {
+ $suites = $this->printXmlSuites($this->results);
+$content = <<<EOD
+<?xml version="1.0" encoding="UTF-8"?>
+<testsuites total="{$this->getRunCount()}" name="{$test_name}">
+$suites
+</testsuites>
+EOD;
+ $this->out->write($content);
+ }
+
+ protected function printXmlSuites($results)
+ {
+ $contents = '';
+ foreach($results as $suiteName => $suite)
+ {
+ $tests = $this->printXmlTests($suite['tests'],$suiteName);
+$contents .= <<<EOD
+<testsuite name="{$suiteName}" tests="{$suite['total']}" failures="{$suite['failures']}" errors="{$suite['errors']}" time="{$suite['time']}">
+ $tests
+</testsuite>
+EOD;
+ }
+ return $contents;
+ }
+
+ protected function printXmlTests($tests,$suiteName)
+ {
+ $contents = '';
+ foreach($tests as $name => $result)
+ {
+ if(count($result['results'])==0)
+ {
+ $contents .= <<<EOD
+<testcase name="{$name}" class="{$suiteName}" result="success" time="{$result['time']}"/>
+EOD;
+ }
+ else
+ {
+ $type = strtolower($result['results']['type']);
+ $message = htmlspecialchars($result['results']['message']);
+$contents .= <<<EOD
+<testcase name="{$name}" class="{$suiteName}" result="{$type}" time="{$result['time']}">
+ <{$type}>$message</{$type}>
+</testcase>
+EOD;
+ }
+ }
+ return $contents;
+ }
+
+ function paintCaseStart($test_name)
+ {
+ parent::paintCaseStart($test_name);
+ $this->results[$test_name] = array('tests'=>array());
+ $this->currentSuite=$test_name;
+ $this->methodCounts=0;
+ }
+
+ function paintCaseEnd($test_name)
+ {
+ parent::paintCaseEnd($test_name);
+ $details = array(
+ 'total' => $this->methodCounts,
+ 'failures' => $this->getFailureCount(),
+ 'errors' => $this->getErrorCount(),
+ 'time' => $this->getElapsedTime());
+
+ $this->results[$test_name] = array_merge($this->results[$test_name],$details);
+ }
+
+ function paintMethodStart($test_name)
+ {
+ $this->currentTest=$test_name;
+ parent::paintMethodStart($test_name);
+ $this->results[$this->currentSuite]['tests'][$test_name]['results'] = array();
+ $this->methodCounts++;
+ $this->methodTime = new Timer();
+ $this->methodTime->start();
+ }
+
+ function paintMethodEnd($test_name)
+ {
+ parent::paintMethodEnd($test_name);
+ $this->methodTime->stop();
+ $this->results[$this->currentSuite]['tests'][$test_name]['time'] = $this->methodTime->getElapsedTime();
+ }
+
+ function paintError($message)
+ {
+ parent::paintError($message);
+ $this->formatError("ERROR", $message);
+ }
+
+ function paintFail($message)
+ {
+ parent::paintFail($message);
+ $this->formatError("FAILED", $message);
+ }
+
+ private function formatError($type, $message)
+ {
+ $result = array('type'=>$type, 'message' => $message);
+ $this->results[$this->currentSuite]['tests'][$this->currentTest]['results'] =
+ $result;
+ }
+}
+?> \ No newline at end of file