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: ProcessHandlerTest.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\Attributes\DataProvider; class ProcessHandlerTest extends TestCase { /** * Dummy command to be used by tests that should not fail due to the command. * * @var string */ const DUMMY_COMMAND = 'echo'; /** * @covers Monolog\Handler\ProcessHandler::__construct * @covers Monolog\Handler\ProcessHandler::guardAgainstInvalidCommand * @covers Monolog\Handler\ProcessHandler::guardAgainstInvalidCwd * @covers Monolog\Handler\ProcessHandler::write * @covers Monolog\Handler\ProcessHandler::ensureProcessIsStarted * @covers Monolog\Handler\ProcessHandler::startProcess * @covers Monolog\Handler\ProcessHandler::handleStartupErrors */ public function testWriteOpensProcessAndWritesToStdInOfProcess() { $fixtures = [ 'chuck norris', 'foobar1337', ]; $mockBuilder = $this->getMockBuilder('Monolog\Handler\ProcessHandler'); $mockBuilder->onlyMethods(['writeProcessInput']); // using echo as command, as it is most probably available $mockBuilder->setConstructorArgs([self::DUMMY_COMMAND]); $handler = $mockBuilder->getMock(); $matcher = $this->exactly(2); $handler->expects($matcher) ->method('writeProcessInput') ->willReturnCallback(function () use ($matcher, $fixtures) { match ($matcher->numberOfInvocations()) { 1 => $this->stringContains($fixtures[0]), 2 => $this->stringContains($fixtures[1]), }; }) ; /** @var ProcessHandler $handler */ $handler->handle($this->getRecord(Level::Warning, $fixtures[0])); $handler->handle($this->getRecord(Level::Error, $fixtures[1])); } /** * Data provider for invalid commands. */ public static function invalidCommandProvider(): array { return [ [1337, 'TypeError'], ['', 'InvalidArgumentException'], [null, 'TypeError'], [fopen('php://input', 'r'), 'TypeError'], ]; } /** * @covers Monolog\Handler\ProcessHandler::guardAgainstInvalidCommand */ #[DataProvider('invalidCommandProvider')] public function testConstructWithInvalidCommandThrowsInvalidArgumentException(mixed $invalidCommand, string $expectedExcep) { $this->expectException($expectedExcep); new ProcessHandler($invalidCommand, Level::Debug); } /** * Data provider for invalid CWDs. */ public static function invalidCwdProvider(): array { return [ [1337, 'TypeError'], ['', 'InvalidArgumentException'], [fopen('php://input', 'r'), 'TypeError'], ]; } /** * @param mixed $invalidCwd * @covers Monolog\Handler\ProcessHandler::guardAgainstInvalidCwd */ #[DataProvider('invalidCwdProvider')] public function testConstructWithInvalidCwdThrowsInvalidArgumentException($invalidCwd, $expectedExcep) { $this->expectException($expectedExcep); new ProcessHandler(self::DUMMY_COMMAND, Level::Debug, true, $invalidCwd); } /** * @covers Monolog\Handler\ProcessHandler::__construct * @covers Monolog\Handler\ProcessHandler::guardAgainstInvalidCwd */ public function testConstructWithValidCwdWorks() { $handler = new ProcessHandler(self::DUMMY_COMMAND, Level::Debug, true, sys_get_temp_dir()); $this->assertInstanceOf( 'Monolog\Handler\ProcessHandler', $handler, 'Constructed handler is not a ProcessHandler.' ); } /** * @covers Monolog\Handler\ProcessHandler::handleStartupErrors */ public function testStartupWithFailingToSelectErrorStreamThrowsUnexpectedValueException() { $mockBuilder = $this->getMockBuilder('Monolog\Handler\ProcessHandler'); $mockBuilder->onlyMethods(['selectErrorStream']); $mockBuilder->setConstructorArgs([self::DUMMY_COMMAND]); $handler = $mockBuilder->getMock(); $handler->expects($this->once()) ->method('selectErrorStream') ->willReturn(false); $this->expectException(\UnexpectedValueException::class); /** @var ProcessHandler $handler */ $handler->handle($this->getRecord(Level::Warning, 'stream failing, whoops')); } /** * @covers Monolog\Handler\ProcessHandler::handleStartupErrors * @covers Monolog\Handler\ProcessHandler::selectErrorStream */ public function testStartupWithErrorsThrowsUnexpectedValueException() { $handler = new ProcessHandler('>&2 echo "some fake error message"'); $this->expectException(\UnexpectedValueException::class); $handler->handle($this->getRecord(Level::Warning, 'some warning in the house')); } /** * @covers Monolog\Handler\ProcessHandler::write */ public function testWritingWithErrorsOnStdOutOfProcessThrowsInvalidArgumentException() { $mockBuilder = $this->getMockBuilder('Monolog\Handler\ProcessHandler'); $mockBuilder->onlyMethods(['readProcessErrors']); // using echo as command, as it is most probably available $mockBuilder->setConstructorArgs([self::DUMMY_COMMAND]); $handler = $mockBuilder->getMock(); $handler->expects($this->exactly(2)) ->method('readProcessErrors') ->willReturnOnConsecutiveCalls('', 'some fake error message here'); $this->expectException(\UnexpectedValueException::class); /** @var ProcessHandler $handler */ $handler->handle($this->getRecord(Level::Warning, 'some test stuff')); } /** * @covers Monolog\Handler\ProcessHandler::close */ public function testCloseClosesProcess() { $class = new \ReflectionClass('Monolog\Handler\ProcessHandler'); $property = $class->getProperty('process'); $property->setAccessible(true); $handler = new ProcessHandler(self::DUMMY_COMMAND); $handler->handle($this->getRecord(Level::Warning, '21 is only the half truth')); $process = $property->getValue($handler); $this->assertTrue(\is_resource($process), 'Process is not running although it should.'); $handler->close(); $process = $property->getValue($handler); $this->assertFalse(\is_resource($process), 'Process is still running although it should not.'); } }