mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-26 18:16:24 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php declare(strict_types=1);
 | |
| 
 | |
| /*
 | |
|  * 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\Processor;
 | |
| 
 | |
| class PsrLogMessageProcessorTest extends \PHPUnit\Framework\TestCase
 | |
| {
 | |
|     /**
 | |
|      * @dataProvider getPairs
 | |
|      */
 | |
|     public function testReplacement($val, $expected)
 | |
|     {
 | |
|         $proc = new PsrLogMessageProcessor;
 | |
| 
 | |
|         $message = $proc([
 | |
|             'message' => '{foo}',
 | |
|             'context' => ['foo' => $val],
 | |
|         ]);
 | |
|         $this->assertEquals($expected, $message['message']);
 | |
|         $this->assertSame(['foo' => $val], $message['context']);
 | |
|     }
 | |
| 
 | |
|     public function testReplacementWithContextRemoval()
 | |
|     {
 | |
|         $proc = new PsrLogMessageProcessor($dateFormat = null, $removeUsedContextFields = true);
 | |
| 
 | |
|         $message = $proc([
 | |
|             'message' => '{foo}',
 | |
|             'context' => ['foo' => 'bar', 'lorem' => 'ipsum'],
 | |
|         ]);
 | |
|         $this->assertSame('bar', $message['message']);
 | |
|         $this->assertSame(['lorem' => 'ipsum'], $message['context']);
 | |
|     }
 | |
| 
 | |
|     public function testCustomDateFormat()
 | |
|     {
 | |
|         $format = "Y-m-d";
 | |
|         $date = new \DateTime();
 | |
| 
 | |
|         $proc = new PsrLogMessageProcessor($format);
 | |
| 
 | |
|         $message = $proc([
 | |
|             'message' => '{foo}',
 | |
|             'context' => ['foo' => $date],
 | |
|         ]);
 | |
|         $this->assertEquals($date->format($format), $message['message']);
 | |
|         $this->assertSame(['foo' => $date], $message['context']);
 | |
|     }
 | |
| 
 | |
|     public function getPairs()
 | |
|     {
 | |
|         $date = new \DateTime();
 | |
| 
 | |
|         return [
 | |
|             ['foo',    'foo'],
 | |
|             ['3',      '3'],
 | |
|             [3,        '3'],
 | |
|             [null,     ''],
 | |
|             [true,     '1'],
 | |
|             [false,    ''],
 | |
|             [$date, $date->format(PsrLogMessageProcessor::SIMPLE_DATE)],
 | |
|             [new \stdClass, '[object stdClass]'],
 | |
|             [[], 'array[]'],
 | |
|             [[], 'array[]'],
 | |
|             [[1, 2, 3], 'array[1,2,3]'],
 | |
|             [['foo' => 'bar'], 'array{"foo":"bar"}'],
 | |
|             [stream_context_create(), '[resource]'],
 | |
|         ];
 | |
|     }
 | |
| }
 |