mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 18:46:14 +02:00 
			
		
		
		
	* Remove unused code path in MongoDBFormatter Monolog already required mongodb/mongodb 1.8+ (and a related ext-mongodb version) so this code path was never used. * Use Collection::getCollection() from mongodb/mongodb 1.21 The original selectCollection method is deprecated. Since Monolog itself requires PHP 8.1, it should be sane to rely on 1.21+, which shares the same requirement. * Update class refs for MongoDB extension and library * Conditionally use Collection getter by version * Relax PHPLIB version requirement * Use RequiresPhpExtension attribute to require ext-mongodb * Import UTCDateTime class and revise var names
		
			
				
	
	
		
			264 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			264 lines
		
	
	
		
			9.1 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\Formatter;
 | |
| 
 | |
| use MongoDB\BSON\ObjectId;
 | |
| use MongoDB\BSON\Regex;
 | |
| use MongoDB\BSON\UTCDateTime;
 | |
| use Monolog\Level;
 | |
| use PHPUnit\Framework\Attributes\DataProvider;
 | |
| use PHPUnit\Framework\Attributes\RequiresPhpExtension;
 | |
| 
 | |
| /**
 | |
|  * @author Florian Plattner <me@florianplattner.de>
 | |
|  */
 | |
| #[RequiresPhpExtension('mongodb')]
 | |
| class MongoDBFormatterTest extends \Monolog\Test\MonologTestCase
 | |
