wallabag/tests/Wallabag/CoreBundle/Controller/SecurityControllerTest.php

112 lines
3.4 KiB
PHP
Raw Normal View History

2015-10-14 17:10:12 +02:00
<?php
2016-06-01 21:27:35 +02:00
namespace Tests\Wallabag\CoreBundle\Controller;
2015-10-14 17:10:12 +02:00
2022-08-28 02:01:46 +02:00
use Doctrine\ORM\EntityManagerInterface;
2016-06-01 21:27:35 +02:00
use Tests\Wallabag\CoreBundle\WallabagCoreTestCase;
2022-08-25 21:37:10 +02:00
use Wallabag\UserBundle\Entity\User;
2015-10-14 17:10:12 +02:00
class SecurityControllerTest extends WallabagCoreTestCase
{
2018-03-28 21:56:55 +02:00
public function testLoginWithEmail()
{
$this->logInAsUsingHttp('bigboss@wallabag.org');
$client = $this->getTestClient();
2018-03-28 21:56:55 +02:00
$client->followRedirects();
$crawler = $client->request('GET', '/config');
2020-06-15 13:37:50 +02:00
$this->assertStringContainsString('config.form_feed.description', $crawler->filter('body')->extract(['_text'])[0]);
2018-03-28 21:56:55 +02:00
}
2015-10-14 17:10:12 +02:00
public function testLoginWithout2Factor()
{
$this->logInAs('admin');
$client = $this->getTestClient();
2015-10-14 17:10:12 +02:00
$client->followRedirects();
$crawler = $client->request('GET', '/config');
2020-06-15 13:37:50 +02:00
$this->assertStringContainsString('config.form_feed.description', $crawler->filter('body')->extract(['_text'])[0]);
2015-10-14 17:10:12 +02:00
}
public function testLoginWith2FactorEmail()
2015-10-14 17:10:12 +02:00
{
$client = $this->getTestClient();
2015-10-14 17:10:12 +02:00
if (!$client->getContainer()->getParameter('twofactor_auth')) {
$this->markTestSkipped('twofactor_auth is not enabled.');
2016-03-11 14:55:02 +01:00
return;
}
2015-10-14 17:10:12 +02:00
$client->followRedirects();
2015-10-15 13:17:21 +02:00
2022-08-28 02:01:46 +02:00
$em = $client->getContainer()->get(EntityManagerInterface::class);
$user = $em
2022-08-25 21:37:10 +02:00
->getRepository(User::class)
->findOneByUsername('admin');
$user->setEmailTwoFactor(true);
$em->persist($user);
$em->flush();
2015-10-15 13:17:21 +02:00
$this->logInAsUsingHttp('admin');
$crawler = $client->request('GET', '/config');
2020-06-15 13:37:50 +02:00
$this->assertStringContainsString('trusted', $crawler->filter('body')->extract(['_text'])[0]);
// restore user
$user = $em
2022-08-25 21:37:10 +02:00
->getRepository(User::class)
->findOneByUsername('admin');
$user->setEmailTwoFactor(false);
$em->persist($user);
$em->flush();
2015-10-14 17:10:12 +02:00
}
public function testLoginWith2FactorGoogle()
2015-10-14 17:10:12 +02:00
{
$client = $this->getTestClient();
2015-10-15 13:17:21 +02:00
if (!$client->getContainer()->getParameter('twofactor_auth')) {
$this->markTestSkipped('twofactor_auth is not enabled.');
2016-03-11 14:55:02 +01:00
return;
2015-10-15 13:17:21 +02:00
}
$client->followRedirects();
2022-08-28 02:01:46 +02:00
$em = $client->getContainer()->get(EntityManagerInterface::class);
$user = $em
2022-08-25 21:37:10 +02:00
->getRepository(User::class)
->findOneByUsername('admin');
$user->setGoogleAuthenticatorSecret('26LDIHYGHNELOQEM');
$em->persist($user);
$em->flush();
$this->logInAsUsingHttp('admin');
$crawler = $client->request('GET', '/config');
2020-06-15 13:37:50 +02:00
$this->assertStringContainsString('trusted', $crawler->filter('body')->extract(['_text'])[0]);
// restore user
$user = $em
2022-08-25 21:37:10 +02:00
->getRepository(User::class)
->findOneByUsername('admin');
$user->setGoogleAuthenticatorSecret(null);
$em->persist($user);
$em->flush();
2015-10-14 17:10:12 +02:00
}
2016-08-24 10:28:43 +02:00
public function testEnabledRegistration()
{
$client = $this->getTestClient();
2016-08-24 10:28:43 +02:00
if (!$client->getContainer()->getParameter('fosuser_registration')) {
$this->markTestSkipped('fosuser_registration is not enabled.');
return;
}
$client->followRedirects();
2018-03-28 21:56:55 +02:00
$client->request('GET', '/register');
2020-06-15 13:37:50 +02:00
$this->assertStringContainsString('registration.submit', $client->getResponse()->getContent());
2016-08-24 10:28:43 +02:00
}
2015-10-14 17:10:12 +02:00
}