mirror of
https://github.com/Seldaek/monolog.git
synced 2025-10-24 10:06:08 +02:00
Include stacktraces for "previous" excpetions in LineFormatter
This commit is contained in:
@@ -126,18 +126,14 @@ class LineFormatter extends NormalizerFormatter
|
|||||||
|
|
||||||
protected function normalizeException(\Throwable $e, int $depth = 0): string
|
protected function normalizeException(\Throwable $e, int $depth = 0): string
|
||||||
{
|
{
|
||||||
$previousText = '';
|
$str = $this->formatException($e);
|
||||||
|
|
||||||
if ($previous = $e->getPrevious()) {
|
if ($previous = $e->getPrevious()) {
|
||||||
do {
|
do {
|
||||||
$previousText .= ', '.get_class($previous).'(code: '.$previous->getCode().'): '.$previous->getMessage().' at '.$previous->getFile().':'.$previous->getLine();
|
$str .= "\n[previous exception] " . $this->formatException($previous);
|
||||||
} while ($previous = $previous->getPrevious());
|
} while ($previous = $previous->getPrevious());
|
||||||
}
|
}
|
||||||
|
|
||||||
$str = '[object] ('.get_class($e).'(code: '.$e->getCode().'): '.$e->getMessage().' at '.$e->getFile().':'.$e->getLine().$previousText.')';
|
|
||||||
if ($this->includeStacktraces) {
|
|
||||||
$str .= "\n[stacktrace]\n".$e->getTraceAsString()."\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $str;
|
return $str;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -166,4 +162,14 @@ class LineFormatter extends NormalizerFormatter
|
|||||||
|
|
||||||
return str_replace(["\r\n", "\r", "\n"], ' ', $str);
|
return str_replace(["\r\n", "\r", "\n"], ' ', $str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function formatException(\Throwable $e): string
|
||||||
|
{
|
||||||
|
$str = '[object] (' . get_class($e) . '(code: ' . $e->getCode() . '): ' . $e->getMessage() . ' at ' . $e->getFile() . ':' . $e->getLine() . ')';
|
||||||
|
if ($this->includeStacktraces) {
|
||||||
|
$str .= "\n[stacktrace]\n" . $e->getTraceAsString() . "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $str;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -170,7 +170,7 @@ class LineFormatterTest extends \PHPUnit\Framework\TestCase
|
|||||||
|
|
||||||
$path = str_replace('\\/', '/', json_encode(__FILE__));
|
$path = str_replace('\\/', '/', json_encode(__FILE__));
|
||||||
|
|
||||||
$this->assertEquals('['.date('Y-m-d').'] core.CRITICAL: foobar {"exception":"[object] (RuntimeException(code: 0): Foo at '.substr($path, 1, -1).':'.(__LINE__ - 8).', LogicException(code: 0): Wut? at '.substr($path, 1, -1).':'.(__LINE__ - 12).')"} []'."\n", $message);
|
$this->assertEquals('['.date('Y-m-d').'] core.CRITICAL: foobar {"exception":"[object] (RuntimeException(code: 0): Foo at '.substr($path, 1, -1).':'.(__LINE__ - 8).')\n[previous exception] [object] (LogicException(code: 0): Wut? at '.substr($path, 1, -1).':'.(__LINE__ - 12).')"} []'."\n", $message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testBatchFormat()
|
public function testBatchFormat()
|
||||||
|
Reference in New Issue
Block a user