framework/tests/integration/extenders/AuthTest.php

95 lines
1.9 KiB
PHP
Raw Normal View History

<?php
/*
* This file is part of Flarum.
*
* For detailed copyright and license information, please view the
* LICENSE file that was distributed with this source code.
*/
namespace Flarum\Tests\integration\extenders;
use Flarum\Extend;
use Flarum\Testing\integration\RetrievesAuthorizedUsers;
use Flarum\Testing\integration\TestCase;
use Flarum\User\User;
class AuthTest extends TestCase
{
use RetrievesAuthorizedUsers;
/**
* @test
*/
public function standard_password_works_by_default()
{
$this->app();
$user = User::find(1);
$this->assertTrue($user->checkPassword('password'));
}
/**
* @test
*/
public function standard_password_can_be_disabled()
{
$this->extend(
(new Extend\Auth)
->removePasswordChecker('standard')
);
$this->app();
$user = User::find(1);
$this->assertFalse($user->checkPassword('password'));
}
/**
* @test
*/
public function custom_checker_can_be_added()
{
$this->extend(
(new Extend\Auth)
->removePasswordChecker('standard')
->addPasswordChecker('custom_true', CustomTrueChecker::class)
);
$this->app();
$user = User::find(1);
$this->assertTrue($user->checkPassword('DefinitelyNotThePassword'));
}
/**
* @test
*/
public function false_checker_overrides_true()
{
$this->extend(
(new Extend\Auth)
->addPasswordChecker('custom_false', function (User $user, $password) {
return false;
})
);
$this->app();
$user = User::find(1);
$this->assertFalse($user->checkPassword('password'));
}
}
class CustomTrueChecker
{
public function __invoke(User $user, $password)
{
return true;
}
}