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
|
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Bridge\Monolog\Tests\Formatter;
use Monolog\Logger;
use Monolog\LogRecord;
use PHPUnit\Framework\TestCase;
use Symfony\Bridge\Monolog\Formatter\ConsoleFormatter;
use Symfony\Bridge\Monolog\Tests\RecordFactory;
class ConsoleFormatterTest extends TestCase
{
#[\PHPUnit\Framework\Attributes\DataProvider('providerFormatTests')]
public function testFormat(array|LogRecord $record, $expectedMessage)
{
$formatter = new ConsoleFormatter();
self::assertSame($expectedMessage, $formatter->format($record));
}
public static function providerFormatTests(): array
{
$currentDateTime = new \DateTimeImmutable();
$tests = [
'record with DateTime object in datetime field' => [
'record' => RecordFactory::create(datetime: $currentDateTime),
'expectedMessage' => \sprintf(
"%s <fg=cyan>WARNING </> <comment>[test]</> test\n",
$currentDateTime->format(ConsoleFormatter::SIMPLE_DATE)
),
],
];
if (Logger::API < 3) {
$tests['record with string in datetime field'] = [
'record' => [
'message' => 'test',
'context' => [],
'level' => Level::Warning,
'level_name' => Logger::getLevelName(Level::Warning),
'channel' => 'test',
'datetime' => '2019-01-01T00:42:00+00:00',
'extra' => [],
],
'expectedMessage' => "2019-01-01T00:42:00+00:00 <fg=cyan>WARNING </> <comment>[test]</> test\n",
];
}
return $tests;
}
}
|