aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php
diff options
context:
space:
mode:
authorNicolas LÅ“uillet <nicolas@loeuillet.org>2016-06-23 09:18:18 +0200
committerGitHub <noreply@github.com>2016-06-23 09:18:18 +0200
commitd37bb05c881bfdbeb1144b327edd4dcc2cbb163f (patch)
tree1b90f7e733a83af4741a8cb7f49edf3e303f8677 /tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php
parent891a026e31ad54ca90b70f6026f23260cfadb7fd (diff)
parent99451fe4b76051d61922a6beb7ee9e79cc6e7893 (diff)
downloadwallabag-d37bb05c881bfdbeb1144b327edd4dcc2cbb163f.tar.gz
wallabag-d37bb05c881bfdbeb1144b327edd4dcc2cbb163f.tar.zst
wallabag-d37bb05c881bfdbeb1144b327edd4dcc2cbb163f.zip
Merge pull request #2132 from wallabag/sf3.1
Jump to Symfony 3.1
Diffstat (limited to 'tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php')
-rw-r--r--tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php84
1 files changed, 84 insertions, 0 deletions
diff --git a/tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php b/tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php
new file mode 100644
index 00000000..f670c925
--- /dev/null
+++ b/tests/Wallabag/UserBundle/Mailer/AuthCodeMailerTest.php
@@ -0,0 +1,84 @@
1<?php
2
3namespace Tests\Wallabag\UserBundle\Mailer;
4
5use Wallabag\UserBundle\Entity\User;
6use Wallabag\UserBundle\Mailer\AuthCodeMailer;
7
8/**
9 * @see https://www.pmg.com/blog/integration-testing-swift-mailer/
10 */
11final class CountableMemorySpool extends \Swift_MemorySpool implements \Countable
12{
13 public function count()
14 {
15 return count($this->messages);
16 }
17
18 public function getMessages()
19 {
20 return $this->messages;
21 }
22}
23
24class AuthCodeMailerTest extends \PHPUnit_Framework_TestCase
25{
26 protected $mailer;
27 protected $spool;
28 protected $twig;
29 protected $config;
30
31 protected function setUp()
32 {
33 $this->spool = new CountableMemorySpool();
34 $transport = new \Swift_Transport_SpoolTransport(
35 new \Swift_Events_SimpleEventDispatcher(),
36 $this->spool
37 );
38 $this->mailer = new \Swift_Mailer($transport);
39
40 $twigTemplate = <<<TWIG
41{% block subject %}subject{% endblock %}
42{% block body_html %}html body {{ code }}{% endblock %}
43{% block body_text %}text body {{ support_url }}{% endblock %}
44TWIG;
45
46 $this->twig = new \Twig_Environment(new \Twig_Loader_Array(['WallabagUserBundle:TwoFactor:email_auth_code.html.twig' => $twigTemplate]));
47
48 $this->config = $this->getMockBuilder('Craue\ConfigBundle\Util\Config')
49 ->disableOriginalConstructor()
50 ->getMock();
51
52 $this->config->expects($this->any())
53 ->method('get')
54 ->willReturn('http://0.0.0.0/support');
55 }
56
57 public function testSendEmail()
58 {
59 $user = new User();
60 $user->setTwoFactorAuthentication(true);
61 $user->setEmailAuthCode(666666);
62 $user->setEmail('test@wallabag.io');
63 $user->setName('Bob');
64
65 $authCodeMailer = new AuthCodeMailer(
66 $this->mailer,
67 $this->twig,
68 'nobody@test.io',
69 'wallabag test',
70 $this->config
71 );
72
73 $authCodeMailer->sendAuthCode($user);
74
75 $this->assertCount(1, $this->spool);
76
77 $msg = $this->spool->getMessages()[0];
78 $this->assertArrayHasKey('test@wallabag.io', $msg->getTo());
79 $this->assertEquals(['nobody@test.io' => 'wallabag test'], $msg->getFrom());
80 $this->assertEquals('subject', $msg->getSubject());
81 $this->assertContains('text body http://0.0.0.0/support', $msg->toString());
82 $this->assertContains('html body 666666', $msg->toString());
83 }
84}