From 26e3996014936268f4acbfa214fa881af9320ddd Mon Sep 17 00:00:00 2001 From: Frederic Guillot <fred@kanboard.net> Date: Sat, 9 Jan 2016 17:28:31 -0500 Subject: Add forgot password feature --- tests/units/Model/PasswordResetTest.php | 85 +++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 tests/units/Model/PasswordResetTest.php (limited to 'tests/units/Model') diff --git a/tests/units/Model/PasswordResetTest.php b/tests/units/Model/PasswordResetTest.php new file mode 100644 index 00000000..f88d24fb --- /dev/null +++ b/tests/units/Model/PasswordResetTest.php @@ -0,0 +1,85 @@ +<?php + +require_once __DIR__.'/../Base.php'; + +use Kanboard\Model\User; +use Kanboard\Model\PasswordReset; + +class PasswordResetTest extends Base +{ + public function testCreate() + { + $userModel = new User($this->container); + $passwordResetModel = new PasswordReset($this->container); + + $this->assertEquals(2, $userModel->create(array('username' => 'user1'))); + $this->assertEquals(3, $userModel->create(array('username' => 'user2', 'email' => 'user1@localhost'))); + + $this->assertFalse($passwordResetModel->create('user0')); + $this->assertFalse($passwordResetModel->create('user1')); + $this->assertNotFalse($passwordResetModel->create('user2')); + } + + public function testGetUserIdByToken() + { + $userModel = new User($this->container); + $passwordResetModel = new PasswordReset($this->container); + + $this->assertEquals(2, $userModel->create(array('username' => 'user2', 'email' => 'user1@localhost'))); + + $token = $passwordResetModel->create('user2'); + $this->assertEquals(2, $passwordResetModel->getUserIdByToken($token)); + } + + public function testGetUserIdByTokenWhenExpired() + { + $userModel = new User($this->container); + $passwordResetModel = new PasswordReset($this->container); + + $this->assertEquals(2, $userModel->create(array('username' => 'user2', 'email' => 'user1@localhost'))); + + $token = $passwordResetModel->create('user2', strtotime('-1 year')); + $this->assertFalse($passwordResetModel->getUserIdByToken($token)); + } + + public function testDisableTokens() + { + $userModel = new User($this->container); + $passwordResetModel = new PasswordReset($this->container); + + $this->assertEquals(2, $userModel->create(array('username' => 'user2', 'email' => 'user1@localhost'))); + + $token1 = $passwordResetModel->create('user2'); + $token2 = $passwordResetModel->create('user2'); + + $this->assertEquals(2, $passwordResetModel->getUserIdByToken($token1)); + $this->assertEquals(2, $passwordResetModel->getUserIdByToken($token2)); + + $this->assertTrue($passwordResetModel->disable(2)); + + $this->assertFalse($passwordResetModel->getUserIdByToken($token1)); + $this->assertFalse($passwordResetModel->getUserIdByToken($token2)); + } + + public function testGetAll() + { + $userModel = new User($this->container); + $passwordResetModel = new PasswordReset($this->container); + + $this->assertEquals(2, $userModel->create(array('username' => 'user2', 'email' => 'user1@localhost'))); + $this->assertNotFalse($passwordResetModel->create('user2')); + $this->assertNotFalse($passwordResetModel->create('user2')); + + $tokens = $passwordResetModel->getAll(1); + $this->assertCount(0, $tokens); + + $tokens = $passwordResetModel->getAll(2); + $this->assertCount(2, $tokens); + $this->assertNotEmpty($tokens[0]['token']); + $this->assertNotEmpty($tokens[0]['date_creation']); + $this->assertNotEmpty($tokens[0]['date_expiration']); + $this->assertEquals(2, $tokens[0]['user_id']); + $this->assertArrayHasKey('user_agent', $tokens[0]); + $this->assertArrayHasKey('ip', $tokens[0]); + } +} -- cgit v1.2.3