You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.2 KiB
69 lines
2.2 KiB
9 months ago
|
<?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\Component\Translation\Tests;
|
||
|
|
||
|
use PHPUnit\Framework\TestCase;
|
||
|
use Symfony\Component\Translation\Loader\ArrayLoader;
|
||
|
use Symfony\Component\Translation\LoggingTranslator;
|
||
|
use Symfony\Component\Translation\Translator;
|
||
|
|
||
|
class LoggingTranslatorTest extends TestCase
|
||
|
{
|
||
|
public function testTransWithNoTranslationIsLogged()
|
||
|
{
|
||
|
$logger = $this->getMockBuilder('Psr\Log\LoggerInterface')->getMock();
|
||
|
$logger->expects($this->exactly(1))
|
||
|
->method('warning')
|
||
|
->with('Translation not found.')
|
||
|
;
|
||
|
|
||
|
$translator = new Translator('ar');
|
||
|
$loggableTranslator = new LoggingTranslator($translator, $logger);
|
||
|
$loggableTranslator->trans('bar');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @group legacy
|
||
|
*/
|
||
|
public function testTransChoiceFallbackIsLogged()
|
||
|
{
|
||
|
$logger = $this->getMockBuilder('Psr\Log\LoggerInterface')->getMock();
|
||
|
$logger->expects($this->once())
|
||
|
->method('debug')
|
||
|
->with('Translation use fallback catalogue.')
|
||
|
;
|
||
|
|
||
|
$translator = new Translator('ar');
|
||
|
$translator->setFallbackLocales(['en']);
|
||
|
$translator->addLoader('array', new ArrayLoader());
|
||
|
$translator->addResource('array', ['some_message2' => 'one thing|%count% things'], 'en');
|
||
|
$loggableTranslator = new LoggingTranslator($translator, $logger);
|
||
|
$loggableTranslator->transChoice('some_message2', 10, ['%count%' => 10]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @group legacy
|
||
|
*/
|
||
|
public function testTransChoiceWithNoTranslationIsLogged()
|
||
|
{
|
||
|
$logger = $this->getMockBuilder('Psr\Log\LoggerInterface')->getMock();
|
||
|
$logger->expects($this->exactly(1))
|
||
|
->method('warning')
|
||
|
->with('Translation not found.')
|
||
|
;
|
||
|
|
||
|
$translator = new Translator('ar');
|
||
|
$loggableTranslator = new LoggingTranslator($translator, $logger);
|
||
|
$loggableTranslator->transChoice('some_message2', 10, ['%count%' => 10]);
|
||
|
}
|
||
|
}
|