OXIESEC PANEL
- Current Dir:
/
/
var
/
www
/
firebase
/
vendor
/
monolog
/
monolog
/
tests
/
Monolog
/
Handler
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
08/12/2024 10:36:02 AM
rwxr-xr-x
📄
AbstractHandlerTest.php
2.53 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
AbstractProcessingHandlerTest.php
4.88 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
AmqpHandlerTest.php
4.3 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
BrowserConsoleHandlerTest.php
4.88 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
BufferHandlerTest.php
5.39 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
ChromePHPHandlerTest.php
4.9 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
CouchDBHandlerTest.php
805 bytes
08/12/2024 10:35:59 AM
rw-r--r--
📄
DeduplicationHandlerTest.php
6.2 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
DoctrineCouchDBHandlerTest.php
1.49 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
DynamoDbHandlerTest.php
2.31 KB
08/12/2024 10:35:59 AM
rw-r--r--
📄
ElasticaHandlerTest.php
7.74 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
ElasticsearchHandlerTest.php
7.78 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
ErrorLogHandlerTest.php
2.22 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
ExceptionTestHandler.php
567 bytes
08/12/2024 10:36:00 AM
rw-r--r--
📄
FallbackGroupHandlerTest.php
6.17 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
FilterHandlerTest.php
7.43 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
FingersCrossedHandlerTest.php
11.28 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
FirePHPHandlerTest.php
3.12 KB
08/12/2024 10:36:00 AM
rw-r--r--
📁
Fixtures
-
08/12/2024 10:36:32 AM
rwxr-xr-x
📄
FleepHookHandlerTest.php
1.99 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
FlowdockHandlerTest.php
2.74 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
GelfHandlerTest.php
3.59 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
GroupHandlerTest.php
4.97 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
HandlerWrapperTest.php
2.12 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
InsightOpsHandlerTest.php
2.58 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
LogEntriesHandlerTest.php
2.6 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
LogmaticHandlerTest.php
2.87 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
MailHandlerTest.php
2.29 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
MongoDBHandlerTest.php
2.27 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
NativeMailerHandlerTest.php
3.78 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
NewRelicHandlerTest.php
6.04 KB
08/12/2024 10:36:00 AM
rw-r--r--
📄
NoopHandlerTest.php
1.08 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
NullHandlerTest.php
1.27 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
OverflowHandlerTest.php
3.62 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
PHPConsoleHandlerTest.php
10.37 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
ProcessHandlerTest.php
6.91 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
PsrHandlerTest.php
2.47 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
PushoverHandlerTest.php
5.59 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
RedisHandlerTest.php
4.29 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
RedisPubSubHandlerTest.php
2.18 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
RollbarHandlerTest.php
2.52 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
RotatingFileHandlerTest.php
12.63 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
SamplingHandlerTest.php
909 bytes
08/12/2024 10:36:01 AM
rw-r--r--
📁
Slack
-
08/12/2024 10:36:32 AM
rwxr-xr-x
📄
SlackHandlerTest.php
5.68 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
SlackWebhookHandlerTest.php
5 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
SocketHandlerTest.php
9.69 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
StreamHandlerTest.php
9.85 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
SymfonyMailerHandlerTest.php
3.34 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
SyslogHandlerTest.php
1.32 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
SyslogUdpHandlerTest.php
3.97 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
TelegramBotHandlerTest.php
1.87 KB
08/12/2024 10:36:01 AM
rw-r--r--
📄
TestHandlerTest.php
4.05 KB
08/12/2024 10:36:02 AM
rw-r--r--
📄
UdpSocketTest.php
1.79 KB
08/12/2024 10:36:02 AM
rw-r--r--
📄
WhatFailureGroupHandlerTest.php
5.8 KB
08/12/2024 10:36:02 AM
rw-r--r--
📄
ZendMonitorHandlerTest.php
2.21 KB
08/12/2024 10:36:02 AM
rw-r--r--
Editing: SocketHandlerTest.php
Close
<?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\Test\TestCase; use Monolog\Level; use PHPUnit\Framework\MockObject\MockObject; /** * @author Pablo de Leon Belloc <pablolb@gmail.com> */ class SocketHandlerTest extends TestCase { private SocketHandler&MockObject $handler; /** * @var resource */ private $res; public function tearDown(): void { parent::tearDown(); unset($this->res); } public function testInvalidHostname() { $this->expectException(\UnexpectedValueException::class); $handler = $this->createHandler('garbage://here'); $handler->handle($this->getRecord(Level::Warning, 'data')); } public function testBadConnectionTimeout() { $this->expectException(\InvalidArgumentException::class); $handler = $this->createHandler('localhost:1234'); $handler->setConnectionTimeout(-1); } public function testSetConnectionTimeout() { $handler = $this->createHandler('localhost:1234'); $handler->setConnectionTimeout(10.1); $this->assertEquals(10.1, $handler->getConnectionTimeout()); } public function testBadTimeout() { $this->expectException(\InvalidArgumentException::class); $handler = $this->createHandler('localhost:1234'); $handler->setTimeout(-1); } public function testSetTimeout() { $handler = $this->createHandler('localhost:1234'); $handler->setTimeout(10.25); $this->assertEquals(10.25, $handler->getTimeout()); } public function testSetWritingTimeout() { $handler = $this->createHandler('localhost:1234'); $handler->setWritingTimeout(10.25); $this->assertEquals(10.25, $handler->getWritingTimeout()); } public function testSetChunkSize() { $handler = $this->createHandler('localhost:1234'); $handler->setChunkSize(1025); $this->assertEquals(1025, $handler->getChunkSize()); } public function testSetConnectionString() { $handler = $this->createHandler('tcp://localhost:9090'); $this->assertEquals('tcp://localhost:9090', $handler->getConnectionString()); } public function testExceptionIsThrownOnFsockopenError() { $this->setMockHandler(['fsockopen']); $this->handler->expects($this->once()) ->method('fsockopen') ->willReturn(false); $this->expectException(\UnexpectedValueException::class); $this->writeRecord('Hello world'); } public function testExceptionIsThrownOnPfsockopenError() { $this->setMockHandler(['pfsockopen']); $this->handler->expects($this->once()) ->method('pfsockopen') ->willReturn(false); $this->handler->setPersistent(true); $this->expectException(\UnexpectedValueException::class); $this->writeRecord('Hello world'); } public function testExceptionIsThrownIfCannotSetTimeout() { $this->setMockHandler(['streamSetTimeout']); $this->handler->expects($this->once()) ->method('streamSetTimeout') ->willReturn(false); $this->expectException(\UnexpectedValueException::class); $this->writeRecord('Hello world'); } public function testExceptionIsThrownIfCannotSetChunkSize() { $this->setMockHandler(['streamSetChunkSize']); $this->handler->setChunkSize(8192); $this->handler->expects($this->once()) ->method('streamSetChunkSize') ->willReturn(false); $this->expectException(\UnexpectedValueException::class); $this->writeRecord('Hello world'); } public function testWriteFailsOnIfFwriteReturnsFalse() { $this->setMockHandler(['fwrite']); $callback = function ($arg) { $map = [ 'Hello world' => 6, 'world' => false, ]; return $map[$arg]; }; $this->handler->expects($this->exactly(2)) ->method('fwrite') ->willReturnCallback($callback); $this->expectException(\RuntimeException::class); $this->writeRecord('Hello world'); } public function testWriteFailsIfStreamTimesOut() { $this->setMockHandler(['fwrite', 'streamGetMetadata']); $callback = function ($arg) { $map = [ 'Hello world' => 6, 'world' => 5, ]; return $map[$arg]; }; $this->handler->expects($this->exactly(1)) ->method('fwrite') ->willReturnCallback($callback); $this->handler->expects($this->exactly(1)) ->method('streamGetMetadata') ->willReturn(['timed_out' => true]); $this->expectException(\RuntimeException::class); $this->writeRecord('Hello world'); } public function testWriteFailsOnIncompleteWrite() { $this->setMockHandler(['fwrite', 'streamGetMetadata']); $res = $this->res; $callback = function ($string) use ($res) { fclose($res); return \strlen('Hello'); }; $this->handler->expects($this->exactly(1)) ->method('fwrite') ->willReturnCallback($callback); $this->handler->expects($this->exactly(1)) ->method('streamGetMetadata') ->willReturn(['timed_out' => false]); $this->expectException(\RuntimeException::class); $this->writeRecord('Hello world'); } public function testWriteWithMemoryFile() { $this->setMockHandler(); $this->writeRecord('test1'); $this->writeRecord('test2'); $this->writeRecord('test3'); fseek($this->res, 0); $this->assertEquals('test1test2test3', fread($this->res, 1024)); } public function testWriteWithMock() { $this->setMockHandler(['fwrite']); $callback = function ($arg) { $map = [ 'Hello world' => 6, 'world' => 5, ]; return $map[$arg]; }; $this->handler->expects($this->exactly(2)) ->method('fwrite') ->willReturnCallback($callback); $this->writeRecord('Hello world'); } public function testClose() { $this->setMockHandler(); $this->writeRecord('Hello world'); $this->assertIsResource($this->res); $this->handler->close(); $this->assertFalse(\is_resource($this->res), "Expected resource to be closed after closing handler"); } public function testCloseDoesNotClosePersistentSocket() { $this->setMockHandler(); $this->handler->setPersistent(true); $this->writeRecord('Hello world'); $this->assertTrue(\is_resource($this->res)); $this->handler->close(); $this->assertTrue(\is_resource($this->res)); } public function testAvoidInfiniteLoopWhenNoDataIsWrittenForAWritingTimeoutSeconds() { $this->setMockHandler(['fwrite', 'streamGetMetadata']); $this->handler->expects($this->any()) ->method('fwrite') ->willReturn(0); $this->handler->expects($this->any()) ->method('streamGetMetadata') ->willReturn(['timed_out' => false]); $this->handler->setWritingTimeout(1); $this->expectException(\RuntimeException::class); $this->writeRecord('Hello world'); } private function createHandler(string $connectionString): SocketHandler { $handler = new SocketHandler($connectionString); $handler->setFormatter($this->getIdentityFormatter()); return $handler; } private function writeRecord($string) { $this->handler->handle($this->getRecord(Level::Warning, $string)); } private function setMockHandler(array $methods = []) { $this->res = fopen('php://memory', 'a'); $defaultMethods = ['fsockopen', 'pfsockopen', 'streamSetTimeout', 'streamSetChunkSize']; $newMethods = array_diff($methods, $defaultMethods); $finalMethods = array_merge($defaultMethods, $newMethods); $this->handler = $this->getMockBuilder('Monolog\Handler\SocketHandler') ->onlyMethods($finalMethods) ->setConstructorArgs(['localhost:1234']) ->getMock(); if (!\in_array('fsockopen', $methods)) { $this->handler->expects($this->any()) ->method('fsockopen') ->willReturn($this->res); } if (!\in_array('pfsockopen', $methods)) { $this->handler->expects($this->any()) ->method('pfsockopen') ->willReturn($this->res); } if (!\in_array('streamSetTimeout', $methods)) { $this->handler->expects($this->any()) ->method('streamSetTimeout') ->willReturn(true); } if (!\in_array('streamSetChunkSize', $methods)) { $this->handler->expects($this->any()) ->method('streamSetChunkSize') ->willReturn(8192); } $this->handler->setFormatter($this->getIdentityFormatter()); } }