Wenn ich einen PHPUnit-Test durchführe, möchte ich in der Lage sein, die Ausgabe zu sichern, damit ich ein oder zwei Dinge debuggen kann.
Ich habe Folgendes versucht (ähnlich dem Beispiel im PHPUnit-Handbuch );
class theTest extends PHPUnit_Framework_TestCase
{
/**
* @outputBuffering disabled
*/
public function testOutput() {
print_r("Hello World");
print "Ping";
echo "Pong";
$out = "Foo";
var_dump($out);
}
}
Mit folgendem Ergebnis:
PHPUnit @package_version@ by Sebastian Bergmann.
.
Time: 0 seconds, Memory: 3.00Mb
OK (1 test, 0 assertions)
Beachten Sie, dass keine der erwarteten Ausgaben vorhanden ist.
Ich verwende die HEAD-Versionen der Git-Repos vom 19. September 2011.
Ausgabe von php -version
:
$ php -version
PHP 5.2.9 (cli) (built: Dec 8 2010 11:36:37)
Copyright (c) 1997-2009 The PHP Group
Zend Engine v2.2.0, Copyright (c) 1998-2009 Zend Technologies
with Xdebug v2.1.0, Copyright (c) 2002-2010, by Derick Rethans
Gibt es irgendetwas, was ich falsch mache, oder ist dies möglicherweise ein PHPUnit-Fehler?
phpunit /path/to/tests/theTest.php
(wenn die obige Klasse in der Datei enthalten ist theTest.php
).
ob_get_level()
kehrt zurück 1
. Dem widerspricht jedoch der folgende Code: while (ob_get_level() > 0) { ob_end_flush(); }
welche Fehler mit ob_end_clean(): failed to delete buffer. No buffer to delete.
. Neugieriger und neugieriger.
testOutput()
Methode aufruft ?