mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 10:36:33 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			117 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			3.9 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\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'));
 | |
|     }
 | |
| }
 |