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 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
<?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\Processor;
class WebProcessorTest extends \Monolog\Test\MonologTestCase
{
public function testProcessor()
{
$server = [
'REQUEST_URI' => 'A',
'REMOTE_ADDR' => 'B',
'REQUEST_METHOD' => 'C',
'HTTP_REFERER' => 'D',
'SERVER_NAME' => 'F',
'UNIQUE_ID' => 'G',
];
$processor = new WebProcessor($server);
$record = $processor($this->getRecord());
$this->assertEquals($server['REQUEST_URI'], $record->extra['url']);
$this->assertEquals($server['REMOTE_ADDR'], $record->extra['ip']);
$this->assertEquals($server['REQUEST_METHOD'], $record->extra['http_method']);
$this->assertEquals($server['HTTP_REFERER'], $record->extra['referrer']);
$this->assertEquals($server['SERVER_NAME'], $record->extra['server']);
$this->assertEquals($server['UNIQUE_ID'], $record->extra['unique_id']);
}
public function testProcessorDoNothingIfNoRequestUri()
{
$server = [
'REMOTE_ADDR' => 'B',
'REQUEST_METHOD' => 'C',
];
$processor = new WebProcessor($server);
$record = $processor($this->getRecord());
$this->assertEmpty($record->extra);
}
public function testProcessorReturnNullIfNoHttpReferer()
{
$server = [
'REQUEST_URI' => 'A',
'REMOTE_ADDR' => 'B',
'REQUEST_METHOD' => 'C',
'SERVER_NAME' => 'F',
];
$processor = new WebProcessor($server);
$record = $processor($this->getRecord());
$this->assertNull($record->extra['referrer']);
}
public function testProcessorDoesNotAddUniqueIdIfNotPresent()
{
$server = [
'REQUEST_URI' => 'A',
'REMOTE_ADDR' => 'B',
'REQUEST_METHOD' => 'C',
'SERVER_NAME' => 'F',
];
$processor = new WebProcessor($server);
$record = $processor($this->getRecord());
$this->assertFalse(isset($record->extra['unique_id']));
}
public function testProcessorAddsOnlyRequestedExtraFields()
{
$server = [
'REQUEST_URI' => 'A',
'REMOTE_ADDR' => 'B',
'REQUEST_METHOD' => 'C',
'SERVER_NAME' => 'F',
];
$processor = new WebProcessor($server, ['url', 'http_method']);
$record = $processor($this->getRecord());
$this->assertSame(['url' => 'A', 'http_method' => 'C'], $record->extra);
}
public function testProcessorAddsOnlyRequestedExtraFieldsIncludingOptionalFields()
{
$server = [
'REQUEST_URI' => 'A',
'UNIQUE_ID' => 'X',
];
$processor = new WebProcessor($server, ['url']);
$record = $processor($this->getRecord());
$this->assertSame(['url' => 'A'], $record->extra);
}
public function testProcessorConfiguringOfExtraFields()
{
$server = [
'REQUEST_URI' => 'A',
'REMOTE_ADDR' => 'B',
'REQUEST_METHOD' => 'C',
'SERVER_NAME' => 'F',
];
$processor = new WebProcessor($server, ['url' => 'REMOTE_ADDR']);
$record = $processor($this->getRecord());
$this->assertSame(['url' => 'B'], $record->extra);
}
public function testInvalidData()
{
$this->expectException(\TypeError::class);
new WebProcessor(new \stdClass);
}
}
|