Skip to content

Commit

Permalink
OutputHandler: result() renamed to finish() and receives whole Test i…
Browse files Browse the repository at this point in the history
…nstance (BC break)
  • Loading branch information
milo committed Jul 31, 2017
1 parent 900febd commit 64ef642
Show file tree
Hide file tree
Showing 12 changed files with 39 additions and 39 deletions.
14 changes: 7 additions & 7 deletions src/Runner/Output/ConsolePrinter.php
Expand Up @@ -51,20 +51,20 @@ public function begin()
}


public function result($testName, $result, $message)
public function finish(Test $test)
{
$outputs = [
Test::PASSED => '.',
Test::SKIPPED => 's',
Test::FAILED => Dumper::color('white/red', 'F'),
];
fwrite($this->file, $outputs[$result]);
fwrite($this->file, $outputs[$test->getResult()]);

$message = ' ' . str_replace("\n", "\n ", trim($message)) . "\n\n";
if ($result === Test::FAILED) {
$this->buffer .= Dumper::color('red', "-- FAILED: $testName") . "\n$message";
} elseif ($result === Test::SKIPPED && $this->displaySkipped) {
$this->buffer .= "-- Skipped: $testName\n$message";
$message = ' ' . str_replace("\n", "\n ", trim($test->message)) . "\n\n";
if ($test->getResult() === Test::FAILED) {
$this->buffer .= Dumper::color('red', "-- FAILED: {$test->getSignature()}") . "\n$message";
} elseif ($test->getResult() === Test::SKIPPED && $this->displaySkipped) {
$this->buffer .= "-- Skipped: {$test->getSignature()}\n$message";
}
}

Expand Down
8 changes: 4 additions & 4 deletions src/Runner/Output/JUnitPrinter.php
Expand Up @@ -44,13 +44,13 @@ public function begin()
}


