mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 02:26:16 +02:00 
			
		
		
		
	Merge pull request #1170 from mpdude/include_trace_for_previous
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