aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/Wallabag/UserBundle/Mailer
diff options
context:
space:
mode:
authorJeremy Benoist <jeremy.benoist@gmail.com>2016-06-23 11:47:46 +0200
committerJeremy Benoist <jeremy.benoist@gmail.com>2016-06-23 11:47:46 +0200
commitf49d9ca383c9f8a1bc426cfabf6b1cea53ea26b4 (patch)
tree156b1a29cfbe1962e68d409c3dea5a3911a34e9c /tests/Wallabag/UserBundle/Mailer
parent49e2854d5c15bbce3f24f91da34450e8f209295b (diff)
parentfb5c17a9ab5e10b1de9caa50e73638fdae19cb78 (diff)
downloadwallabag-f49d9ca383c9f8a1bc426cfabf6b1cea53ea26b4.tar.gz
wallabag-f49d9ca383c9f8a1bc426cfabf6b1cea53ea26b4.tar.zst
wallabag-f49d9ca383c9f8a1bc426cfabf6b1cea53ea26b4.zip
Merge branch 'master' into 2.1
Diffstat (limited to 'tests/Wallabag/UserBundle/Mailer')
-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}