PsrHandlerTest.php 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <?php declare(strict_types=1);
  2. /*
  3. * This file is part of the Monolog package.
  4. *
  5. * (c) Jordi Boggiano <j.boggiano@seld.be>
  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 Monolog\Handler;
  11. use Monolog\Test\TestCase;
  12. use Monolog\Logger;
  13. use Monolog\Formatter\LineFormatter;
  14. /**
  15. * @covers Monolog\Handler\PsrHandler::handle
  16. */
  17. class PsrHandlerTest extends TestCase
  18. {
  19. public function logLevelProvider()
  20. {
  21. $levels = [];
  22. $monologLogger = new Logger('');
  23. foreach ($monologLogger->getLevels() as $levelName => $level) {
  24. $levels[] = [$levelName, $level];
  25. }
  26. return $levels;
  27. }
  28. /**
  29. * @dataProvider logLevelProvider
  30. */
  31. public function testHandlesAllLevels($levelName, $level)
  32. {
  33. $message = 'Hello, world! ' . $level;
  34. $context = ['foo' => 'bar', 'level' => $level];
  35. $psrLogger = $this->createMock('Psr\Log\NullLogger');
  36. $psrLogger->expects($this->once())
  37. ->method('log')
  38. ->with(strtolower($levelName), $message, $context);
  39. $handler = new PsrHandler($psrLogger);
  40. $handler->handle(['level' => $level, 'level_name' => $levelName, 'message' => $message, 'context' => $context]);
  41. }
  42. public function testFormatter()
  43. {
  44. $message = 'Hello, world!';
  45. $context = ['foo' => 'bar'];
  46. $level = Logger::ERROR;
  47. $levelName = 'error';
  48. $psrLogger = $this->createMock('Psr\Log\NullLogger');
  49. $psrLogger->expects($this->once())
  50. ->method('log')
  51. ->with(strtolower($levelName), 'dummy', $context);
  52. $handler = new PsrHandler($psrLogger);
  53. $handler->setFormatter(new LineFormatter('dummy'));
  54. $handler->handle(['level' => $level, 'level_name' => $levelName, 'message' => $message, 'context' => $context, 'extra' => [], 'date' => new \DateTimeImmutable()]);
  55. }
  56. }