WebProcessorTest.php 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Tests\Bridge\Monolog\Processor;
  11. use Monolog\Logger;
  12. use Symfony\Bridge\Monolog\Processor\WebProcessor;
  13. use Symfony\Component\HttpFoundation\Request;
  14. use Symfony\Component\HttpKernel\HttpKernelInterface;
  15. class WebProcessorTest extends \PHPUnit_Framework_TestCase
  16. {
  17. public function setUp()
  18. {
  19. if (!class_exists('Monolog\\Logger')) {
  20. $this->markTestSkipped('Monolog is not available.');
  21. }
  22. }
  23. public function testUsesRequestServerData()
  24. {
  25. $server = array(
  26. 'REQUEST_URI' => 'A',
  27. 'REMOTE_ADDR' => 'B',
  28. 'REQUEST_METHOD' => 'C',
  29. );
  30. $request = new Request();
  31. $request->server->replace($server);
  32. $event = $this->getMockBuilder('Symfony\Component\HttpKernel\Event\GetResponseEvent')
  33. ->disableOriginalConstructor()
  34. ->getMock();
  35. $event->expects($this->any())
  36. ->method('getRequestType')
  37. ->will($this->returnValue(HttpKernelInterface::MASTER_REQUEST));
  38. $event->expects($this->any())
  39. ->method('getRequest')
  40. ->will($this->returnValue($request));
  41. $processor = new WebProcessor();
  42. $processor->onKernelRequest($event);
  43. $record = $processor($this->getRecord());
  44. $this->assertEquals($server['REQUEST_URI'], $record['extra']['url']);
  45. $this->assertEquals($server['REMOTE_ADDR'], $record['extra']['ip']);
  46. $this->assertEquals($server['REQUEST_METHOD'], $record['extra']['http_method']);
  47. }
  48. /**
  49. * @return array Record
  50. */
  51. protected function getRecord($level = Logger::WARNING, $message = 'test')
  52. {
  53. return array(
  54. 'message' => $message,
  55. 'context' => array(),
  56. 'level' => $level,
  57. 'level_name' => Logger::getLevelName($level),
  58. 'channel' => 'test',
  59. 'datetime' => new \DateTime(),
  60. 'extra' => array(),
  61. );
  62. }
  63. }