summaryrefslogtreecommitdiffstats
path: root/tests/Core/Controller/LostControllerTest.php
diff options
context:
space:
mode:
authorJulius Haertl <jus@bitgrid.net>2016-05-19 22:40:53 +0200
committerJulius Haertl <jus@bitgrid.net>2016-05-23 16:48:10 +0200
commitd06598081471896dde67a15bb02cae49d1548480 (patch)
treee7bcd41947b28ead9ba7d1480112aed97a00d541 /tests/Core/Controller/LostControllerTest.php
parent8ee2cb47d09fbcf7c188d48ab6c840fbffbade95 (diff)
downloadnextcloud-server-d06598081471896dde67a15bb02cae49d1548480.tar.gz
nextcloud-server-d06598081471896dde67a15bb02cae49d1548480.zip
Add more tests for OC\Core\Controller\LostController
- remove testResetFormUnsuccessful as it is now splitted up in different test cases - add testResetFormInvalidToken to check if timestamp and token are present - add testResetFormInvalidTokenMatch to check if the saved token matches the provided - add testResetFormExpiredToken to check if expiration detection works - add testResetFormValidToken to check if detection of valid tokens works
Diffstat (limited to 'tests/Core/Controller/LostControllerTest.php')
-rw-r--r--tests/Core/Controller/LostControllerTest.php107
1 files changed, 104 insertions, 3 deletions
diff --git a/tests/Core/Controller/LostControllerTest.php b/tests/Core/Controller/LostControllerTest.php
index ca63c3404eb..492a04bcfde 100644
--- a/tests/Core/Controller/LostControllerTest.php
+++ b/tests/Core/Controller/LostControllerTest.php
@@ -114,14 +114,115 @@ class LostControllerTest extends \PHPUnit_Framework_TestCase {
);
}
- public function testResetFormUnsuccessful() {
+ public function testResetFormInvalidToken() {
$userId = 'admin';
$token = 'MySecretToken';
+ $response = $this->lostController->resetform($token, $userId);
+ $expectedResponse = new TemplateResponse('core',
+ 'error',
+ [
+ 'errors' => [
+ ['error' => 'Couldn\'t reset password because the token is invalid'],
+ ]
+ ],
+ 'guest');
+ $this->assertEquals($expectedResponse, $response);
+ }
+
+ public function testResetFormInvalidTokenMatch() {
+ $this->config
+ ->expects($this->once())
+ ->method('getUserValue')
+ ->with('ValidTokenUser', 'owncloud', 'lostpassword', null)
+ ->will($this->returnValue('12345:TheOnlyAndOnlyOneTokenToResetThePassword'));
+ $user = $this->getMockBuilder('\OCP\IUser')
+ ->disableOriginalConstructor()->getMock();
+ $user
+ ->expects($this->once())
+ ->method('getLastLogin')
+ ->will($this->returnValue(12344));
+ $this->userManager
+ ->expects($this->once())
+ ->method('get')
+ ->with('ValidTokenUser')
+ ->will($this->returnValue($user));
+ $userId = 'ValidTokenUser';
+ $token = '12345:MySecretToken';
+ $response = $this->lostController->resetform($token, $userId);
+ $expectedResponse = new TemplateResponse('core',
+ 'error',
+ [
+ 'errors' => [
+ ['error' => 'Couldn\'t reset password because the token is invalid'],
+ ]
+ ],
+ 'guest');
+ $this->assertEquals($expectedResponse, $response);
+ }
+
+
+ public function testResetFormExpiredToken() {
+ $userId = 'ValidTokenUser';
+ $token = '12345:TheOnlyAndOnlyOneTokenToResetThePassword';
+ $user = $this->getMockBuilder('\OCP\IUser')
+ ->disableOriginalConstructor()->getMock();
+ $this->userManager
+ ->expects($this->once())
+ ->method('get')
+ ->with('ValidTokenUser')
+ ->will($this->returnValue($user));
+ $this->timeFactory
+ ->expects($this->once())
+ ->method('getTime')
+ ->will($this->returnValue(12345*60*60*12));
+ $userId = 'ValidTokenUser';
+ $token = 'TheOnlyAndOnlyOneTokenToResetThePassword';
+ $this->config
+ ->expects($this->once())
+ ->method('getUserValue')
+ ->with('ValidTokenUser', 'owncloud', 'lostpassword', null)
+ ->will($this->returnValue('12345:TheOnlyAndOnlyOneTokenToResetThePassword'));
+ $response = $this->lostController->resetform($token, $userId);
+ $expectedResponse = new TemplateResponse('core',
+ 'error',
+ [
+ 'errors' => [
+ ['error' => 'Couldn\'t reset password because the token is expired'],
+ ]
+ ],
+ 'guest');
+ $this->assertEquals($expectedResponse, $response);
+ }
+ public function testResetFormValidToken() {
+ $userId = 'ValidTokenUser';
+ $token = '12345:TheOnlyAndOnlyOneTokenToResetThePassword';
+ $user = $this->getMockBuilder('\OCP\IUser')
+ ->disableOriginalConstructor()->getMock();
+ $user
+ ->expects($this->once())
+ ->method('getLastLogin')
+ ->will($this->returnValue(12344));
+ $this->userManager
+ ->expects($this->once())
+ ->method('get')
+ ->with('ValidTokenUser')
+ ->will($this->returnValue($user));
+ $this->timeFactory
+ ->expects($this->once())
+ ->method('getTime')
+ ->will($this->returnValue(12348));
+ $userId = 'ValidTokenUser';
+ $token = 'TheOnlyAndOnlyOneTokenToResetThePassword';
+ $this->config
+ ->expects($this->once())
+ ->method('getUserValue')
+ ->with('ValidTokenUser', 'owncloud', 'lostpassword', null)
+ ->will($this->returnValue('12345:TheOnlyAndOnlyOneTokenToResetThePassword'));
$this->urlGenerator
->expects($this->once())
->method('linkToRouteAbsolute')
- ->with('core.lost.setPassword', array('userId' => 'admin', 'token' => 'MySecretToken'))
+ ->with('core.lost.setPassword', array('userId' => 'ValidTokenUser', 'token' => 'TheOnlyAndOnlyOneTokenToResetThePassword'))
->will($this->returnValue('https://ownCloud.com/index.php/lostpassword/'));
$response = $this->lostController->resetform($token, $userId);
@@ -329,7 +430,7 @@ class LostControllerTest extends \PHPUnit_Framework_TestCase {
->with('NewPassword')
->will($this->returnValue(true));
$this->userManager
- ->expects($this->once())
+ ->expects($this->exactly(2))
->method('get')
->with('ValidTokenUser')
->will($this->returnValue($user));