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