diff options
| author | Frédéric Guillot <fred@kanboard.net> | 2017-12-15 11:24:35 -0800 | 
|---|---|---|
| committer | Frédéric Guillot <fred@kanboard.net> | 2017-12-15 11:55:42 -0800 | 
| commit | a93b8e10f5954be0853eec693c13e84c4bd9e6f2 (patch) | |
| tree | eda5de9494b819235616e8623bb3393e9cc373af /vendor/symfony/console/Tests/Logger | |
| parent | 2c72a283f2d51034f85f4e2ca8b194d304a3c433 (diff) | |
Kanboard requires at least PHP 5.6 now
Diffstat (limited to 'vendor/symfony/console/Tests/Logger')
| -rw-r--r-- | vendor/symfony/console/Tests/Logger/ConsoleLoggerTest.php | 165 | 
1 files changed, 161 insertions, 4 deletions
| diff --git a/vendor/symfony/console/Tests/Logger/ConsoleLoggerTest.php b/vendor/symfony/console/Tests/Logger/ConsoleLoggerTest.php index c5eca2ca..734a153e 100644 --- a/vendor/symfony/console/Tests/Logger/ConsoleLoggerTest.php +++ b/vendor/symfony/console/Tests/Logger/ConsoleLoggerTest.php @@ -11,9 +11,11 @@  namespace Symfony\Component\Console\Tests\Logger; -use Psr\Log\Test\LoggerInterfaceTest; +use PHPUnit\Framework\TestCase; +use Psr\Log\LoggerInterface;  use Psr\Log\LogLevel;  use Symfony\Component\Console\Logger\ConsoleLogger; +use Symfony\Component\Console\Output\BufferedOutput;  use Symfony\Component\Console\Tests\Fixtures\DummyOutput;  use Symfony\Component\Console\Output\OutputInterface; @@ -21,8 +23,9 @@ use Symfony\Component\Console\Output\OutputInterface;   * Console logger test.   *   * @author Kévin Dunglas <dunglas@gmail.com> + * @author Jordi Boggiano <j.boggiano@seld.be>   */ -class ConsoleLoggerTest extends LoggerInterfaceTest +class ConsoleLoggerTest extends TestCase  {      /**       * @var DummyOutput @@ -30,7 +33,7 @@ class ConsoleLoggerTest extends LoggerInterfaceTest      protected $output;      /** -     * {@inheritdoc} +     * @return LoggerInterface       */      public function getLogger()      { @@ -49,10 +52,164 @@ class ConsoleLoggerTest extends LoggerInterfaceTest      }      /** -     * {@inheritdoc} +     * Return the log messages in order. +     * +     * @return string[]       */      public function getLogs()      {          return $this->output->getLogs();      } + +    /** +     * @dataProvider provideOutputMappingParams +     */ +    public function testOutputMapping($logLevel, $outputVerbosity, $isOutput, $addVerbosityLevelMap = array()) +    { +        $out = new BufferedOutput($outputVerbosity); +        $logger = new ConsoleLogger($out, $addVerbosityLevelMap); +        $logger->log($logLevel, 'foo bar'); +        $logs = $out->fetch(); +        $this->assertEquals($isOutput ? "[$logLevel] foo bar".PHP_EOL : '', $logs); +    } + +    public function provideOutputMappingParams() +    { +        $quietMap = array(LogLevel::EMERGENCY => OutputInterface::VERBOSITY_QUIET); + +        return array( +            array(LogLevel::EMERGENCY, OutputInterface::VERBOSITY_NORMAL, true), +            array(LogLevel::WARNING, OutputInterface::VERBOSITY_NORMAL, true), +            array(LogLevel::INFO, OutputInterface::VERBOSITY_NORMAL, false), +            array(LogLevel::DEBUG, OutputInterface::VERBOSITY_NORMAL, false), +            array(LogLevel::INFO, OutputInterface::VERBOSITY_VERBOSE, false), +            array(LogLevel::INFO, OutputInterface::VERBOSITY_VERY_VERBOSE, true), +            array(LogLevel::DEBUG, OutputInterface::VERBOSITY_VERY_VERBOSE, false), +            array(LogLevel::DEBUG, OutputInterface::VERBOSITY_DEBUG, true), +            array(LogLevel::ALERT, OutputInterface::VERBOSITY_QUIET, false), +            array(LogLevel::EMERGENCY, OutputInterface::VERBOSITY_QUIET, false), +            array(LogLevel::ALERT, OutputInterface::VERBOSITY_QUIET, false, $quietMap), +            array(LogLevel::EMERGENCY, OutputInterface::VERBOSITY_QUIET, true, $quietMap), +        ); +    } + +    public function testHasErrored() +    { +        $logger = new ConsoleLogger(new BufferedOutput()); + +        $this->assertFalse($logger->hasErrored()); + +        $logger->warning('foo'); +        $this->assertFalse($logger->hasErrored()); + +        $logger->error('bar'); +        $this->assertTrue($logger->hasErrored()); +    } + +    public function testImplements() +    { +        $this->assertInstanceOf('Psr\Log\LoggerInterface', $this->getLogger()); +    } + +    /** +     * @dataProvider provideLevelsAndMessages +     */ +    public function testLogsAtAllLevels($level, $message) +    { +        $logger = $this->getLogger(); +        $logger->{$level}($message, array('user' => 'Bob')); +        $logger->log($level, $message, array('user' => 'Bob')); + +        $expected = array( +            $level.' message of level '.$level.' with context: Bob', +            $level.' message of level '.$level.' with context: Bob', +        ); +        $this->assertEquals($expected, $this->getLogs()); +    } + +    public function provideLevelsAndMessages() +    { +        return array( +            LogLevel::EMERGENCY => array(LogLevel::EMERGENCY, 'message of level emergency with context: {user}'), +            LogLevel::ALERT => array(LogLevel::ALERT, 'message of level alert with context: {user}'), +            LogLevel::CRITICAL => array(LogLevel::CRITICAL, 'message of level critical with context: {user}'), +            LogLevel::ERROR => array(LogLevel::ERROR, 'message of level error with context: {user}'), +            LogLevel::WARNING => array(LogLevel::WARNING, 'message of level warning with context: {user}'), +            LogLevel::NOTICE => array(LogLevel::NOTICE, 'message of level notice with context: {user}'), +            LogLevel::INFO => array(LogLevel::INFO, 'message of level info with context: {user}'), +            LogLevel::DEBUG => array(LogLevel::DEBUG, 'message of level debug with context: {user}'), +        ); +    } + +    /** +     * @expectedException \Psr\Log\InvalidArgumentException +     */ +    public function testThrowsOnInvalidLevel() +    { +        $logger = $this->getLogger(); +        $logger->log('invalid level', 'Foo'); +    } + +    public function testContextReplacement() +    { +        $logger = $this->getLogger(); +        $logger->info('{Message {nothing} {user} {foo.bar} a}', array('user' => 'Bob', 'foo.bar' => 'Bar')); + +        $expected = array('info {Message {nothing} Bob Bar a}'); +        $this->assertEquals($expected, $this->getLogs()); +    } + +    public function testObjectCastToString() +    { +        if (method_exists($this, 'createPartialMock')) { +            $dummy = $this->createPartialMock('Symfony\Component\Console\Tests\Logger\DummyTest', array('__toString')); +        } else { +            $dummy = $this->getMock('Symfony\Component\Console\Tests\Logger\DummyTest', array('__toString')); +        } +        $dummy->method('__toString')->will($this->returnValue('DUMMY')); + +        $this->getLogger()->warning($dummy); + +        $expected = array('warning DUMMY'); +        $this->assertEquals($expected, $this->getLogs()); +    } + +    public function testContextCanContainAnything() +    { +        $context = array( +            'bool' => true, +            'null' => null, +            'string' => 'Foo', +            'int' => 0, +            'float' => 0.5, +            'nested' => array('with object' => new DummyTest()), +            'object' => new \DateTime(), +            'resource' => fopen('php://memory', 'r'), +        ); + +        $this->getLogger()->warning('Crazy context data', $context); + +        $expected = array('warning Crazy context data'); +        $this->assertEquals($expected, $this->getLogs()); +    } + +    public function testContextExceptionKeyCanBeExceptionOrOtherValues() +    { +        $logger = $this->getLogger(); +        $logger->warning('Random message', array('exception' => 'oops')); +        $logger->critical('Uncaught Exception!', array('exception' => new \LogicException('Fail'))); + +        $expected = array( +            'warning Random message', +            'critical Uncaught Exception!', +        ); +        $this->assertEquals($expected, $this->getLogs()); +    } +} + +class DummyTest +{ +    public function __toString() +    { +    }  } | 
