| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- <?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\Handler;
- use Monolog\Level;
- use Monolog\Test\TestCase;
- /**
- * @requires extension sockets
- */
- class SyslogUdpHandlerTest extends TestCase
- {
- public function testWeValidateFacilities()
- {
- $this->expectException(\UnexpectedValueException::class);
- $handler = new SyslogUdpHandler("ip", 514, "invalidFacility");
- }
- public function testWeSplitIntoLines()
- {
- $pid = getmypid();
- $host = gethostname();
- $handler = new \Monolog\Handler\SyslogUdpHandler("127.0.0.1", 514, "authpriv");
- $handler->setFormatter(new \Monolog\Formatter\ChromePHPFormatter());
- $time = '2014-01-07T12:34:56+00:00';
- $socket = $this->getMockBuilder('Monolog\Handler\SyslogUdp\UdpSocket')
- ->onlyMethods(['write'])
- ->setConstructorArgs(['lol'])
- ->getMock();
- $matcher = $this->atLeast(2);
- $socket->expects($matcher)
- ->method('write')
- ->willReturnCallback(function () use ($matcher, $time, $host, $pid) {
- match ($matcher->numberOfInvocations()) {
- 1 => $this->equalTo("lol") && $this->equalTo("<".(LOG_AUTHPRIV + LOG_WARNING).">1 $time $host php $pid - - "),
- 2 => $this->equalTo("hej") && $this->equalTo("<".(LOG_AUTHPRIV + LOG_WARNING).">1 $time $host php $pid - - "),
- default => $this->assertTrue(true)
- };
- });
- $handler->setSocket($socket);
- $handler->handle($this->getRecordWithMessage("hej\nlol"));
- }
- public function testSplitWorksOnEmptyMsg()
- {
- $handler = new SyslogUdpHandler("127.0.0.1", 514, "authpriv");
- $handler->setFormatter($this->getIdentityFormatter());
- $socket = $this->getMockBuilder('Monolog\Handler\SyslogUdp\UdpSocket')
- ->onlyMethods(['write'])
- ->setConstructorArgs(['lol'])
- ->getMock();
- $socket->expects($this->never())
- ->method('write');
- $handler->setSocket($socket);
- $handler->handle($this->getRecordWithMessage(''));
- }
- public function testRfc()
- {
- $time = 'Jan 07 12:34:56';
- $pid = getmypid();
- $host = gethostname();
- $handler = $this->getMockBuilder('\Monolog\Handler\SyslogUdpHandler')
- ->setConstructorArgs(["127.0.0.1", 514, "authpriv", 'debug', true, "php", \Monolog\Handler\SyslogUdpHandler::RFC3164])
- ->onlyMethods([])
- ->getMock();
- $handler->setFormatter(new \Monolog\Formatter\ChromePHPFormatter());
- $socket = $this->getMockBuilder('\Monolog\Handler\SyslogUdp\UdpSocket')
- ->setConstructorArgs(['lol', 999])
- ->onlyMethods(['write'])
- ->getMock();
- $matcher = $this->atLeast(2);
- $socket->expects($matcher)
- ->method('write')
- ->willReturnCallback(function () use ($matcher, $time, $host, $pid) {
- match ($matcher->numberOfInvocations()) {
- 1 => $this->equalTo("lol") && $this->equalTo("<".(LOG_AUTHPRIV + LOG_WARNING).">$time $host php[$pid]: "),
- 2 => $this->equalTo("hej") && $this->equalTo("<".(LOG_AUTHPRIV + LOG_WARNING).">$time $host php[$pid]: "),
- default => $this->assertTrue(true)
- };
- });
- $handler->setSocket($socket);
- $handler->handle($this->getRecordWithMessage("hej\nlol"));
- }
- protected function getRecordWithMessage($msg)
- {
- return $this->getRecord(message: $msg, level: Level::Warning, channel: 'lol', datetime: new \DateTimeImmutable('2014-01-07 12:34:56'));
- }
- }
|