public function result($testName, $result, $message)
public function finish(Test $test)
{
$this->buffer .= "\t\t<testcase classname=\"" . htmlspecialchars($testName) . '" name="' . htmlspecialchars($testName) . '"';
$this->buffer .= "\t\t<testcase classname=\"" . htmlspecialchars($test->getSignature()) . '" name="' . htmlspecialchars($test->getSignature()) . '"';

switch ($result) {
switch ($test->getResult()) {
case Test::FAILED:
$this->buffer .= ">\n\t\t\t<failure message=\"" . htmlspecialchars($message) . "\"/>\n\t\t</testcase>\n";
$this->buffer .= ">\n\t\t\t<failure message=\"" . htmlspecialchars($test->message) . "\"/>\n\t\t</testcase>\n";
break;
case Test::SKIPPED:
$this->buffer .= ">\n\t\t\t<skipped/>\n\t\t</testcase>\n";
Expand Down
12 changes: 6 additions & 6 deletions src/Runner/Output/Logger.php
Expand Up @@ -39,15 +39,15 @@ public function begin()
}


public function result($testName, $result, $message)
public function finish(Test $test)
{
$message = ' ' . str_replace("\n", "\n ", Tester\Dumper::removeColors(trim($message)));
$message = ' ' . str_replace("\n", "\n ", Tester\Dumper::removeColors(trim($test->message)));
$outputs = [
Test::PASSED => "-- OK: $testName",
Test::SKIPPED => "-- Skipped: $testName\n$message",
Test::FAILED => "-- FAILED: $testName\n$message",
Test::PASSED => "-- OK: {$test->getSignature()}",
Test::SKIPPED => "-- Skipped: {$test->getSignature()}\n$message",
Test::FAILED => "-- FAILED: {$test->getSignature()}\n$message",
];
fwrite($this->file, $outputs[$result] . "\n\n");
fwrite($this->file, $outputs[$test->getResult()] . "\n\n");
}


Expand Down
12 changes: 6 additions & 6 deletions src/Runner/Output/TapPrinter.php
Expand Up @@ -37,15 +37,15 @@ public function begin()
}


public function result($testName, $result, $message)
public function finish(Test $test)
{
$message = str_replace("\n", "\n# ", trim($message));
$message = str_replace("\n", "\n# ", trim($test->message));
$outputs = [
Test::PASSED => "ok $testName",
Test::SKIPPED => "ok $testName #skip $message",
Test::FAILED => "not ok $testName\n# $message",
Test::PASSED => "ok {$test->getSignature()}",
Test::SKIPPED => "ok {$test->getSignature()} #skip $message",
Test::FAILED => "not ok {$test->getSignature()}\n# $message",
];
fwrite($this->file, $outputs[$result] . "\n");
fwrite($this->file, $outputs[$test->getResult()] . "\n");
}


Expand Down
2 changes: 1 addition & 1 deletion src/Runner/OutputHandler.php
Expand Up @@ -17,7 +17,7 @@ interface OutputHandler
{
function begin();

function result($testName, $result, $message);
function finish(Test $test);

function end();
}
4 changes: 2 additions & 2 deletions src/Runner/Runner.php
Expand Up @@ -212,11 +212,11 @@ public function getJobCount()
* Writes to output handlers.
* @return void
*/
public function writeResult(Test $test)
public function finishTest(Test $test)
{
$this->results[$test->getResult()]++;
foreach ($this->outputHandlers as $handler) {
$handler->result($test->getSignature(), $test->getResult(), $test->message);
$handler->finish(clone $test);
}

if ($this->tempDir) {
Expand Down
6 changes: 3 additions & 3 deletions src/Runner/TestHandler.php
Expand Up @@ -56,7 +56,7 @@ public function initiate($file)
foreach (is_array($res) ? $res : [$res] as $testVariety) {
/** @var Test $testVariety */
if ($testVariety->hasResult()) {
$this->runner->writeResult($testVariety);
$this->runner->finishTest($testVariety);
} else {
$prepared[] = $testVariety;
}
Expand Down Expand Up @@ -92,12 +92,12 @@ public function assess(Job $job)
foreach ((array) $annotations[$m[1]] as $arg) {
/** @var Test|null $res */
if ($res = $this->$method($job, $arg)) {
$this->runner->writeResult($res);
$this->runner->finishTest($res);
return;
}
}
}
$this->runner->writeResult($test->withResult(Test::PASSED, $test->message));
$this->runner->finishTest($test->withResult(Test::PASSED, $test->message));
}


Expand Down
4 changes: 2 additions & 2 deletions tests/Runner/Runner.annotations.phpt
Expand Up @@ -15,9 +15,9 @@ class Logger implements Tester\Runner\OutputHandler
public $results = [];


public function result($testName, $result, $message)
public function finish(Test $test)
{
$this->results[] = [basename($testName), $result, $message];
$this->results[] = [basename($test->getFile()), $test->getResult(), $test->message];
}


Expand Down
4 changes: 2 additions & 2 deletions tests/Runner/Runner.edge.phpt
Expand Up @@ -15,9 +15,9 @@ class Logger implements Tester\Runner\OutputHandler
public $results = [];


public function result($testName, $result, $message)
public function finish(Test $test)
{
$this->results[basename($testName)] = [$result, $message];
$this->results[basename($test->getFile())] = [$test->getResult(), $test->message];
}


Expand Down
4 changes: 2 additions & 2 deletions tests/Runner/Runner.misc.phpt
Expand Up @@ -15,9 +15,9 @@ class Logger implements Tester\Runner\OutputHandler
public $results = [];


public function result($testName, $result, $message)
public function finish(Test $test)
{
$this->results[basename($testName)] = $result;
$this->results[basename($test->getFile())] = $test->getResult();
}


Expand Down
4 changes: 2 additions & 2 deletions tests/Runner/Runner.multiple-fails.phpt
Expand Up @@ -17,9 +17,9 @@ class Logger implements Tester\Runner\OutputHandler
public $results = [];


public function result($testName, $result, $message)
public function finish(Test $test)
{
$this->results[basename($testName)] = [$result, $message];
$this->results[basename($test->getFile())] = [$test->getResult(), $test->message];
}


Expand Down
4 changes: 2 additions & 2 deletions tests/Runner/Runner.stop-on-fail.phpt
Expand Up @@ -16,9 +16,9 @@ class Logger implements Tester\Runner\OutputHandler
public $results = [];


public function result($testName, $result, $message)
public function finish(Test $test)
{
$this->results[] = [$result, basename($testName)];
$this->results[] = [$test->getResult(), basename($test->getFile())];
}


Expand Down

0 comments on commit 64ef642

Please sign in to comment.