| {
 | |
|     public static function constructArgumentProvider()
 | |
|     {
 | |
|         return [
 | |
|             [1, true, 1, true],
 | |
|             [0, false, 0, false],
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     #[DataProvider('constructArgumentProvider')]
 | |
|     public function testConstruct($traceDepth, $traceAsString, $expectedTraceDepth, $expectedTraceAsString)
 | |
|     {
 | |
|         $formatter = new MongoDBFormatter($traceDepth, $traceAsString);
 | |
| 
 | |
|         $reflTrace = new \ReflectionProperty($formatter, 'exceptionTraceAsString');
 | |
|         $this->assertEquals($expectedTraceAsString, $reflTrace->getValue($formatter));
 | |
| 
 | |
|         $reflDepth = new \ReflectionProperty($formatter, 'maxNestingLevel');
 | |
|         $this->assertEquals($expectedTraceDepth, $reflDepth->getValue($formatter));
 | |
|     }
 | |
| 
 | |
|     public function testSimpleFormat()
 | |
|     {
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.123456+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter();
 | |
|         $formattedRecord = $formatter->format($record);
 | |
| 
 | |
|         $this->assertCount(7, $formattedRecord);
 | |
|         $this->assertEquals('some log message', $formattedRecord['message']);
 | |
|         $this->assertEquals([], $formattedRecord['context']);
 | |
|         $this->assertEquals(Level::Warning->value, $formattedRecord['level']);
 | |
|         $this->assertEquals(Level::Warning->getName(), $formattedRecord['level_name']);
 | |
|         $this->assertEquals('test', $formattedRecord['channel']);
 | |
|         $this->assertInstanceOf(UTCDateTime::class, $formattedRecord['datetime']);
 | |
|         $this->assertEquals('1453410690123', $formattedRecord['datetime']->__toString());
 | |
|         $this->assertEquals([], $formattedRecord['extra']);
 | |
|     }
 | |
| 
 | |
|     public function testRecursiveFormat()
 | |
|     {
 | |
|         $someObject = new \stdClass();
 | |
|         $someObject->foo = 'something';
 | |
|         $someObject->bar = 'stuff';
 | |
| 
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             context: [
 | |
|                 'stuff' => new \DateTimeImmutable('1969-01-21T21:11:30.213000+00:00'),
 | |
|                 'some_object' => $someObject,
 | |
|                 'context_string' => 'some string',
 | |
|                 'context_int' => 123456,
 | |
|                 'except' => new \Exception('exception message', 987),
 | |
|             ],
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.213000+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter();
 | |
|         $formattedRecord = $formatter->format($record);
 | |
| 
 | |
|         $this->assertCount(5, $formattedRecord['context']);
 | |
|         $this->assertInstanceOf(UTCDateTime::class, $formattedRecord['context']['stuff']);
 | |
|         $this->assertEquals('-29731710213', $formattedRecord['context']['stuff']->__toString());
 | |
|         $this->assertEquals(
 | |
|             [
 | |
|                 'foo' => 'something',
 | |
|                 'bar' => 'stuff',
 | |
|                 'class' => 'stdClass',
 | |
|             ],
 | |
|             $formattedRecord['context']['some_object']
 | |
|         );
 | |
|         $this->assertEquals('some string', $formattedRecord['context']['context_string']);
 | |
|         $this->assertEquals(123456, $formattedRecord['context']['context_int']);
 | |
| 
 | |
|         $this->assertCount(5, $formattedRecord['context']['except']);
 | |
|         $this->assertEquals('exception message', $formattedRecord['context']['except']['message']);
 | |
|         $this->assertEquals(987, $formattedRecord['context']['except']['code']);
 | |
|         $this->assertIsString($formattedRecord['context']['except']['file']);
 | |
|         $this->assertIsInt($formattedRecord['context']['except']['code']);
 | |
|         $this->assertIsString($formattedRecord['context']['except']['trace']);
 | |
|         $this->assertEquals('Exception', $formattedRecord['context']['except']['class']);
 | |
|     }
 | |
| 
 | |
|     public function testFormatDepthArray()
 | |
|     {
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             context: [
 | |
|                 'nest2' => [
 | |
|                     'property' => 'anything',
 | |
|                     'nest3' => [
 | |
|                         'nest4' => 'value',
 | |
|                         'property' => 'nothing',
 | |
|                     ],
 | |
|                 ],
 | |
|             ],
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.123456+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter(2);
 | |
|         $formattedResult = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             [
 | |
|                 'nest2' => [
 | |
|                     'property' => 'anything',
 | |
|                     'nest3' => '[...]',
 | |
|                 ],
 | |
|             ],
 | |
|             $formattedResult['context']
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     public function testFormatDepthArrayInfiniteNesting()
 | |
|     {
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             context: [
 | |
|                 'nest2' => [
 | |
|                     'property' => 'something',
 | |
|                     'nest3' => [
 | |
|                         'property' => 'anything',
 | |
|                         'nest4' => [
 | |
|                             'property' => 'nothing',
 | |
|                         ],
 | |
|                     ],
 | |
|                 ],
 | |
|             ],
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.123456+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter(0);
 | |
|         $formattedResult = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             [
 | |
|                 'nest2' => [
 | |
|                     'property' => 'something',
 | |
|                     'nest3' => [
 | |
|                         'property' => 'anything',
 | |
|                         'nest4' => [
 | |
|                             'property' => 'nothing',
 | |
|                         ],
 | |
|                     ],
 | |
|                 ],
 | |
|             ],
 | |
|             $formattedResult['context']
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     public function testFormatDepthObjects()
 | |
|     {
 | |
|         $someObject = new \stdClass();
 | |
|         $someObject->property = 'anything';
 | |
|         $someObject->nest3 = new \stdClass();
 | |
|         $someObject->nest3->property = 'nothing';
 | |
|         $someObject->nest3->nest4 = 'invisible';
 | |
| 
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             context: [
 | |
|                 'nest2' => $someObject,
 | |
|             ],
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.123456+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter(2, true);
 | |
|         $formattedResult = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             [
 | |
|                 'nest2' => [
 | |
|                     'property' => 'anything',
 | |
|                     'nest3' => '[...]',
 | |
|                     'class' => 'stdClass',
 | |
|                 ],
 | |
|             ],
 | |
|             $formattedResult['context']
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     public function testFormatDepthException()
 | |
|     {
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             context: [
 | |
|                 'nest2' => new \Exception('exception message', 987),
 | |
|             ],
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.123456+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter(2, false);
 | |
|         $formattedRecord = $formatter->format($record);
 | |
| 
 | |
|         $this->assertEquals('exception message', $formattedRecord['context']['nest2']['message']);
 | |
|         $this->assertEquals(987, $formattedRecord['context']['nest2']['code']);
 | |
|         $this->assertEquals('[...]', $formattedRecord['context']['nest2']['trace']);
 | |
|     }
 | |
| 
 | |
|     public function testBsonTypes()
 | |
|     {
 | |
|         $record = $this->getRecord(
 | |
|             message: 'some log message',
 | |
|             context: [
 | |
|                 'objectid' => new ObjectId(),
 | |
|                 'nest' => [
 | |
|                     'timestamp' => new UTCDateTime(),
 | |
|                     'regex' => new Regex('pattern'),
 | |
|                 ],
 | |
|             ],
 | |
|             level: Level::Warning,
 | |
|             channel: 'test',
 | |
|             datetime: new \DateTimeImmutable('2016-01-21T21:11:30.123456+00:00'),
 | |
|         );
 | |
| 
 | |
|         $formatter = new MongoDBFormatter();
 | |
|         $formattedRecord = $formatter->format($record);
 | |
| 
 | |
|         $this->assertInstanceOf(ObjectId::class, $formattedRecord['context']['objectid']);
 | |
|         $this->assertInstanceOf(UTCDateTime::class, $formattedRecord['context']['nest']['timestamp']);
 | |
|         $this->assertInstanceOf(Regex::class, $formattedRecord['context']['nest']['regex']);
 | |
|     }
 | |
| }
 |