SwiftMailerHandlerTest.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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. use Monolog\TestCase;
  13. class SwiftMailerHandlerTest extends TestCase
  14. {
  15. /** @var \Swift_Mailer|\PHPUnit_Framework_MockObject_MockObject */
  16. private $mailer;
  17. public function setUp()
  18. {
  19. $this->mailer = $this
  20. ->getMockBuilder('Swift_Mailer')
  21. ->disableOriginalConstructor()
  22. ->getMock();
  23. }
  24. public function testMessageCreationIsLazyWhenUsingCallback()
  25. {
  26. $this->mailer->expects($this->never())
  27. ->method('send');
  28. $callback = function () {
  29. throw new \RuntimeException('Swift_Message creation callback should not have been called in this test');
  30. };
  31. $handler = new SwiftMailerHandler($this->mailer, $callback);
  32. $records = array(
  33. $this->getRecord(Logger::DEBUG),
  34. $this->getRecord(Logger::INFO),
  35. );
  36. $handler->handleBatch($records);
  37. }
  38. public function testMessageCanBeCustomizedGivenLoggedData()
  39. {
  40. // Wire Mailer to expect a specific Swift_Message with a customized Subject
  41. $expectedMessage = new \Swift_Message();
  42. $this->mailer->expects($this->once())
  43. ->method('send')
  44. ->with($this->callback(function ($value) use ($expectedMessage) {
  45. return $value instanceof \Swift_Message
  46. && $value->getSubject() === 'Emergency'
  47. && $value === $expectedMessage;
  48. }));
  49. // Callback dynamically changes subject based on number of logged records
  50. $callback = function ($content, array $records) use ($expectedMessage) {
  51. $subject = count($records) > 0 ? 'Emergency' : 'Normal';
  52. $expectedMessage->setSubject($subject);
  53. return $expectedMessage;
  54. };
  55. $handler = new SwiftMailerHandler($this->mailer, $callback);
  56. // Logging 1 record makes this an Emergency
  57. $records = array(
  58. $this->getRecord(Logger::EMERGENCY),
  59. );
  60. $handler->handleBatch($records);
  61. }
  62. public function testMessageHaveUniqueId()
  63. {
  64. $messageTemplate = \Swift_Message::newInstance();
  65. $handler = new SwiftMailerHandler($this->mailer, $messageTemplate);
  66. $method = new \ReflectionMethod('Monolog\Handler\SwiftMailerHandler', 'buildMessage');
  67. $method->setAccessible(true);
  68. $method->invokeArgs($handler, array($messageTemplate, array()));
  69. $builtMessage1 = $method->invoke($handler, $messageTemplate, array());
  70. $builtMessage2 = $method->invoke($handler, $messageTemplate, array());
  71. $this->assertFalse($builtMessage1->getId() === $builtMessage2->getId(), 'Two different messages have the same id');
  72. }
  73. }