| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- <?php declare(strict_types=1);
- /*
- * This file is part of the Monolog package.
- *
- * (c) Jordi Boggiano <j.boggiano@seld.be>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Monolog\Handler;
- use Monolog\Test\TestCase;
- use Monolog\Level;
- /**
- * @covers Monolog\Handler\BrowserConsoleHandlerTest
- */
- class BrowserConsoleHandlerTest extends TestCase
- {
- protected function setUp(): void
- {
- BrowserConsoleHandler::resetStatic();
- }
- protected function generateScript()
- {
- $reflMethod = new \ReflectionMethod('Monolog\Handler\BrowserConsoleHandler', 'generateScript');
- return $reflMethod->invoke(null);
- }
- public function testStyling()
- {
- $handler = new BrowserConsoleHandler();
- $handler->setFormatter($this->getIdentityFormatter());
- $handler->handle($this->getRecord(Level::Debug, 'foo[[bar]]{color: red}'));
- $expected = <<<EOF
- (function (c) {if (c && c.groupCollapsed) {
- c.debug("%cfoo%cbar%c", "font-weight: normal", "color: red", "font-weight: normal");
- }})(console);
- EOF;
- $this->assertEquals($expected, $this->generateScript());
- }
- public function testStylingMultiple()
- {
- $handler = new BrowserConsoleHandler();
- $handler->setFormatter($this->getIdentityFormatter());
- $handler->handle($this->getRecord(Level::Debug, 'foo[[bar]]{color: red}[[baz]]{color: blue}'));
- $expected = <<<EOF
- (function (c) {if (c && c.groupCollapsed) {
- c.debug("%cfoo%cbar%c%cbaz%c", "font-weight: normal", "color: red", "font-weight: normal", "color: blue", "font-weight: normal");
- }})(console);
- EOF;
- $this->assertEquals($expected, $this->generateScript());
- }
- public function testEscaping()
- {
- $handler = new BrowserConsoleHandler();
- $handler->setFormatter($this->getIdentityFormatter());
- $handler->handle($this->getRecord(Level::Debug, "[foo] [[\"bar\n[baz]\"]]{color: red}"));
- $expected = <<<EOF
- (function (c) {if (c && c.groupCollapsed) {
- c.debug("%c[foo] %c\"bar\\n[baz]\"%c", "font-weight: normal", "color: red", "font-weight: normal");
- }})(console);
- EOF;
- $this->assertEquals($expected, $this->generateScript());
- }
- public function testAutolabel()
- {
- $handler = new BrowserConsoleHandler();
- $handler->setFormatter($this->getIdentityFormatter());
- $handler->handle($this->getRecord(Level::Debug, '[[foo]]{macro: autolabel}'));
- $handler->handle($this->getRecord(Level::Debug, '[[bar]]{macro: autolabel}'));
- $handler->handle($this->getRecord(Level::Debug, '[[foo]]{macro: autolabel}'));
- $expected = <<<EOF
- (function (c) {if (c && c.groupCollapsed) {
- c.debug("%c%cfoo%c", "font-weight: normal", "background-color: blue; color: white; border-radius: 3px; padding: 0 2px 0 2px", "font-weight: normal");
- c.debug("%c%cbar%c", "font-weight: normal", "background-color: green; color: white; border-radius: 3px; padding: 0 2px 0 2px", "font-weight: normal");
- c.debug("%c%cfoo%c", "font-weight: normal", "background-color: blue; color: white; border-radius: 3px; padding: 0 2px 0 2px", "font-weight: normal");
- }})(console);
- EOF;
- $this->assertEquals($expected, $this->generateScript());
- }
- public function testContext()
- {
- $handler = new BrowserConsoleHandler();
- $handler->setFormatter($this->getIdentityFormatter());
- $handler->handle($this->getRecord(Level::Debug, 'test', ['foo' => 'bar', 0 => 'oop']));
- $expected = <<<EOF
- (function (c) {if (c && c.groupCollapsed) {
- c.groupCollapsed("%ctest", "font-weight: normal");
- c.log("%c%s", "font-weight: bold", "Context");
- c.log("%s: %o", "foo", "bar");
- c.log("%s: %o", "0", "oop");
- c.groupEnd();
- }})(console);
- EOF;
- $this->assertEquals($expected, $this->generateScript());
- }
- public function testConcurrentHandlers()
- {
- $handler1 = new BrowserConsoleHandler();
- $handler1->setFormatter($this->getIdentityFormatter());
- $handler2 = new BrowserConsoleHandler();
- $handler2->setFormatter($this->getIdentityFormatter());
- $handler1->handle($this->getRecord(Level::Debug, 'test1'));
- $handler2->handle($this->getRecord(Level::Debug, 'test2'));
- $handler1->handle($this->getRecord(Level::Debug, 'test3'));
- $handler2->handle($this->getRecord(Level::Debug, 'test4'));
- $expected = <<<EOF
- (function (c) {if (c && c.groupCollapsed) {
- c.debug("%ctest1", "font-weight: normal");
- c.debug("%ctest2", "font-weight: normal");
- c.debug("%ctest3", "font-weight: normal");
- c.debug("%ctest4", "font-weight: normal");
- }})(console);
- EOF;
- $this->assertEquals($expected, $this->generateScript());
- }
- }
|