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 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
|
<?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 DateTimeImmutable;
use Monolog\Level;
use Monolog\LogRecord;
use PHPUnit\Framework\Attributes\DataProvider;
class SyslogFormatterTest extends \Monolog\Test\MonologTestCase
{
/**
* @param mixed[] $context
* @param mixed[] $extra
*/
#[DataProvider('formatDataProvider')]
public function testFormat(
string $expected,
DateTimeImmutable $dateTime,
string $channel,
Level $level,
string $message,
?string $appName = null,
array $context = [],
array $extra = []
): void {
if ($appName !== null) {
$formatter = new SyslogFormatter($appName);
} else {
$formatter = new SyslogFormatter();
}
$record = new LogRecord(
datetime: $dateTime,
channel: $channel,
level: $level,
message: $message,
context: $context,
extra: $extra
);
$message = $formatter->format($record);
$this->assertEquals($expected, $message);
}
/**
* @return mixed[]
*/
public static function formatDataProvider(): array
{
return [
'error' => [
'expected' => "<11>1 1970-01-01T00:00:00.000000+00:00 " . gethostname() . " - " . getmypid() ." meh - ERROR: log \n",
'dateTime' => new DateTimeImmutable("@0"),
'channel' => 'meh',
'level' => Level::Error,
'message' => 'log',
],
'info' => [
'expected' => "<11>1 1970-01-01T00:00:00.000000+00:00 " . gethostname() . " - " . getmypid() ." meh - ERROR: log \n",
'dateTime' => new DateTimeImmutable("@0"),
'channel' => 'meh',
'level' => Level::Error,
'message' => 'log',
],
'with app name' => [
'expected' => "<11>1 1970-01-01T00:00:00.000000+00:00 " . gethostname() . " my-app " . getmypid() ." meh - ERROR: log \n",
'dateTime' => new DateTimeImmutable("@0"),
'channel' => 'meh',
'level' => Level::Error,
'message' => 'log',
'appName' => 'my-app',
],
'with context' => [
'expected' => "<11>1 1970-01-01T00:00:00.000000+00:00 " . gethostname() . " - " . getmypid() ." meh - ERROR: log {\"additional-context\":\"test\"} \n",
'dateTime' => new DateTimeImmutable("@0"),
'channel' => 'meh',
'level' => Level::Error,
'message' => 'log',
'appName' => null,
'context' => ['additional-context' => 'test'],
],
'with extra' => [
'expected' => "<11>1 1970-01-01T00:00:00.000000+00:00 " . gethostname() . " - " . getmypid() ." meh - ERROR: log {\"userId\":1}\n",
'dateTime' => new DateTimeImmutable("@0"),
'channel' => 'meh',
'level' => Level::Error,
'message' => 'log',
'appName' => null,
'context' => [],
'extra' => ['userId' => 1],
],
];
}
}
|