LoggerDataCollectorTest.php 4.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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\Component\HttpKernel\Tests\DataCollector;
  11. use Symfony\Component\HttpKernel\DataCollector\LoggerDataCollector;
  12. class LoggerDataCollectorTest extends \PHPUnit_Framework_TestCase
  13. {
  14. /**
  15. * @dataProvider getCollectTestData
  16. */
  17. public function testCollect($nb, $logs, $expectedLogs, $expectedDeprecationCount, $expectedScreamCount, $expectedPriorities = null)
  18. {
  19. $logger = $this->getMock('Symfony\Component\HttpKernel\Log\DebugLoggerInterface');
  20. $logger->expects($this->once())->method('countErrors')->will($this->returnValue($nb));
  21. $logger->expects($this->exactly(2))->method('getLogs')->will($this->returnValue($logs));
  22. $c = new LoggerDataCollector($logger);
  23. $c->lateCollect();
  24. $this->assertSame('logger', $c->getName());
  25. $this->assertSame($nb, $c->countErrors());
  26. $this->assertSame($expectedLogs ?: $logs, $c->getLogs());
  27. $this->assertSame($expectedDeprecationCount, $c->countDeprecations());
  28. $this->assertSame($expectedScreamCount, $c->countScreams());
  29. if (isset($expectedPriorities)) {
  30. $this->assertSame($expectedPriorities, $c->getPriorities());
  31. }
  32. }
  33. public function getCollectTestData()
  34. {
  35. return array(
  36. array(
  37. 1,
  38. array(array('message' => 'foo', 'context' => array(), 'priority' => 100, 'priorityName' => 'DEBUG')),
  39. null,
  40. 0,
  41. 0,
  42. ),
  43. array(
  44. 1,
  45. array(array('message' => 'foo', 'context' => array('foo' => fopen(__FILE__, 'r')), 'priority' => 100, 'priorityName' => 'DEBUG')),
  46. array(array('message' => 'foo', 'context' => array('foo' => 'Resource(stream)'), 'priority' => 100, 'priorityName' => 'DEBUG')),
  47. 0,
  48. 0,
  49. ),
  50. array(
  51. 1,
  52. array(array('message' => 'foo', 'context' => array('foo' => new \stdClass()), 'priority' => 100, 'priorityName' => 'DEBUG')),
  53. array(array('message' => 'foo', 'context' => array('foo' => 'Object(stdClass)'), 'priority' => 100, 'priorityName' => 'DEBUG')),
  54. 0,
  55. 0,
  56. ),
  57. array(
  58. 1,
  59. array(
  60. array('message' => 'foo', 'context' => array('type' => E_DEPRECATED, 'level' => E_ALL), 'priority' => 100, 'priorityName' => 'DEBUG'),
  61. array('message' => 'foo2', 'context' => array('type' => E_USER_DEPRECATED, 'level' => E_ALL), 'priority' => 100, 'priorityName' => 'DEBUG'),
  62. ),
  63. null,
  64. 2,
  65. 0,
  66. array(100 => array('count' => 2, 'name' => 'DEBUG')),
  67. ),
  68. array(
  69. 1,
  70. array(array('message' => 'foo3', 'context' => array('name' => 'E_USER_WARNING', 'type' => E_USER_WARNING, 'level' => 0, 'file' => __FILE__, 'line' => 123), 'priority' => 100, 'priorityName' => 'DEBUG')),
  71. array(array('message' => 'foo3', 'context' => array('name' => 'E_USER_WARNING', 'type' => E_USER_WARNING, 'level' => 0, 'file' => __FILE__, 'line' => 123, 'scream' => true), 'priority' => 100, 'priorityName' => 'DEBUG')),
  72. 0,
  73. 1,
  74. ),
  75. array(
  76. 1,
  77. array(
  78. array('message' => 'foo3', 'context' => array('type' => E_USER_WARNING, 'level' => 0, 'file' => __FILE__, 'line' => 123), 'priority' => 100, 'priorityName' => 'DEBUG'),
  79. array('message' => 'foo3', 'context' => array('type' => E_USER_WARNING, 'level' => -1, 'file' => __FILE__, 'line' => 123), 'priority' => 100, 'priorityName' => 'DEBUG'),
  80. ),
  81. array(array('message' => 'foo3', 'context' => array('name' => 'E_USER_WARNING', 'type' => E_USER_WARNING, 'level' => -1, 'file' => __FILE__, 'line' => 123, 'errorCount' => 2), 'priority' => 100, 'priorityName' => 'DEBUG')),
  82. 0,
  83. 1,
  84. ),
  85. );
  86. }
  87. }