BufferHandlerTest.php 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  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\Logger;
  12. class BufferHandlerTest extends \PHPUnit_Framework_TestCase
  13. {
  14. public function testHandleBuffers()
  15. {
  16. $test = new TestHandler();
  17. $handler = new BufferHandler($test);
  18. $handler->handle($this->getRecord(Logger::DEBUG));
  19. $handler->handle($this->getRecord(Logger::INFO));
  20. $this->assertFalse($test->hasDebugRecords());
  21. $this->assertFalse($test->hasInfoRecords());
  22. $handler->close();
  23. $this->assertTrue($test->hasInfoRecords());
  24. $this->assertTrue(count($test->getRecords()) === 2);
  25. }
  26. public function testDestructPropagatesRecords()
  27. {
  28. $test = new TestHandler();
  29. $handler = new BufferHandler($test);
  30. $handler->handle($this->getRecord(Logger::WARNING));
  31. $handler->handle($this->getRecord(Logger::DEBUG));
  32. unset ($handler);
  33. $this->assertTrue($test->hasWarningRecords());
  34. $this->assertTrue($test->hasDebugRecords());
  35. }
  36. public function testHandleBufferLimit()
  37. {
  38. $test = new TestHandler();
  39. $handler = new BufferHandler($test, 2);
  40. $handler->handle($this->getRecord(Logger::DEBUG));
  41. $handler->handle($this->getRecord(Logger::DEBUG));
  42. $handler->handle($this->getRecord(Logger::INFO));
  43. $handler->handle($this->getRecord(Logger::WARNING));
  44. $handler->close();
  45. $this->assertTrue($test->hasWarningRecords());
  46. $this->assertTrue($test->hasInfoRecords());
  47. $this->assertFalse($test->hasDebugRecords());
  48. }
  49. protected function getRecord($level = Logger::WARNING)
  50. {
  51. return array(
  52. 'level' => $level,
  53. 'level_name' => Logger::getLevelName($level),
  54. 'channel' => 'log',
  55. 'Record' => 'foo',
  56. 'datetime' => new \DateTime,
  57. 'extra' => array(),
  58. );
  59. }
  60. }