PsrHandlerTest.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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\Level;
  12. use Monolog\Formatter\LineFormatter;
  13. use PHPUnit\Framework\Attributes\DataProvider;
  14. /**
  15. * @covers Monolog\Handler\PsrHandler::handle
  16. */
  17. class PsrHandlerTest extends \Monolog\Test\MonologTestCase
  18. {
  19. public static function logLevelProvider()
  20. {
  21. return array_map(
  22. fn (Level $level) => [$level->toPsrLogLevel(), $level],
  23. Level::cases()
  24. );
  25. }
  26. #[DataProvider('logLevelProvider')]
  27. public function testHandlesAllLevels(string $levelName, Level $level)
  28. {
  29. $message = 'Hello, world! ' . $level->value;
  30. $context = ['foo' => 'bar', 'level' => $level->value];
  31. $psrLogger = $this->createMock('Psr\Log\NullLogger');
  32. $psrLogger->expects($this->once())
  33. ->method('log')
  34. ->with($levelName, $message, $context);
  35. $handler = new PsrHandler($psrLogger);
  36. $handler->handle($this->getRecord($level, $message, context: $context));
  37. }
  38. public function testFormatter()
  39. {
  40. $message = 'Hello, world!';
  41. $context = ['foo' => 'bar'];
  42. $level = Level::Error;
  43. $psrLogger = $this->createMock('Psr\Log\NullLogger');
  44. $psrLogger->expects($this->once())
  45. ->method('log')
  46. ->with($level->toPsrLogLevel(), 'dummy', $context);
  47. $handler = new PsrHandler($psrLogger);
  48. $handler->setFormatter(new LineFormatter('dummy'));
  49. $handler->handle($this->getRecord($level, $message, context: $context, datetime: new \DateTimeImmutable()));
  50. }
  51. public function testIncludeExtra()
  52. {
  53. $message = 'Hello, world!';
  54. $context = ['foo' => 'bar'];
  55. $extra = ['baz' => 'boo'];
  56. $level = Level::Error;
  57. $psrLogger = $this->createMock('Psr\Log\NullLogger');
  58. $psrLogger->expects($this->once())
  59. ->method('log')
  60. ->with($level->toPsrLogLevel(), $message, ['baz' => 'boo', 'foo' => 'bar']);
  61. $handler = new PsrHandler($psrLogger, includeExtra: true);
  62. $handler->handle($this->getRecord($level, $message, context: $context, datetime: new \DateTimeImmutable(), extra: $extra));
  63. }
  64. }