mirror of
https://github.com/atlanticbiomedical/portal-legacy.git
synced 2025-07-02 01:47:28 -04:00
initial commit
This commit is contained in:
52
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestCountResultFormatter.php
vendored
Executable file
52
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestCountResultFormatter.php
vendored
Executable file
@ -0,0 +1,52 @@
|
||||
<?php
|
||||
/**
|
||||
* $Id: SimpleTestCountResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
*
|
||||
* 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';
|
||||
|
||||
/**
|
||||
* Dummy result formatter used to count SimpleTest results
|
||||
*
|
||||
* @author Michiel Rook <michiel.rook@gmail.com>
|
||||
* @version $Id: SimpleTestCountResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
* @package phing.tasks.ext.simpletest
|
||||
* @since 2.2.0
|
||||
*/
|
||||
class SimpleTestCountResultFormatter extends SimpleTestResultFormatter
|
||||
{
|
||||
const SUCCESS = 0;
|
||||
const FAILURES = 1;
|
||||
const ERRORS = 2;
|
||||
|
||||
function getRetCode()
|
||||
{
|
||||
if ($this->getExceptionCount() != 0)
|
||||
{
|
||||
return self::ERRORS;
|
||||
}
|
||||
else if ($this->getFailCount() != 0)
|
||||
{
|
||||
return self::FAILURES;
|
||||
}
|
||||
|
||||
return self::SUCCESS;
|
||||
}
|
||||
}
|
||||
?>
|
62
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestFormatterElement.php
vendored
Executable file
62
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestFormatterElement.php
vendored
Executable file
@ -0,0 +1,62 @@
|
||||
<?php
|
||||
/**
|
||||
* $Id: SimpleTestFormatterElement.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
*
|
||||
* 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/SimpleTestPlainResultFormatter.php';
|
||||
require_once 'phing/tasks/ext/simpletest/SimpleTestSummaryResultFormatter.php';
|
||||
require_once 'phing/tasks/ext/phpunit2/FormatterElement.php';
|
||||
|
||||
/**
|
||||
* Child class of "FormatterElement", overrides setType to provide other
|
||||
* formatter classes for SimpleTest
|
||||
*
|
||||
* @author Michiel Rook <michiel.rook@gmail.com>
|
||||
* @version $Id: SimpleTestFormatterElement.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
* @package phing.tasks.ext.simpletest
|
||||
* @since 2.2.0
|
||||
*/
|
||||
class SimpleTestFormatterElement extends FormatterElement
|
||||
{
|
||||
function setType($type)
|
||||
{
|
||||
$this->type = $type;
|
||||
|
||||
if ($this->type == "xml")
|
||||
{
|
||||
$destFile = new PhingFile($this->toDir, 'testsuites.xml');
|
||||
//$this->formatter = new SimpleTestXmlResultFormatter();
|
||||
}
|
||||
else
|
||||
if ($this->type == "plain")
|
||||
{
|
||||
$this->formatter = new SimpleTestPlainResultFormatter();
|
||||
}
|
||||
else
|
||||
if ($this->type == "summary")
|
||||
{
|
||||
$this->formatter = new SimpleTestSummaryResultFormatter();
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new BuildException("Formatter '" . $this->type . "' not implemented");
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
95
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestPlainResultFormatter.php
vendored
Executable file
95
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestPlainResultFormatter.php
vendored
Executable file
@ -0,0 +1,95 @@
|
||||
<?php
|
||||
/**
|
||||
* $Id: SimpleTestPlainResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
*
|
||||
* 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.rook@gmail.com>
|
||||
* @version $Id: SimpleTestPlainResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
* @package phing.tasks.ext.simpletest
|
||||
* @since 2.2.0
|
||||
*/
|
||||
class SimpleTestPlainResultFormatter extends SimpleTestResultFormatter
|
||||
{
|
||||
private $inner = "";
|
||||
|
||||
function getExtension()
|
||||
{
|
||||
return ".txt";
|
||||
}
|
||||
|
||||
function getPreferredOutfile()
|
||||
{
|
||||
return "testresults";
|
||||
}
|
||||
|
||||
function paintCaseStart($test_name)
|
||||
{
|
||||
parent::paintCaseStart($test_name);
|
||||
|
||||
$this->inner = "";
|
||||
}
|
||||
|
||||
function paintCaseEnd($test_name)
|
||||
{
|
||||
parent::paintCaseEnd($test_name);
|
||||
|
||||
/* Only count suites where more than one test was run */
|
||||
if ($this->getRunCount())
|
||||
{
|
||||
$sb.= "Testsuite: $test_name\n";
|
||||
$sb.= "Tests run: " . $this->getRunCount();
|
||||
$sb.= ", Failures: " . $this->getFailureCount();
|
||||
$sb.= ", Errors: " . $this->getErrorCount();
|
||||
$sb.= ", Time elapsed: " . $this->getElapsedTime();
|
||||
$sb.= " sec\n";
|
||||
|
||||
if ($this->out != NULL)
|
||||
{
|
||||
$this->out->write($sb);
|
||||
$this->out->write($this->inner);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
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)
|
||||
{
|
||||
$this->inner.= $this->getTestName() . " " . $type . "\n";
|
||||
$this->inner.= $message . "\n";
|
||||
}
|
||||
}
|
||||
?>
|
162
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestResultFormatter.php
vendored
Executable file
162
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestResultFormatter.php
vendored
Executable file
@ -0,0 +1,162 @@
|
||||
<?php
|
||||
/**
|
||||
* $Id: SimpleTestResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
*
|
||||
* 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 'simpletest/scorer.php';
|
||||
|
||||
require_once 'phing/system/io/Writer.php';
|
||||
|
||||
/**
|
||||
* This abstract class describes classes that format the results of a SimpleTest testrun.
|
||||
*
|
||||
* @author Michiel Rook <michiel.rook@gmail.com>
|
||||
* @version $Id: SimpleTestResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
* @package phing.tasks.ext.phpunit2
|
||||
* @since 2.2.0
|
||||
*/
|
||||
abstract class SimpleTestResultFormatter extends SimpleReporter
|
||||
{
|
||||
protected $out = NULL;
|
||||
|
||||
protected $project = NULL;
|
||||
|
||||
private $timer = NULL;
|
||||
|
||||
private $runCount = 0;
|
||||
|
||||
private $failureCount = 0;
|
||||
|
||||
private $errorCount = 0;
|
||||
|
||||
private $currentTest = "";
|
||||
|
||||
/**
|
||||
* Sets the writer the formatter is supposed to write its results to.
|
||||
*/
|
||||
function setOutput(Writer $out)
|
||||
{
|
||||
$this->out = $out;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the extension used for this formatter
|
||||
*
|
||||
* @return string the extension
|
||||
*/
|
||||
function getExtension()
|
||||
{
|
||||
return "";
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the project
|
||||
*
|
||||
* @param Project the project
|
||||
*/
|
||||
function setProject(Project $project)
|
||||
{
|
||||
$this->project = $project;
|
||||
}
|
||||
|
||||
function getPreferredOutfile()
|
||||
{
|
||||
return "";
|
||||
}
|
||||
|
||||
function paintMethodStart($test_name)
|
||||
{
|
||||
parent::paintMethodStart($test_name);
|
||||
|
||||
$this->currentTest = $test_name;
|
||||
}
|
||||
|
||||
function paintMethodEnd($test_name)
|
||||
{
|
||||
parent::paintMethodEnd($test_name);
|
||||
|
||||
$this->runCount++;
|
||||
}
|
||||
|
||||
function paintCaseStart($test_name)
|
||||
{
|
||||
parent::paintCaseStart($test_name);
|
||||
|
||||
$this->runCount = 0;
|
||||
$this->failureCount = 0;
|
||||
$this->errorCount = 0;
|
||||
|
||||
$this->timer = new Timer();
|
||||
$this->timer->start();
|
||||
}
|
||||
|
||||
function paintCaseEnd($test_name)
|
||||
{
|
||||
parent::paintCaseEnd($test_name);
|
||||
|
||||
$this->timer->stop();
|
||||
}
|
||||
|
||||
function paintError($message)
|
||||
{
|
||||
parent::paintError($message);
|
||||
|
||||
$this->errorCount++;
|
||||
}
|
||||
|
||||
function paintFail($message)
|
||||
{
|
||||
parent::paintFail($message);
|
||||
|
||||
$this->failureCount++;
|
||||
}
|
||||
|
||||
function getRunCount()
|
||||
{
|
||||
return $this->runCount;
|
||||
}
|
||||
|
||||
function getFailureCount()
|
||||
{
|
||||
return $this->failureCount;
|
||||
}
|
||||
|
||||
function getErrorCount()
|
||||
{
|
||||
return $this->errorCount;
|
||||
}
|
||||
|
||||
function getTestName()
|
||||
{
|
||||
return $this->currentTest;
|
||||
}
|
||||
|
||||
function getElapsedTime()
|
||||
{
|
||||
if ($this->timer)
|
||||
{
|
||||
return $this->timer->getElapsedTime();
|
||||
}
|
||||
else
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
54
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestSummaryResultFormatter.php
vendored
Executable file
54
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestSummaryResultFormatter.php
vendored
Executable file
@ -0,0 +1,54 @@
|
||||
<?php
|
||||
/**
|
||||
* $Id: SimpleTestSummaryResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
*
|
||||
* 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 short summary output of the test to Phing's logging system.
|
||||
*
|
||||
* @author Michiel Rook <michiel.rook@gmail.com>
|
||||
* @version $Id: SimpleTestSummaryResultFormatter.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
* @package phing.tasks.ext.simpletest
|
||||
* @since 2.2.0
|
||||
*/
|
||||
class SimpleTestSummaryResultFormatter extends SimpleTestResultFormatter
|
||||
{
|
||||
function paintCaseEnd($test_name)
|
||||
{
|
||||
parent::paintCaseEnd($test_name);
|
||||
|
||||
/* Only count suites where more than one test was run */
|
||||
if ($this->getRunCount())
|
||||
{
|
||||
$sb.= "Tests run: " . $this->getRunCount();
|
||||
$sb.= ", Failures: " . $this->getFailureCount();
|
||||
$sb.= ", Errors: " . $this->getErrorCount();
|
||||
$sb.= ", Time elapsed: " . $this->getElapsedTime();
|
||||
$sb.= " sec\n";
|
||||
|
||||
if ($this->out != NULL)
|
||||
{
|
||||
$this->out->write($sb);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
238
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestTask.php
vendored
Executable file
238
lib/symfony/vendor/phing/tasks/ext/simpletest/SimpleTestTask.php
vendored
Executable file
@ -0,0 +1,238 @@
|
||||
<?php
|
||||
/**
|
||||
* $Id: SimpleTestTask.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
*
|
||||
* 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/Task.php';
|
||||
require_once 'phing/system/io/PhingFile.php';
|
||||
require_once 'phing/system/io/Writer.php';
|
||||
require_once 'phing/util/LogWriter.php';
|
||||
|
||||
/**
|
||||
* Runs SimpleTest tests.
|
||||
*
|
||||
* @author Michiel Rook <michiel.rook@gmail.com>
|
||||
* @version $Id: SimpleTestTask.php 3076 2006-12-18 08:52:12Z fabien $
|
||||
* @package phing.tasks.ext.simpletest
|
||||
* @since 2.2.0
|
||||
*/
|
||||
class SimpleTestTask extends Task
|
||||
{
|
||||
private $formatters = array();
|
||||
private $haltonerror = false;
|
||||
private $haltonfailure = false;
|
||||
private $failureproperty;
|
||||
private $errorproperty;
|
||||
private $printsummary = false;
|
||||
private $testfailed = false;
|
||||
|
||||
/**
|
||||
* Initialize Task.
|
||||
* This method includes any necessary SimpleTest libraries and triggers
|
||||
* appropriate error if they cannot be found. This is not done in header
|
||||
* because we may want this class to be loaded w/o triggering an error.
|
||||
*/
|
||||
function init() {
|
||||
@include_once 'simpletest/scorer.php';
|
||||
|
||||
if (!class_exists('SimpleReporter')) {
|
||||
throw new BuildException("SimpleTestTask depends on SimpleTest package being installed.", $this->getLocation());
|
||||
}
|
||||
|
||||
require_once 'simpletest/reporter.php';
|
||||
require_once 'simpletest/xml.php';
|
||||
require_once 'simpletest/test_case.php';
|
||||
require_once 'phing/tasks/ext/simpletest/SimpleTestCountResultFormatter.php';
|
||||
require_once 'phing/tasks/ext/simpletest/SimpleTestFormatterElement.php';
|
||||
}
|
||||
|
||||
function setFailureproperty($value)
|
||||
{
|
||||
$this->failureproperty = $value;
|
||||
}
|
||||
|
||||
function setErrorproperty($value)
|
||||
{
|
||||
$this->errorproperty = $value;
|
||||
}
|
||||
|
||||
function setHaltonerror($value)
|
||||
{
|
||||
$this->haltonerror = $value;
|
||||
}
|
||||
|
||||
function setHaltonfailure($value)
|
||||
{
|
||||
$this->haltonfailure = $value;
|
||||
}
|
||||
|
||||
function setPrintsummary($printsummary)
|
||||
{
|
||||
$this->printsummary = $printsummary;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a new formatter to all tests of this task.
|
||||
*
|
||||
* @param SimpleTestFormatterElement formatter element
|
||||
*/
|
||||
function addFormatter(SimpleTestFormatterElement $fe)
|
||||
{
|
||||
$this->formatters[] = $fe;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a new fileset containing the XML results to aggregate
|
||||
*
|
||||
* @param FileSet the new fileset containing XML results.
|
||||
*/
|
||||
function addFileSet(FileSet $fileset)
|
||||
{
|
||||
$this->filesets[] = $fileset;
|
||||
}
|
||||
|
||||
/**
|
||||
* Iterate over all filesets and return the filename of all files
|
||||
* that end with .php.
|
||||
*
|
||||
* @return array an array of filenames
|
||||
*/
|
||||
private function getFilenames()
|
||||
{
|
||||
$filenames = array();
|
||||
|
||||
foreach ($this->filesets as $fileset)
|
||||
{
|
||||
$ds = $fileset->getDirectoryScanner($this->project);
|
||||
$ds->scan();
|
||||
|
||||
$files = $ds->getIncludedFiles();
|
||||
|
||||
foreach ($files as $file)
|
||||
{
|
||||
if (strstr($file, ".php"))
|
||||
{
|
||||
$filenames[] = $ds->getBaseDir() . "/" . $file;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $filenames;
|
||||
}
|
||||
|
||||
/**
|
||||
* The main entry point
|
||||
*
|
||||
* @throws BuildException
|
||||
*/
|
||||
function main()
|
||||
{
|
||||
$group = new GroupTest();
|
||||
|
||||
$filenames = $this->getFilenames();
|
||||
|
||||
foreach ($filenames as $testfile)
|
||||
{
|
||||
$group->addTestFile($testfile);
|
||||
}
|
||||
|
||||
if ($this->printsummary)
|
||||
{
|
||||
$fe = new SimpleTestFormatterElement();
|
||||
$fe->setType('summary');
|
||||
$fe->setUseFile(false);
|
||||
$this->formatters[] = $fe;
|
||||
}
|
||||
|
||||
foreach ($this->formatters as $fe)
|
||||
{
|
||||
$formatter = $fe->getFormatter();
|
||||
$formatter->setProject($this->getProject());
|
||||
|
||||
if ($fe->getUseFile())
|
||||
{
|
||||
$destFile = new PhingFile($fe->getToDir(), $fe->getOutfile());
|
||||
|
||||
$writer = new FileWriter($destFile->getAbsolutePath());
|
||||
|
||||
$formatter->setOutput($writer);
|
||||
}
|
||||
else
|
||||
{
|
||||
$formatter->setOutput($this->getDefaultOutput());
|
||||
}
|
||||
}
|
||||
|
||||
$this->execute($group);
|
||||
|
||||
if ($this->testfailed)
|
||||
{
|
||||
throw new BuildException("One or more tests failed");
|
||||
}
|
||||
}
|
||||
|
||||
private function execute($suite)
|
||||
{
|
||||
$counter = new SimpleTestCountResultFormatter();
|
||||
$reporter = new MultipleReporter();
|
||||
$reporter->attachReporter($counter);
|
||||
|
||||
foreach ($this->formatters as $fe)
|
||||
{
|
||||
$formatter = $fe->getFormatter();
|
||||
|
||||
$reporter->attachReporter($formatter);
|
||||
}
|
||||
|
||||
$suite->run($reporter);
|
||||
|
||||
$retcode = $counter->getRetCode();
|
||||
|
||||
if ($retcode == SimpleTestCountResultFormatter::ERRORS)
|
||||
{
|
||||
if ($this->errorproperty)
|
||||
{
|
||||
$this->project->setNewProperty($this->errorproperty, true);
|
||||
}
|
||||
|
||||
if ($this->haltonerror)
|
||||
{
|
||||
$this->testfailed = true;
|
||||
}
|
||||
}
|
||||
elseif ($retcode == SimpleTestCountResultFormatter::FAILURES)
|
||||
{
|
||||
if ($this->failureproperty)
|
||||
{
|
||||
$this->project->setNewProperty($this->failureproperty, true);
|
||||
}
|
||||
|
||||
if ($this->haltonfailure)
|
||||
{
|
||||
$this->testfailed = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private function getDefaultOutput()
|
||||
{
|
||||
return new LogWriter($this);
|
||||
}
|
||||
}
|
||||
?>
|
Reference in New Issue
Block a user