mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 10:36:33 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.5 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;
 | |
| use Monolog\TestCase;
 | |
| 
 | |
| class JsonFormatterTest extends TestCase
 | |
| {
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\JsonFormatter::__construct
 | |
|      * @covers Monolog\Formatter\JsonFormatter::getBatchMode
 | |
|      * @covers Monolog\Formatter\JsonFormatter::isAppendingNewlines
 | |
|      */
 | |
|     public function testConstruct()
 | |
|     {
 | |
|         $formatter = new JsonFormatter();
 | |
|         $this->assertEquals(JsonFormatter::BATCH_MODE_JSON, $formatter->getBatchMode());
 | |
|         $this->assertEquals(true, $formatter->isAppendingNewlines());
 | |
|         $formatter = new JsonFormatter(JsonFormatter::BATCH_MODE_NEWLINES, false);
 | |
|         $this->assertEquals(JsonFormatter::BATCH_MODE_NEWLINES, $formatter->getBatchMode());
 | |
|         $this->assertEquals(false, $formatter->isAppendingNewlines());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\JsonFormatter::format
 | |
|      */
 | |
|     public function testFormat()
 | |
|     {
 | |
|         $formatter = new JsonFormatter();
 | |
|         $record = $this->getRecord();
 | |
|         $this->assertEquals(json_encode($record)."\n", $formatter->format($record));
 | |
| 
 | |
|         $formatter = new JsonFormatter(JsonFormatter::BATCH_MODE_JSON, false);
 | |
|         $record = $this->getRecord();
 | |
|         $this->assertEquals(json_encode($record), $formatter->format($record));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\JsonFormatter::formatBatch
 | |
|      * @covers Monolog\Formatter\JsonFormatter::formatBatchJson
 | |
|      */
 | |
|     public function testFormatBatch()
 | |
|     {
 | |
|         $formatter = new JsonFormatter();
 | |
|         $records = array(
 | |
|             $this->getRecord(Logger::WARNING),
 | |
|             $this->getRecord(Logger::DEBUG),
 | |
|         );
 | |
|         $this->assertEquals(json_encode($records), $formatter->formatBatch($records));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @covers Monolog\Formatter\JsonFormatter::formatBatch
 | |
|      * @covers Monolog\Formatter\JsonFormatter::formatBatchNewlines
 | |
|      */
 | |
|     public function testFormatBatchNewlines()
 | |
|     {
 | |
| 
 | |
|         $formatter = new JsonFormatter(JsonFormatter::BATCH_MODE_NEWLINES);
 | |
|         $records = $expected = array(
 | |
|             $this->getRecord(Logger::WARNING),
 | |
|             $this->getRecord(Logger::DEBUG),
 | |
|         );
 | |
|         array_walk($expected, function (&$value, $key) {
 | |
|             $value = json_encode($value);
 | |
|         });
 | |
|         $this->assertEquals(implode("\n", $expected), $formatter->formatBatch($records));
 | |
|     }
 | |
| }
 |