|
13 | 13 |
|
14 | 14 | use Monolog\Logger;
|
15 | 15 | use Symfony\Bridge\Monolog\Handler\ConsoleHandler;
|
| 16 | +use Symfony\Component\Console\ConsoleEvents; |
| 17 | +use Symfony\Component\Console\Event\ConsoleCommandEvent; |
| 18 | +use Symfony\Component\Console\Event\ConsoleTerminateEvent; |
16 | 19 | use Symfony\Component\Console\Output\OutputInterface;
|
| 20 | +use Symfony\Component\Console\Output\BufferedOutput; |
| 21 | +use Symfony\Component\EventDispatcher\EventDispatcher; |
| 22 | +use Symfony\Component\Console\Command\Command; |
17 | 23 |
|
18 | 24 | /**
|
19 | 25 | * Tests the ConsoleHandler and also the ConsoleFormatter.
|
@@ -156,4 +162,42 @@ public function testWritingAndFormatting()
|
156 | 162 |
|
157 | 163 | $this->assertTrue($handler->handle($errorRecord), 'The handler finished handling the log as bubble is false.');
|
158 | 164 | }
|
| 165 | + |
| 166 | + public function testLogsFromListeners() |
| 167 | + { |
| 168 | + $output = new BufferedOutput(); |
| 169 | + $output->setVerbosity(OutputInterface::VERBOSITY_DEBUG); |
| 170 | + |
| 171 | + $handler = new ConsoleHandler(null, false); |
| 172 | + |
| 173 | + $logger = new Logger('app'); |
| 174 | + $logger->pushHandler($handler); |
| 175 | + |
| 176 | + $dispatcher = new EventDispatcher(); |
| 177 | + $dispatcher->addListener(ConsoleEvents::COMMAND, function () use ($logger) { |
| 178 | + $logger->addInfo('Before command message.'); |
| 179 | + }); |
| 180 | + $dispatcher->addListener(ConsoleEvents::TERMINATE, function () use ($logger) { |
| 181 | + $logger->addInfo('Before terminate message.'); |
| 182 | + }); |
| 183 | + |
| 184 | + $dispatcher->addSubscriber($handler); |
| 185 | + |
| 186 | + $dispatcher->addListener(ConsoleEvents::COMMAND, function () use ($logger) { |
| 187 | + $logger->addInfo('After command message.'); |
| 188 | + }); |
| 189 | + $dispatcher->addListener(ConsoleEvents::TERMINATE, function () use ($logger) { |
| 190 | + $logger->addInfo('After terminate message.'); |
| 191 | + }); |
| 192 | + |
| 193 | + $event = new ConsoleCommandEvent(new Command('foo'), $this->getMock('Symfony\Component\Console\Input\InputInterface'), $output); |
| 194 | + $dispatcher->dispatch(ConsoleEvents::COMMAND, $event); |
| 195 | + $this->assertContains('Before command message.', $out = $output->fetch()); |
| 196 | + $this->assertContains('After command message.', $out); |
| 197 | + |
| 198 | + $event = new ConsoleTerminateEvent(new Command('foo'), $this->getMock('Symfony\Component\Console\Input\InputInterface'), $output, 0); |
| 199 | + $dispatcher->dispatch(ConsoleEvents::TERMINATE, $event); |
| 200 | + $this->assertContains('Before terminate message.', $out = $output->fetch()); |
| 201 | + $this->assertContains('After terminate message.', $out); |
| 202 | + } |
159 | 203 | }
|
0 commit comments