File: PsrLogMessageProcessorTest.php

package info (click to toggle)
php-monolog 3.9.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,456 kB
  • sloc: php: 16,836; makefile: 20
file content (71 lines) | stat: -rw-r--r-- 2,253 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?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;

use Monolog\Level;
use PHPUnit\Framework\Attributes\DataProvider;

class PsrLogMessageProcessorTest extends \Monolog\Test\MonologTestCase
{
    #[DataProvider('getPairs')]
    public function testReplacement($val, $expected)
    {
        $proc = new PsrLogMessageProcessor;

        $message = $proc($this->getRecord(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($this->getRecord(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($this->getRecord(message: '{foo}', context: ['foo' => $date]));
        $this->assertEquals($date->format($format), $message['message']);
        $this->assertSame(['foo' => $date], $message['context']);
    }

    public static 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]'],
            [Level::Info, Level::Info->value],
        ];
    }
}