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]); } }