diff options
Diffstat (limited to 'tests/core/controller')
-rw-r--r-- | tests/core/controller/avatarcontrollertest.php | 437 | ||||
-rw-r--r-- | tests/core/controller/lostcontrollertest.php | 442 |
2 files changed, 0 insertions, 879 deletions
diff --git a/tests/core/controller/avatarcontrollertest.php b/tests/core/controller/avatarcontrollertest.php deleted file mode 100644 index 8e5e58904a7..00000000000 --- a/tests/core/controller/avatarcontrollertest.php +++ /dev/null @@ -1,437 +0,0 @@ -<?php -/** - * @author Roeland Jago Douma <roeland@famdouma.nl> - * - * @copyright Copyright (c) 2015, ownCloud, Inc. - * @license AGPL-3.0 - * - * This code is free software: you can redistribute it and/or modify - * it under the terms of the GNU Affero General Public License, version 3, - * as published by the Free Software Foundation. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Affero General Public License for more details. - * - * You should have received a copy of the GNU Affero General Public License, version 3, - * along with this program. If not, see <http://www.gnu.org/licenses/> - * - */ -namespace OC\Core\Controller; - -use OC; -use OC\Core\Application; -use OCP\AppFramework\IAppContainer; -use OCP\AppFramework\Http; -use OCP\Files\Folder; -use OCP\Files\File; -use OCP\Files\NotFoundException; -use OCP\IUser; -use OCP\IAvatar; -use Punic\Exception; -use Test\Traits\UserTrait; - -/** - * Overwrite is_uploaded_file in this namespace to allow proper unit testing of - * the postAvatar call. - */ -function is_uploaded_file($filename) { - return file_exists($filename); -} - -/** - * Class AvatarControllerTest - * - * @group DB - * - * @package OC\Core\Controller - */ -class AvatarControllerTest extends \Test\TestCase { - use UserTrait; - - /** @var IAppContainer */ - private $container; - /** @var AvatarController */ - private $avatarController; - /** @var IAvatar */ - private $avatarMock; - /** @var IUser */ - private $userMock; - /** @var File */ - private $avatarFile; - - protected function setUp() { - parent::setUp(); - $this->createUser('userid', 'pass'); - $this->loginAsUser('userid'); - - $app = new Application; - $this->container = $app->getContainer(); - $this->container['AppName'] = 'core'; - $this->container['AvatarManager'] = $this->getMock('OCP\IAvatarManager'); - $this->container['Cache'] = $this->getMockBuilder('OC\Cache\File') - ->disableOriginalConstructor()->getMock(); - $this->container['L10N'] = $this->getMock('OCP\IL10N'); - $this->container['L10N']->method('t')->will($this->returnArgument(0)); - $this->container['UserManager'] = $this->getMock('OCP\IUserManager'); - $this->container['UserSession'] = $this->getMock('OCP\IUserSession'); - $this->container['Request'] = $this->getMock('OCP\IRequest'); - $this->container['UserFolder'] = $this->getMock('OCP\Files\Folder'); - $this->container['Logger'] = $this->getMock('OCP\ILogger'); - - $this->avatarMock = $this->getMock('OCP\IAvatar'); - $this->userMock = $this->getMock('OCP\IUser'); - - $this->avatarController = $this->container['AvatarController']; - - // Configure userMock - $this->userMock->method('getDisplayName')->willReturn('displayName'); - $this->userMock->method('getUID')->willReturn('userId'); - $this->container['UserManager']->method('get') - ->willReturnMap([['userId', $this->userMock]]); - $this->container['UserSession']->method('getUser')->willReturn($this->userMock); - - $this->avatarFile = $this->getMock('OCP\Files\File'); - $this->avatarFile->method('getContnet')->willReturn('image data'); - $this->avatarFile->method('getMimeType')->willReturn('image type'); - $this->avatarFile->method('getEtag')->willReturn('my etag'); - } - - public function tearDown() { - $this->logout(); - parent::tearDown(); - } - - /** - * Fetch an avatar if a user has no avatar - */ - public function testGetAvatarNoAvatar() { - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - $this->avatarMock->method('getFile')->will($this->throwException(new NotFoundException())); - $response = $this->avatarController->getAvatar('userId', 32); - - //Comment out until JS is fixed - //$this->assertEquals(Http::STATUS_NOT_FOUND, $response->getStatus()); - $this->assertEquals(Http::STATUS_OK, $response->getStatus()); - $this->assertEquals('displayName', $response->getData()['data']['displayname']); - } - - /** - * Fetch the user's avatar - */ - public function testGetAvatar() { - $this->avatarMock->method('getFile')->willReturn($this->avatarFile); - $this->container['AvatarManager']->method('getAvatar')->with('userId')->willReturn($this->avatarMock); - - $response = $this->avatarController->getAvatar('userId', 32); - - $this->assertEquals(Http::STATUS_OK, $response->getStatus()); - $this->assertArrayHasKey('Content-Type', $response->getHeaders()); - $this->assertEquals('image type', $response->getHeaders()['Content-Type']); - - $this->assertEquals('my etag', $response->getEtag()); - } - - /** - * Fetch the avatar of a non-existing user - */ - public function testGetAvatarNoUser() { - $this->container['AvatarManager'] - ->method('getAvatar') - ->with('userDoesNotExist') - ->will($this->throwException(new \Exception('user does not exist'))); - - $response = $this->avatarController->getAvatar('userDoesNotExist', 32); - - //Comment out until JS is fixed - //$this->assertEquals(Http::STATUS_NOT_FOUND, $response->getStatus()); - $this->assertEquals(Http::STATUS_OK, $response->getStatus()); - $this->assertEquals('', $response->getData()['data']['displayname']); - } - - /** - * Make sure we get the correct size - */ - public function testGetAvatarSize() { - $this->avatarMock->expects($this->once()) - ->method('getFile') - ->with($this->equalTo(32)) - ->willReturn($this->avatarFile); - - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - - $this->avatarController->getAvatar('userId', 32); - } - - /** - * We cannot get avatars that are 0 or negative - */ - public function testGetAvatarSizeMin() { - $this->avatarMock->expects($this->once()) - ->method('getFile') - ->with($this->equalTo(64)) - ->willReturn($this->avatarFile); - - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - - $this->avatarController->getAvatar('userId', 0); - } - - /** - * We do not support avatars larger than 2048*2048 - */ - public function testGetAvatarSizeMax() { - $this->avatarMock->expects($this->once()) - ->method('getFile') - ->with($this->equalTo(2048)) - ->willReturn($this->avatarFile); - - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - - $this->avatarController->getAvatar('userId', 2049); - } - - /** - * Remove an avatar - */ - public function testDeleteAvatar() { - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - - $response = $this->avatarController->deleteAvatar(); - $this->assertEquals(Http::STATUS_OK, $response->getStatus()); - } - - /** - * Test what happens if the removing of the avatar fails - */ - public function testDeleteAvatarException() { - $this->avatarMock->method('remove')->will($this->throwException(new \Exception("foo"))); - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - - $this->container['Logger']->expects($this->once()) - ->method('logException') - ->with(new \Exception("foo")); - $expectedResponse = new Http\DataResponse(['data' => ['message' => 'An error occurred. Please contact your admin.']], Http::STATUS_BAD_REQUEST); - $this->assertEquals($expectedResponse, $this->avatarController->deleteAvatar()); - } - - /** - * Trying to get a tmp avatar when it is not available. 404 - */ - public function testTmpAvatarNoTmp() { - $response = $this->avatarController->getTmpAvatar(); - $this->assertEquals(Http::STATUS_NOT_FOUND, $response->getStatus()); - } - - /** - * Fetch tmp avatar - */ - public function testTmpAvatarValid() { - $this->container['Cache']->method('get')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - - $response = $this->avatarController->getTmpAvatar(); - $this->assertEquals(Http::STATUS_OK, $response->getStatus()); - } - - - /** - * When trying to post a new avatar a path or image should be posted. - */ - public function testPostAvatarNoPathOrImage() { - $response = $this->avatarController->postAvatar(null); - - $this->assertEquals(Http::STATUS_BAD_REQUEST, $response->getStatus()); - } - - /** - * Test a correct post of an avatar using POST - */ - public function testPostAvatarFile() { - //Create temp file - $fileName = tempnam(null, "avatarTest"); - $copyRes = copy(OC::$SERVERROOT.'/tests/data/testimage.jpg', $fileName); - $this->assertTrue($copyRes); - - //Create file in cache - $this->container['Cache']->method('get')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - - //Create request return - $reqRet = ['error' => [0], 'tmp_name' => [$fileName], 'size' => [filesize(OC::$SERVERROOT.'/tests/data/testimage.jpg')]]; - $this->container['Request']->method('getUploadedFile')->willReturn($reqRet); - - $response = $this->avatarController->postAvatar(null); - - //On correct upload always respond with the notsquare message - $this->assertEquals('notsquare', $response->getData()['data']); - - //File should be deleted - $this->assertFalse(file_exists($fileName)); - } - - /** - * Test invalid post os an avatar using POST - */ - public function testPostAvatarInvalidFile() { - //Create request return - $reqRet = ['error' => [1], 'tmp_name' => ['foo']]; - $this->container['Request']->method('getUploadedFile')->willReturn($reqRet); - - $response = $this->avatarController->postAvatar(null); - - $this->assertEquals(Http::STATUS_BAD_REQUEST, $response->getStatus()); - } - - /** - * Check what happens when we upload a GIF - */ - public function testPostAvatarFileGif() { - //Create temp file - $fileName = tempnam(null, "avatarTest"); - $copyRes = copy(OC::$SERVERROOT.'/tests/data/testimage.gif', $fileName); - $this->assertTrue($copyRes); - - //Create file in cache - $this->container['Cache']->method('get')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.gif')); - - //Create request return - $reqRet = ['error' => [0], 'tmp_name' => [$fileName], 'size' => filesize(OC::$SERVERROOT.'/tests/data/testimage.gif')]; - $this->container['Request']->method('getUploadedFile')->willReturn($reqRet); - - $response = $this->avatarController->postAvatar(null); - - $this->assertEquals('Unknown filetype', $response->getData()['data']['message']); - - //File should be deleted - $this->assertFalse(file_exists($fileName)); - } - - /** - * Test posting avatar from existing file - */ - public function testPostAvatarFromFile() { - //Mock node API call - $file = $this->getMockBuilder('OCP\Files\File') - ->disableOriginalConstructor()->getMock(); - $file->method('getContent')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - $this->container['UserFolder']->method('get')->willReturn($file); - - //Create request return - $response = $this->avatarController->postAvatar('avatar.jpg'); - - //On correct upload always respond with the notsquare message - $this->assertEquals('notsquare', $response->getData()['data']); - } - - /** - * Test posting avatar from existing folder - */ - public function testPostAvatarFromNoFile() { - $file = $this->getMock('OCP\Files\Node'); - $this->container['UserFolder'] - ->method('get') - ->with('folder') - ->willReturn($file); - - //Create request return - $response = $this->avatarController->postAvatar('folder'); - - //On correct upload always respond with the notsquare message - $this->assertEquals(['data' => ['message' => 'Please select a file.']], $response->getData()); - } - - /** - * Test what happens if the upload of the avatar fails - */ - public function testPostAvatarException() { - $this->container['Cache']->expects($this->once()) - ->method('set') - ->will($this->throwException(new \Exception("foo"))); - $file = $this->getMockBuilder('OCP\Files\File') - ->disableOriginalConstructor()->getMock(); - $file->method('getContent')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - $this->container['UserFolder']->method('get')->willReturn($file); - - $this->container['Logger']->expects($this->once()) - ->method('logException') - ->with(new \Exception("foo")); - $expectedResponse = new Http\DataResponse(['data' => ['message' => 'An error occurred. Please contact your admin.']], Http::STATUS_OK); - $this->assertEquals($expectedResponse, $this->avatarController->postAvatar('avatar.jpg')); - } - - - /** - * Test invalid crop argument - */ - public function testPostCroppedAvatarInvalidCrop() { - $response = $this->avatarController->postCroppedAvatar([]); - - $this->assertEquals(Http::STATUS_BAD_REQUEST, $response->getStatus()); - } - - /** - * Test no tmp avatar to crop - */ - public function testPostCroppedAvatarNoTmpAvatar() { - $response = $this->avatarController->postCroppedAvatar(['x' => 0, 'y' => 0, 'w' => 10, 'h' => 10]); - - $this->assertEquals(Http::STATUS_BAD_REQUEST, $response->getStatus()); - } - - /** - * Test with non square crop - */ - public function testPostCroppedAvatarNoSquareCrop() { - $this->container['Cache']->method('get')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - - $this->avatarMock->method('set')->will($this->throwException(new \OC\NotSquareException)); - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - $response = $this->avatarController->postCroppedAvatar(['x' => 0, 'y' => 0, 'w' => 10, 'h' => 11]); - - $this->assertEquals(Http::STATUS_BAD_REQUEST, $response->getStatus()); - } - - /** - * Check for proper reply on proper crop argument - */ - public function testPostCroppedAvatarValidCrop() { - $this->container['Cache']->method('get')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - $response = $this->avatarController->postCroppedAvatar(['x' => 0, 'y' => 0, 'w' => 10, 'h' => 10]); - - $this->assertEquals(Http::STATUS_OK, $response->getStatus()); - $this->assertEquals('success', $response->getData()['status']); - } - - /** - * Test what happens if the cropping of the avatar fails - */ - public function testPostCroppedAvatarException() { - $this->container['Cache']->method('get')->willReturn(file_get_contents(OC::$SERVERROOT.'/tests/data/testimage.jpg')); - - $this->avatarMock->method('set')->will($this->throwException(new \Exception('foo'))); - $this->container['AvatarManager']->method('getAvatar')->willReturn($this->avatarMock); - - $this->container['Logger']->expects($this->once()) - ->method('logException') - ->with(new \Exception('foo')); - $expectedResponse = new Http\DataResponse(['data' => ['message' => 'An error occurred. Please contact your admin.']], Http::STATUS_BAD_REQUEST); - $this->assertEquals($expectedResponse, $this->avatarController->postCroppedAvatar(['x' => 0, 'y' => 0, 'w' => 10, 'h' => 11])); - } - - - /** - * Check for proper reply on proper crop argument - */ - public function testFileTooBig() { - $fileName = OC::$SERVERROOT.'/tests/data/testimage.jpg'; - //Create request return - $reqRet = ['error' => [0], 'tmp_name' => [$fileName], 'size' => [21*1024*1024]]; - $this->container['Request']->method('getUploadedFile')->willReturn($reqRet); - - $response = $this->avatarController->postAvatar(null); - - $this->assertEquals('File is too big', $response->getData()['data']['message']); - } - -} diff --git a/tests/core/controller/lostcontrollertest.php b/tests/core/controller/lostcontrollertest.php deleted file mode 100644 index 44bc539247f..00000000000 --- a/tests/core/controller/lostcontrollertest.php +++ /dev/null @@ -1,442 +0,0 @@ -<?php -/** - * @author Lukas Reschke <lukas@owncloud.com> - * - * @copyright Copyright (c) 2015, ownCloud, Inc. - * @license AGPL-3.0 - * - * This code is free software: you can redistribute it and/or modify - * it under the terms of the GNU Affero General Public License, version 3, - * as published by the Free Software Foundation. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Affero General Public License for more details. - * - * You should have received a copy of the GNU Affero General Public License, version 3, - * along with this program. If not, see <http://www.gnu.org/licenses/> - * - */ - -namespace OC\Core\Controller; - -use OCP\AppFramework\Http\TemplateResponse; -use OCP\AppFramework\Utility\ITimeFactory; -use OCP\IConfig; -use OCP\IL10N; -use OCP\IRequest; -use OCP\IURLGenerator; -use OCP\IUser; -use OCP\IUserManager; -use OCP\Mail\IMailer; -use OCP\Security\ISecureRandom; -use PHPUnit_Framework_MockObject_MockObject; - -/** - * Class LostControllerTest - * - * @package OC\Core\Controller - */ -class LostControllerTest extends \PHPUnit_Framework_TestCase { - - /** @var LostController */ - private $lostController; - /** @var IUser */ - private $existingUser; - /** @var IURLGenerator | PHPUnit_Framework_MockObject_MockObject */ - private $urlGenerator; - /** @var IL10N */ - private $l10n; - /** @var IUserManager | PHPUnit_Framework_MockObject_MockObject */ - private $userManager; - /** @var \OC_Defaults */ - private $defaults; - /** @var IConfig | PHPUnit_Framework_MockObject_MockObject */ - private $config; - /** @var IMailer | PHPUnit_Framework_MockObject_MockObject */ - private $mailer; - /** @var ISecureRandom | PHPUnit_Framework_MockObject_MockObject */ - private $secureRandom; - /** @var ITimeFactory | PHPUnit_Framework_MockObject_MockObject */ - private $timeFactory; - /** @var IRequest */ - private $request; - - protected function setUp() { - - $this->existingUser = $this->getMockBuilder('OCP\IUser') - ->disableOriginalConstructor()->getMock(); - - $this->existingUser - ->expects($this->any()) - ->method('getEMailAddress') - ->willReturn('test@example.com'); - - $this->config = $this->getMockBuilder('\OCP\IConfig') - ->disableOriginalConstructor()->getMock(); - $this->l10n = $this->getMockBuilder('\OCP\IL10N') - ->disableOriginalConstructor()->getMock(); - $this->l10n - ->expects($this->any()) - ->method('t') - ->will($this->returnCallback(function($text, $parameters = array()) { - return vsprintf($text, $parameters); - })); - $this->defaults = $this->getMockBuilder('\OC_Defaults') - ->disableOriginalConstructor()->getMock(); - $this->userManager = $this->getMockBuilder('\OCP\IUserManager') - ->disableOriginalConstructor()->getMock(); - $this->urlGenerator = $this->getMockBuilder('\OCP\IURLGenerator') - ->disableOriginalConstructor()->getMock(); - $this->mailer = $this->getMockBuilder('\OCP\Mail\IMailer') - ->disableOriginalConstructor()->getMock(); - $this->secureRandom = $this->getMockBuilder('\OCP\Security\ISecureRandom') - ->disableOriginalConstructor()->getMock(); - $this->timeFactory = $this->getMockBuilder('\OCP\AppFramework\Utility\ITimeFactory') - ->disableOriginalConstructor()->getMock(); - $this->request = $this->getMockBuilder('OCP\IRequest') - ->disableOriginalConstructor()->getMock(); - $this->lostController = new LostController( - 'Core', - $this->request, - $this->urlGenerator, - $this->userManager, - $this->defaults, - $this->l10n, - $this->config, - $this->secureRandom, - 'lostpassword-noreply@localhost', - true, - $this->mailer, - $this->timeFactory - ); - } - - public function testResetFormUnsuccessful() { - $userId = 'admin'; - $token = 'MySecretToken'; - - $this->urlGenerator - ->expects($this->once()) - ->method('linkToRouteAbsolute') - ->with('core.lost.setPassword', array('userId' => 'admin', 'token' => 'MySecretToken')) - ->will($this->returnValue('https://ownCloud.com/index.php/lostpassword/')); - - $response = $this->lostController->resetform($token, $userId); - $expectedResponse = new TemplateResponse('core', - 'lostpassword/resetpassword', - array( - 'link' => 'https://ownCloud.com/index.php/lostpassword/', - ), - 'guest'); - $this->assertEquals($expectedResponse, $response); - } - - public function testEmailUnsucessful() { - $existingUser = 'ExistingUser'; - $nonExistingUser = 'NonExistingUser'; - $this->userManager - ->expects($this->any()) - ->method('userExists') - ->will($this->returnValueMap(array( - array(true, $existingUser), - array(false, $nonExistingUser) - ))); - - // With a non existing user - $response = $this->lostController->email($nonExistingUser); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t send reset email. Please make sure your username is correct.' - ]; - $this->assertSame($expectedResponse, $response); - - // With no mail address - $this->config - ->expects($this->any()) - ->method('getUserValue') - ->with($existingUser, 'settings', 'email') - ->will($this->returnValue(null)); - $response = $this->lostController->email($existingUser); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t send reset email. Please make sure your username is correct.' - ]; - $this->assertSame($expectedResponse, $response); - } - - public function testEmailSuccessful() { - $this->secureRandom - ->expects($this->once()) - ->method('generate') - ->with('21') - ->will($this->returnValue('ThisIsMaybeANotSoSecretToken!')); - $this->userManager - ->expects($this->once()) - ->method('userExists') - ->with('ExistingUser') - ->will($this->returnValue(true)); - $this->userManager - ->expects($this->any()) - ->method('get') - ->with('ExistingUser') - ->willReturn($this->existingUser); - $this->timeFactory - ->expects($this->once()) - ->method('getTime') - ->will($this->returnValue(12348)); - $this->config - ->expects($this->once()) - ->method('setUserValue') - ->with('ExistingUser', 'owncloud', 'lostpassword', '12348:ThisIsMaybeANotSoSecretToken!'); - $this->urlGenerator - ->expects($this->once()) - ->method('linkToRouteAbsolute') - ->with('core.lost.resetform', array('userId' => 'ExistingUser', 'token' => 'ThisIsMaybeANotSoSecretToken!')) - ->will($this->returnValue('https://ownCloud.com/index.php/lostpassword/')); - $message = $this->getMockBuilder('\OC\Mail\Message') - ->disableOriginalConstructor()->getMock(); - $message - ->expects($this->at(0)) - ->method('setTo') - ->with(['test@example.com' => 'ExistingUser']); - $message - ->expects($this->at(1)) - ->method('setSubject') - ->with(' password reset'); - $message - ->expects($this->at(2)) - ->method('setPlainBody') - ->with('Use the following link to reset your password: https://ownCloud.com/index.php/lostpassword/'); - $message - ->expects($this->at(3)) - ->method('setFrom') - ->with(['lostpassword-noreply@localhost' => null]); - $this->mailer - ->expects($this->at(0)) - ->method('createMessage') - ->will($this->returnValue($message)); - $this->mailer - ->expects($this->at(1)) - ->method('send') - ->with($message); - - $response = $this->lostController->email('ExistingUser'); - $expectedResponse = array('status' => 'success'); - $this->assertSame($expectedResponse, $response); - } - - public function testEmailCantSendException() { - $this->secureRandom - ->expects($this->once()) - ->method('generate') - ->with('21') - ->will($this->returnValue('ThisIsMaybeANotSoSecretToken!')); - $this->userManager - ->expects($this->once()) - ->method('userExists') - ->with('ExistingUser') - ->will($this->returnValue(true)); - $this->userManager - ->expects($this->any()) - ->method('get') - ->with('ExistingUser') - ->willReturn($this->existingUser); - $this->config - ->expects($this->once()) - ->method('setUserValue') - ->with('ExistingUser', 'owncloud', 'lostpassword', '12348:ThisIsMaybeANotSoSecretToken!'); - $this->timeFactory - ->expects($this->once()) - ->method('getTime') - ->will($this->returnValue(12348)); - $this->urlGenerator - ->expects($this->once()) - ->method('linkToRouteAbsolute') - ->with('core.lost.resetform', array('userId' => 'ExistingUser', 'token' => 'ThisIsMaybeANotSoSecretToken!')) - ->will($this->returnValue('https://ownCloud.com/index.php/lostpassword/')); - $message = $this->getMockBuilder('\OC\Mail\Message') - ->disableOriginalConstructor()->getMock(); - $message - ->expects($this->at(0)) - ->method('setTo') - ->with(['test@example.com' => 'ExistingUser']); - $message - ->expects($this->at(1)) - ->method('setSubject') - ->with(' password reset'); - $message - ->expects($this->at(2)) - ->method('setPlainBody') - ->with('Use the following link to reset your password: https://ownCloud.com/index.php/lostpassword/'); - $message - ->expects($this->at(3)) - ->method('setFrom') - ->with(['lostpassword-noreply@localhost' => null]); - $this->mailer - ->expects($this->at(0)) - ->method('createMessage') - ->will($this->returnValue($message)); - $this->mailer - ->expects($this->at(1)) - ->method('send') - ->with($message) - ->will($this->throwException(new \Exception())); - - $response = $this->lostController->email('ExistingUser'); - $expectedResponse = ['status' => 'error', 'msg' => 'Couldn\'t send reset email. Please contact your administrator.']; - $this->assertSame($expectedResponse, $response); - } - - public function testSetPasswordUnsuccessful() { - $this->config - ->expects($this->once()) - ->method('getUserValue') - ->with('InvalidTokenUser', 'owncloud', 'lostpassword', null) - ->will($this->returnValue('TheOnlyAndOnlyOneTokenToResetThePassword')); - - // With an invalid token - $userName = 'InvalidTokenUser'; - $response = $this->lostController->setPassword('wrongToken', $userName, 'NewPassword', true); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t reset password because the token is invalid' - ]; - $this->assertSame($expectedResponse, $response); - - // With a valid token and no proceed - $response = $this->lostController->setPassword('TheOnlyAndOnlyOneTokenToResetThePassword!', $userName, 'NewPassword', false); - $expectedResponse = ['status' => 'error', 'msg' => '', 'encryption' => true]; - $this->assertSame($expectedResponse, $response); - } - - public function testSetPasswordSuccessful() { - $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)); - $user->expects($this->once()) - ->method('setPassword') - ->with('NewPassword') - ->will($this->returnValue(true)); - $this->userManager - ->expects($this->once()) - ->method('get') - ->with('ValidTokenUser') - ->will($this->returnValue($user)); - $this->config - ->expects($this->once()) - ->method('deleteUserValue') - ->with('ValidTokenUser', 'owncloud', 'lostpassword'); - $this->timeFactory - ->expects($this->once()) - ->method('getTime') - ->will($this->returnValue(12348)); - - $response = $this->lostController->setPassword('TheOnlyAndOnlyOneTokenToResetThePassword', 'ValidTokenUser', 'NewPassword', true); - $expectedResponse = array('status' => 'success'); - $this->assertSame($expectedResponse, $response); - } - - public function testSetPasswordExpiredToken() { - $this->config - ->expects($this->once()) - ->method('getUserValue') - ->with('ValidTokenUser', 'owncloud', 'lostpassword', null) - ->will($this->returnValue('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(55546)); - - $response = $this->lostController->setPassword('TheOnlyAndOnlyOneTokenToResetThePassword', 'ValidTokenUser', 'NewPassword', true); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t reset password because the token is expired', - ]; - $this->assertSame($expectedResponse, $response); - } - - public function testSetPasswordInvalidDataInDb() { - $this->config - ->expects($this->once()) - ->method('getUserValue') - ->with('ValidTokenUser', 'owncloud', 'lostpassword', null) - ->will($this->returnValue('TheOnlyAndOnlyOneTokenToResetThePassword')); - $user = $this->getMockBuilder('\OCP\IUser') - ->disableOriginalConstructor()->getMock(); - $this->userManager - ->expects($this->once()) - ->method('get') - ->with('ValidTokenUser') - ->will($this->returnValue($user)); - - $response = $this->lostController->setPassword('TheOnlyAndOnlyOneTokenToResetThePassword', 'ValidTokenUser', 'NewPassword', true); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t reset password because the token is invalid', - ]; - $this->assertSame($expectedResponse, $response); - } - - public function testSetPasswordExpiredTokenDueToLogin() { - $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(12346)); - $this->userManager - ->expects($this->once()) - ->method('get') - ->with('ValidTokenUser') - ->will($this->returnValue($user)); - $this->timeFactory - ->expects($this->once()) - ->method('getTime') - ->will($this->returnValue(12345)); - - $response = $this->lostController->setPassword('TheOnlyAndOnlyOneTokenToResetThePassword', 'ValidTokenUser', 'NewPassword', true); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t reset password because the token is expired', - ]; - $this->assertSame($expectedResponse, $response); - } - - public function testIsSetPasswordWithoutTokenFailing() { - $this->config - ->expects($this->once()) - ->method('getUserValue') - ->with('ValidTokenUser', 'owncloud', 'lostpassword', null) - ->will($this->returnValue(null)); - - $response = $this->lostController->setPassword('', 'ValidTokenUser', 'NewPassword', true); - $expectedResponse = [ - 'status' => 'error', - 'msg' => 'Couldn\'t reset password because the token is invalid' - ]; - $this->assertSame($expectedResponse, $response); - } - -} |