123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Bridge\Doctrine\Tests\Logger;
- use Symfony\Bridge\Doctrine\Logger\DbalLogger;
- class DbalLoggerTest extends \PHPUnit_Framework_TestCase
- {
- /**
- * @dataProvider getLogFixtures
- */
- public function testLog($sql, $params, $logParams)
- {
- $logger = $this->getMock('Psr\\Log\\LoggerInterface');
- $dbalLogger = $this
- ->getMockBuilder('Symfony\\Bridge\\Doctrine\\Logger\\DbalLogger')
- ->setConstructorArgs(array($logger, null))
- ->setMethods(array('log'))
- ->getMock()
- ;
- $dbalLogger
- ->expects($this->once())
- ->method('log')
- ->with($sql, $logParams)
- ;
- $dbalLogger->startQuery($sql, $params);
- }
- public function getLogFixtures()
- {
- return array(
- array('SQL', null, array()),
- array('SQL', array(), array()),
- array('SQL', array('foo' => 'bar'), array('foo' => 'bar'))
- );
- }
- public function testLogNonUtf8()
- {
- $logger = $this->getMock('Psr\\Log\\LoggerInterface');
- $dbalLogger = $this
- ->getMockBuilder('Symfony\\Bridge\\Doctrine\\Logger\\DbalLogger')
- ->setConstructorArgs(array($logger, null))
- ->setMethods(array('log'))
- ->getMock()
- ;
- $dbalLogger
- ->expects($this->once())
- ->method('log')
- ->with('SQL', array('utf8' => 'foo', 'nonutf8' => DbalLogger::BINARY_DATA_VALUE))
- ;
- $dbalLogger->startQuery('SQL', array(
- 'utf8' => 'foo',
- 'nonutf8' => "\x7F\xFF",
- ));
- }
- public function testLogLongString()
- {
- $logger = $this->getMock('Symfony\\Component\\HttpKernel\\Log\\LoggerInterface');
- $dbalLogger = $this
- ->getMockBuilder('Symfony\\Bridge\\Doctrine\\Logger\\DbalLogger')
- ->setConstructorArgs(array($logger, null))
- ->setMethods(array('log'))
- ->getMock()
- ;
- $testString = 'abc';
- $shortString = str_pad('', DbalLogger::MAX_STRING_LENGTH, $testString);
- $longString = str_pad('', DbalLogger::MAX_STRING_LENGTH+1, $testString);
- $dbalLogger
- ->expects($this->once())
- ->method('log')
- ->with('SQL', array('short' => $shortString, 'long' => substr($longString, 0, DbalLogger::MAX_STRING_LENGTH - 6).' [...]'))
- ;
- $dbalLogger->startQuery('SQL', array(
- 'short' => $shortString,
- 'long' => $longString,
- ));
- }
- public function testLogUTF8LongString()
- {
- if (!function_exists('mb_detect_encoding')) {
- $this->markTestSkipped('Testing log shortening of utf8 charsets requires the mb_detect_encoding() function.');
- }
- $logger = $this->getMock('Symfony\\Component\\HttpKernel\\Log\\LoggerInterface');
- $dbalLogger = $this
- ->getMockBuilder('Symfony\\Bridge\\Doctrine\\Logger\\DbalLogger')
- ->setConstructorArgs(array($logger, null))
- ->setMethods(array('log'))
- ->getMock()
- ;
- $testStringArray = array('é', 'á', 'ű', 'ő', 'ú', 'ö', 'ü', 'ó', 'í');
- $testStringCount = count($testStringArray);
- $shortString = '';
- $longString = '';
- for ($i = 1; $i <= DbalLogger::MAX_STRING_LENGTH; $i++) {
- $shortString .= $testStringArray[$i % $testStringCount];
- $longString .= $testStringArray[$i % $testStringCount];
- }
- $longString .= $testStringArray[$i % $testStringCount];
- $dbalLogger
- ->expects($this->once())
- ->method('log')
- ->with('SQL', array('short' => $shortString, 'long' => mb_substr($longString, 0, DbalLogger::MAX_STRING_LENGTH - 6, mb_detect_encoding($longString)).' [...]'))
- ;
- $dbalLogger->startQuery('SQL', array(
- 'short' => $shortString,
- 'long' => $longString,
- ));
- }
- }
|