mirror of
https://github.com/wallabag/wallabag.git
synced 2025-01-08 16:05:25 +00:00
Use translator interface instead of final class
Symfony use a different class when in dev mode and prod mode. Prod loads `Symfony\Bundle\FrameworkBundle\Translation\Translator`. Dev loads `Symfony\Component\Translation\DataCollectorTranslator` to gather information for the debug bar. Fix #1585
This commit is contained in:
parent
3bcc4d4cb2
commit
e678c4752a
3 changed files with 14 additions and 17 deletions
|
@ -255,7 +255,7 @@ class EntryRepository extends EntityRepository
|
||||||
*
|
*
|
||||||
* @param int $userId
|
* @param int $userId
|
||||||
*
|
*
|
||||||
* @return integer
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function countAllEntriesByUsername($userId)
|
public function countAllEntriesByUsername($userId)
|
||||||
{
|
{
|
||||||
|
|
|
@ -4,7 +4,7 @@ namespace Wallabag\UserBundle\Mailer;
|
||||||
|
|
||||||
use Scheb\TwoFactorBundle\Model\Email\TwoFactorInterface;
|
use Scheb\TwoFactorBundle\Model\Email\TwoFactorInterface;
|
||||||
use Scheb\TwoFactorBundle\Mailer\AuthCodeMailerInterface;
|
use Scheb\TwoFactorBundle\Mailer\AuthCodeMailerInterface;
|
||||||
use Symfony\Component\Translation\DataCollectorTranslator;
|
use Symfony\Component\Translation\TranslatorInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Custom mailer for TwoFactorBundle email.
|
* Custom mailer for TwoFactorBundle email.
|
||||||
|
@ -22,7 +22,7 @@ class AuthCodeMailer implements AuthCodeMailerInterface
|
||||||
/**
|
/**
|
||||||
* Translator for email content.
|
* Translator for email content.
|
||||||
*
|
*
|
||||||
* @var DataCollectorTranslator
|
* @var TranslatorInterface
|
||||||
*/
|
*/
|
||||||
private $translator;
|
private $translator;
|
||||||
|
|
||||||
|
@ -50,13 +50,13 @@ class AuthCodeMailer implements AuthCodeMailerInterface
|
||||||
/**
|
/**
|
||||||
* Initialize the auth code mailer with the SwiftMailer object.
|
* Initialize the auth code mailer with the SwiftMailer object.
|
||||||
*
|
*
|
||||||
* @param \Swift_Mailer $mailer
|
* @param \Swift_Mailer $mailer
|
||||||
* @param DataCollectorTranslator $translator
|
* @param TranslatorInterface $translator
|
||||||
* @param string $senderEmail
|
* @param string $senderEmail
|
||||||
* @param string $senderName
|
* @param string $senderName
|
||||||
* @param string $supportUrl
|
* @param string $supportUrl
|
||||||
*/
|
*/
|
||||||
public function __construct(\Swift_Mailer $mailer, DataCollectorTranslator $translator, $senderEmail, $senderName, $supportUrl)
|
public function __construct(\Swift_Mailer $mailer, TranslatorInterface $translator, $senderEmail, $senderName, $supportUrl)
|
||||||
{
|
{
|
||||||
$this->mailer = $mailer;
|
$this->mailer = $mailer;
|
||||||
$this->translator = $translator;
|
$this->translator = $translator;
|
||||||
|
|
|
@ -6,7 +6,6 @@ use Wallabag\UserBundle\Entity\User;
|
||||||
use Wallabag\UserBundle\Mailer\AuthCodeMailer;
|
use Wallabag\UserBundle\Mailer\AuthCodeMailer;
|
||||||
use Symfony\Component\Translation\Translator;
|
use Symfony\Component\Translation\Translator;
|
||||||
use Symfony\Component\Translation\Loader\ArrayLoader;
|
use Symfony\Component\Translation\Loader\ArrayLoader;
|
||||||
use Symfony\Component\Translation\DataCollectorTranslator;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see https://www.pmg.com/blog/integration-testing-swift-mailer/
|
* @see https://www.pmg.com/blog/integration-testing-swift-mailer/
|
||||||
|
@ -28,7 +27,7 @@ class AuthCodeMailerTest extends \PHPUnit_Framework_TestCase
|
||||||
{
|
{
|
||||||
protected $mailer;
|
protected $mailer;
|
||||||
protected $spool;
|
protected $spool;
|
||||||
protected $dataCollector;
|
protected $translator;
|
||||||
|
|
||||||
protected function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
|
@ -39,14 +38,12 @@ class AuthCodeMailerTest extends \PHPUnit_Framework_TestCase
|
||||||
);
|
);
|
||||||
$this->mailer = new \Swift_Mailer($transport);
|
$this->mailer = new \Swift_Mailer($transport);
|
||||||
|
|
||||||
$translator = new Translator('en');
|
$this->translator = new Translator('en');
|
||||||
$translator->addLoader('array', new ArrayLoader());
|
$this->translator->addLoader('array', new ArrayLoader());
|
||||||
$translator->addResource('array', array(
|
$this->translator->addResource('array', array(
|
||||||
'auth_code.mailer.subject' => 'auth_code subject',
|
'auth_code.mailer.subject' => 'auth_code subject',
|
||||||
'auth_code.mailer.body' => 'Hi %user%, here is the code: %code% and the support: %support%',
|
'auth_code.mailer.body' => 'Hi %user%, here is the code: %code% and the support: %support%',
|
||||||
), 'en', 'wallabag_user');
|
), 'en', 'wallabag_user');
|
||||||
|
|
||||||
$this->dataCollector = new DataCollectorTranslator($translator);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSendEmail()
|
public function testSendEmail()
|
||||||
|
@ -59,7 +56,7 @@ class AuthCodeMailerTest extends \PHPUnit_Framework_TestCase
|
||||||
|
|
||||||
$authCodeMailer = new AuthCodeMailer(
|
$authCodeMailer = new AuthCodeMailer(
|
||||||
$this->mailer,
|
$this->mailer,
|
||||||
$this->dataCollector,
|
$this->translator,
|
||||||
'nobody@test.io',
|
'nobody@test.io',
|
||||||
'wallabag test',
|
'wallabag test',
|
||||||
'http://0.0.0.0'
|
'http://0.0.0.0'
|
||||||
|
|
Loading…
Reference in a new issue