2017-05-11 17:38:29 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\Logging\Tests;
|
|
|
|
|
|
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
use SilverStripe\Logging\DetailedErrorFormatter;
|
|
|
|
use SilverStripe\Logging\Tests\DetailedErrorFormatterTest\ErrorGenerator;
|
|
|
|
|
|
|
|
class DetailedErrorFormatterTest extends SapphireTest
|
|
|
|
{
|
|
|
|
public function testFormat()
|
|
|
|
{
|
|
|
|
$generator = new ErrorGenerator();
|
|
|
|
$formatter = new DetailedErrorFormatter();
|
|
|
|
$exception = $generator->mockException();
|
|
|
|
|
2018-01-16 18:39:30 +00:00
|
|
|
$output = '' . $formatter->format(['context' => [
|
2017-05-11 17:38:29 +12:00
|
|
|
'exception' => $exception,
|
|
|
|
]]);
|
|
|
|
|
|
|
|
$base = __DIR__;
|
|
|
|
$this->assertContains('ERROR [Emergency]: Uncaught Exception: Error', $output);
|
|
|
|
$this->assertContains("Line 32 in $base/DetailedErrorFormatterTest/ErrorGenerator.php", $output);
|
|
|
|
$this->assertContains('* 32: throw new Exception(\'Error\');', $output);
|
|
|
|
$this->assertContains(
|
|
|
|
'SilverStripe\\Logging\\Tests\\DetailedErrorFormatterTest\\ErrorGenerator->mockException(4)',
|
|
|
|
$output
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|