aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/Wallabag/CoreBundle/Tests/Controller/SecurityControllerTest.php
blob: b9f5d835589676beb6890612a2e39d6ee93e1a06 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<?php

namespace Wallabag\CoreBundle\Tests\Controller;

use Wallabag\CoreBundle\Tests\WallabagCoreTestCase;

class SecurityControllerTest extends WallabagCoreTestCase
{
    public function testLoginWithout2Factor()
    {
        $this->logInAs('admin');
        $client = $this->getClient();
        $client->followRedirects();

        $client->request('GET', '/config');
        $this->assertContains('RSS', $client->getResponse()->getContent());
    }

    public function testLoginWith2Factor()
    {
        $client = $this->getClient();

        if ($client->getContainer()->getParameter('twofactor_auth')) {
            $client->followRedirects();

            $em = $client->getContainer()->get('doctrine.orm.entity_manager');
            $user = $em
                ->getRepository('WallabagUserBundle:User')
                ->findOneByUsername('admin');
            $user->setTwoFactorAuthentication(true);
            $em->persist($user);
            $em->flush();

            $this->logInAs('admin');
            $client->request('GET', '/config');
            $this->assertContains('trusted computer', $client->getResponse()->getContent());

            // restore user
            $user = $em
                ->getRepository('WallabagUserBundle:User')
                ->findOneByUsername('admin');
            $user->setTwoFactorAuthentication(false);
            $em->persist($user);
            $em->flush();
        }
    }

    public function testTrustedComputer()
    {
        $client = $this->getClient();

        if ($client->getContainer()->getParameter('twofactor_auth')) {
            $em = $client->getContainer()->get('doctrine.orm.entity_manager');
            $user = $em
                ->getRepository('WallabagUserBundle:User')
                ->findOneByUsername('admin');

            $date = new \DateTime();
            $user->addTrustedComputer('ABCDEF', $date->add(new \DateInterval('P1M')));
            $this->assertTrue($user->isTrustedComputer('ABCDEF'));
            $this->assertFalse($user->isTrustedComputer('FEDCBA'));
        }
    }
}