mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-04-19 11:39:48 +00:00

* bump packages * dynamic invoice options * make sure that invoice previews can be detected * support for mpdf associated files * do not include any future times in work contract calculation * re-add username column in Excel spreadsheet * deactivate internal rate editing * show if plugin update exists * shorten name to Kimai only, without Time-Tracking * remove check for existing id in work contract * fix metafield already defined in search * helper methods to unlock months * new translation * send event on unlock month
156 lines
6.4 KiB
PHP
156 lines
6.4 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Kimai time-tracking app.
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace App\Tests\Controller\Security;
|
|
|
|
use App\Tests\Controller\AbstractControllerBaseTestCase;
|
|
|
|
/**
|
|
* @group integration
|
|
*/
|
|
class PasswordResetControllerTest extends AbstractControllerBaseTestCase
|
|
{
|
|
private function testResetActionWithDeactivatedFeature(string $route, string $method = 'GET'): void
|
|
{
|
|
$client = self::createClient();
|
|
$this->setSystemConfiguration('user.password_reset', false);
|
|
$this->request($client, $route, $method);
|
|
$this->assertRouteNotFound($client);
|
|
}
|
|
|
|
public function testResetRequestWithDeactivatedFeature(): void
|
|
{
|
|
$this->testResetActionWithDeactivatedFeature('/resetting/request');
|
|
}
|
|
|
|
public function testSendEmailRequestWithDeactivatedFeature(): void
|
|
{
|
|
$this->testResetActionWithDeactivatedFeature('/resetting/send-email', 'POST');
|
|
}
|
|
|
|
public function testCheckEmailWithDeactivatedFeature(): void
|
|
{
|
|
$this->testResetActionWithDeactivatedFeature('/resetting/check-email');
|
|
}
|
|
|
|
public function testResetRequestPageIsRendered(): void
|
|
{
|
|
$client = self::createClient();
|
|
|
|
$this->setSystemConfiguration('user.password_reset', true);
|
|
$this->request($client, '/resetting/request');
|
|
|
|
$response = $client->getResponse();
|
|
self::assertTrue($response->isSuccessful());
|
|
|
|
$content = $response->getContent();
|
|
self::assertNotFalse($content);
|
|
self::assertStringContainsString('<title>Kimai</title>', $content);
|
|
self::assertStringContainsString('Reset your password', $content);
|
|
self::assertStringContainsString('<form class="card-body security-password-reset" action="/en/resetting/send-email" method="post" autocomplete="off">', $content);
|
|
self::assertStringContainsString('<input autocomplete="username" type="text"', $content);
|
|
self::assertStringContainsString('id="username" name="username" required="required"', $content);
|
|
self::assertStringContainsString('Reset your password', $content);
|
|
|
|
$form = $client->getCrawler()->filter('form')->form();
|
|
$client->submit($form, [
|
|
'username' => 'john_user',
|
|
]);
|
|
|
|
$this->assertIsRedirect($client, $this->createUrl('/resetting/check-email'));
|
|
$client->followRedirect();
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
|
|
// TODO test the actual email and provided login link
|
|
|
|
$user = $this->loadUserFromDatabase('john_user');
|
|
self::assertTrue($user->requiresPasswordReset());
|
|
}
|
|
|
|
public function testRequestAsLoggedInUserRedirects(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser();
|
|
$this->request($client, '/resetting/request');
|
|
$this->assertIsRedirect($client, $this->createUrl('/homepage'));
|
|
}
|
|
|
|
public function testResetAsLoggedInUserRedirects(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser();
|
|
$this->request($client, '/resetting/send-email', 'POST');
|
|
$this->assertIsRedirect($client, $this->createUrl('/homepage'));
|
|
}
|
|
|
|
public function testResetWithMissingUsername(): void
|
|
{
|
|
$client = self::createClient();
|
|
$this->request($client, '/resetting/send-email', 'POST');
|
|
$this->assertIsRedirect($client, $this->createUrl('/resetting/check-email'));
|
|
$client->followRedirect();
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertNotFalse($content);
|
|
self::assertStringContainsString('An email has been sent with a link to reset your password.', $content);
|
|
self::assertStringContainsString('Note: You can only request a new password once every 1:00 hours.', $content);
|
|
}
|
|
|
|
public function testResetWithEmptyUsername(): void
|
|
{
|
|
$client = self::createClient();
|
|
$this->request($client, '/resetting/send-email', 'POST', ['username' => '']);
|
|
$this->assertIsRedirect($client, $this->createUrl('/resetting/check-email'));
|
|
$client->followRedirect();
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertNotFalse($content);
|
|
self::assertStringContainsString('An email has been sent with a link to reset your password.', $content);
|
|
self::assertStringContainsString('Note: You can only request a new password once every 1:00 hours.', $content);
|
|
}
|
|
|
|
public function testResetWithUnknownUsername(): void
|
|
{
|
|
$client = self::createClient();
|
|
$this->request($client, '/resetting/send-email', 'POST', ['username' => 'foobar']);
|
|
$this->assertIsRedirect($client, $this->createUrl('/resetting/check-email'));
|
|
$client->followRedirect();
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertNotFalse($content);
|
|
self::assertStringContainsString('An email has been sent with a link to reset your password.', $content);
|
|
self::assertStringContainsString('Note: You can only request a new password once every 1:00 hours.', $content);
|
|
}
|
|
|
|
public function testResetWithKnownUsername(): void
|
|
{
|
|
$client = self::createClient();
|
|
|
|
$user = $this->loadUserFromDatabase('john_user');
|
|
self::assertFalse($user->requiresPasswordReset());
|
|
|
|
$this->request($client, '/resetting/request');
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$form = $client->getCrawler()->filter('form')->form();
|
|
$client->submit($form, [
|
|
'username' => 'john_user',
|
|
]);
|
|
|
|
$this->assertIsRedirect($client, $this->createUrl('/resetting/check-email'));
|
|
$client->followRedirect();
|
|
self::assertTrue($client->getResponse()->isSuccessful());
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertNotFalse($content);
|
|
self::assertStringContainsString('An email has been sent with a link to reset your password.', $content);
|
|
self::assertStringContainsString('Note: You can only request a new password once every 1:00 hours.', $content);
|
|
|
|
// TODO test the actual email and provided login link
|
|
|
|
$user = $this->loadUserFromDatabase('john_user');
|
|
self::assertTrue($user->requiresPasswordReset());
|
|
}
|
|
}
|