mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 18:46:14 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			159 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of the Monolog package.
 | |
|  *
 | |
|  * (c) Jordi Boggiano <j.boggiano@seld.be>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Monolog\Formatter;
 | |
| 
 | |
| use Monolog\Logger;
 | |
| 
 | |
| class ChromePHPFormatterTest extends \PHPUnit_Framework_TestCase
 | |
| {
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\ChromePHPFormatter::format
 | |
|      */
 | |
|     public function testDefaultFormat()
 | |
|     {
 | |
|         $formatter = new ChromePHPFormatter();
 | |
|         $record = array(
 | |
|             'level' => Logger::ERROR,
 | |
|             'level_name' => 'ERROR',
 | |
|             'channel' => 'meh',
 | |
|             'context' => array('from' => 'logger'),
 | |
|             'datetime' => new \DateTime("@0"),
 | |
|             'extra' => array('ip' => '127.0.0.1'),
 | |
|             'message' => 'log',
 | |
|         );
 | |
| 
 | |
|         $message = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 'meh',
 | |
|                 array(
 | |
|                     'message' => 'log',
 | |
|                     'context' => array('from' => 'logger'),
 | |
|                     'extra' => array('ip' => '127.0.0.1'),
 | |
|                 ),
 | |
|                 'unknown',
 | |
|                 'error',
 | |
|             ),
 | |
|             $message
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\ChromePHPFormatter::format
 | |
|      */
 | |
|     public function testFormatWithFileAndLine()
 | |
|     {
 | |
|         $formatter = new ChromePHPFormatter();
 | |
|         $record = array(
 | |
|             'level' => Logger::CRITICAL,
 | |
|             'level_name' => 'CRITICAL',
 | |
|             'channel' => 'meh',
 | |
|             'context' => array('from' => 'logger'),
 | |
|             'datetime' => new \DateTime("@0"),
 | |
|             'extra' => array('ip' => '127.0.0.1', 'file' => 'test', 'line' => 14),
 | |
|             'message' => 'log',
 | |
|         );
 | |
| 
 | |
|         $message = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 'meh',
 | |
|                 array(
 | |
|                     'message' => 'log',
 | |
|                     'context' => array('from' => 'logger'),
 | |
|                     'extra' => array('ip' => '127.0.0.1'),
 | |
|                 ),
 | |
|                 'test : 14',
 | |
|                 'error',
 | |
|             ),
 | |
|             $message
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\ChromePHPFormatter::format
 | |
|      */
 | |
|     public function testFormatWithoutContext()
 | |
|     {
 | |
|         $formatter = new ChromePHPFormatter();
 | |
|         $record = array(
 | |
|             'level' => Logger::DEBUG,
 | |
|             'level_name' => 'DEBUG',
 | |
|             'channel' => 'meh',
 | |
|             'context' => array(),
 | |
|             'datetime' => new \DateTime("@0"),
 | |
|             'extra' => array(),
 | |
|             'message' => 'log',
 | |
|         );
 | |
| 
 | |
|         $message = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 'meh',
 | |
|                 'log',
 | |
|                 'unknown',
 | |
|                 'log',
 | |
|             ),
 | |
|             $message
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\ChromePHPFormatter::formatBatch
 | |
|      */
 | |
|     public function testBatchFormatThrowException()
 | |
|     {
 | |
|         $formatter = new ChromePHPFormatter();
 | |
|         $records = array(
 | |
|             array(
 | |
|                 'level' => Logger::INFO,
 | |
|                 'level_name' => 'INFO',
 | |
|                 'channel' => 'meh',
 | |
|                 'context' => array(),
 | |
|                 'datetime' => new \DateTime("@0"),
 | |
|                 'extra' => array(),
 | |
|                 'message' => 'log',
 | |
|             ),
 | |
|             array(
 | |
|                 'level' => Logger::WARNING,
 | |
|                 'level_name' => 'WARNING',
 | |
|                 'channel' => 'foo',
 | |
|                 'context' => array(),
 | |
|                 'datetime' => new \DateTime("@0"),
 | |
|                 'extra' => array(),
 | |
|                 'message' => 'log2',
 | |
|             ),
 | |
|         );
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 array(
 | |
|                     'meh',
 | |
|                     'log',
 | |
|                     'unknown',
 | |
|                     'info',
 | |
|                 ),
 | |
|                 array(
 | |
|                     'foo',
 | |
|                     'log2',
 | |
|                     'unknown',
 | |
|                     'warn',
 | |
|                 ),
 | |
|             ),
 | |
|             $formatter->formatBatch($records)
 | |
|         );
 | |
|     }
 | |
| }
 |