- public function testUserEnable2faEmail()
- {
- $this->logInAs('admin');
- $client = $this->getClient();
-
- $crawler = $client->request('GET', '/config');
-
- $this->assertSame(200, $client->getResponse()->getStatusCode());
-
- $form = $crawler->filter('button[id=update_user_save]')->form();
-
- $data = [
- 'update_user[emailTwoFactor]' => '1',
- ];
-
- $client->submit($form, $data);
-
- $this->assertSame(302, $client->getResponse()->getStatusCode());
-
- $crawler = $client->followRedirect();
-
- $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
- $this->assertContains('flashes.config.notice.user_updated', $alert[0]);
-
- // restore user
- $em = $this->getEntityManager();
- $user = $em
- ->getRepository('WallabagUserBundle:User')
- ->findOneByUsername('admin');
-
- $this->assertTrue($user->isEmailTwoFactor());
-
- $user->setEmailTwoFactor(false);
- $em->persist($user);
- $em->flush();
- }
-
- public function testUserEnable2faGoogle()
- {
- $this->logInAs('admin');
- $client = $this->getClient();
-
- $crawler = $client->request('GET', '/config');
-
- $this->assertSame(200, $client->getResponse()->getStatusCode());
-
- $form = $crawler->filter('button[id=update_user_save]')->form();
-
- $data = [
- 'update_user[googleTwoFactor]' => '1',
- ];
-
- $client->submit($form, $data);
-
- $this->assertSame(302, $client->getResponse()->getStatusCode());
-
- $crawler = $client->followRedirect();
-
- $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
- $this->assertContains('flashes.config.notice.user_updated', $alert[0]);
-
- // restore user
- $em = $this->getEntityManager();
- $user = $em
- ->getRepository('WallabagUserBundle:User')
- ->findOneByUsername('admin');
-
- $this->assertTrue($user->isGoogleAuthenticatorEnabled());
-
- $user->setGoogleAuthenticatorSecret(null);
- $em->persist($user);
- $em->flush();
- }
-
- public function testUserEnable2faBoth()
- {
- $this->logInAs('admin');
- $client = $this->getClient();
-
- $crawler = $client->request('GET', '/config');
-
- $this->assertSame(200, $client->getResponse()->getStatusCode());
-
- $form = $crawler->filter('button[id=update_user_save]')->form();
-
- $data = [
- 'update_user[googleTwoFactor]' => '1',
- 'update_user[emailTwoFactor]' => '1',
- ];
-
- $client->submit($form, $data);
-
- $this->assertSame(302, $client->getResponse()->getStatusCode());
-
- $crawler = $client->followRedirect();
-
- $this->assertGreaterThan(1, $alert = $crawler->filter('body')->extract(['_text']));
- $this->assertContains('flashes.config.notice.user_updated', $alert[0]);
-
- // restore user
- $em = $this->getEntityManager();
- $user = $em
- ->getRepository('WallabagUserBundle:User')
- ->findOneByUsername('admin');
-
- $this->assertTrue($user->isGoogleAuthenticatorEnabled());
- $this->assertFalse($user->isEmailTwoFactor());
-
- $user->setGoogleAuthenticatorSecret(null);
- $em->persist($user);
- $em->flush();
- }
-