2010-10-15 03:03:19 +00:00
|
|
|
<?php
|
2016-06-23 11:37:22 +12:00
|
|
|
|
2024-09-24 17:44:12 +12:00
|
|
|
namespace SilverStripe\Security\Tests\Validation;
|
2016-10-14 14:30:05 +13:00
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2018-11-13 14:08:28 +02:00
|
|
|
use SilverStripe\Security\Member;
|
2024-09-24 17:44:12 +12:00
|
|
|
use SilverStripe\Security\Validation\RulesPasswordValidator;
|
2016-08-19 10:51:35 +12:00
|
|
|
|
2024-09-24 17:44:12 +12:00
|
|
|
class RulesPasswordValidatorTest extends SapphireTest
|
2016-12-16 17:34:21 +13:00
|
|
|
{
|
2024-09-24 17:44:12 +12:00
|
|
|
protected $usesDatabase = false;
|
2016-12-16 17:34:21 +13:00
|
|
|
|
2021-10-27 15:39:47 +13:00
|
|
|
protected function setUp(): void
|
2018-11-13 14:08:28 +02:00
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
2024-09-24 17:44:12 +12:00
|
|
|
RulesPasswordValidator::config()
|
2018-11-13 14:08:28 +02:00
|
|
|
->remove('min_length')
|
2018-12-02 23:04:34 +00:00
|
|
|
->remove('historic_count')
|
|
|
|
->set('min_test_score', 0);
|
2018-11-13 14:08:28 +02:00
|
|
|
}
|
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testValidate()
|
|
|
|
{
|
2024-09-24 17:44:12 +12:00
|
|
|
$v = new RulesPasswordValidator();
|
2016-12-16 17:34:21 +13:00
|
|
|
$r = $v->validate('', new Member());
|
|
|
|
$this->assertTrue($r->isValid(), 'Empty password is valid by default');
|
|
|
|
|
|
|
|
$r = $v->validate('mypassword', new Member());
|
|
|
|
$this->assertTrue($r->isValid(), 'Non-Empty password is valid by default');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateMinLength()
|
|
|
|
{
|
2024-09-24 17:44:12 +12:00
|
|
|
$v = new RulesPasswordValidator();
|
2016-12-16 17:34:21 +13:00
|
|
|
|
2018-04-18 10:35:31 +12:00
|
|
|
$v->setMinLength(4);
|
2016-12-16 17:34:21 +13:00
|
|
|
$r = $v->validate('123', new Member());
|
|
|
|
$this->assertFalse($r->isValid(), 'Password too short');
|
|
|
|
|
2018-04-18 10:35:31 +12:00
|
|
|
$v->setMinLength(4);
|
2016-12-16 17:34:21 +13:00
|
|
|
$r = $v->validate('1234', new Member());
|
|
|
|
$this->assertTrue($r->isValid(), 'Password long enough');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateMinScore()
|
|
|
|
{
|
2018-04-18 10:35:31 +12:00
|
|
|
// Set both score and set of tests
|
2024-09-24 17:44:12 +12:00
|
|
|
$v = new RulesPasswordValidator();
|
2018-04-18 10:35:31 +12:00
|
|
|
$v->setMinTestScore(3);
|
|
|
|
$v->setTestNames(["lowercase", "uppercase", "digits", "punctuation"]);
|
2016-12-16 17:34:21 +13:00
|
|
|
|
|
|
|
$r = $v->validate('aA', new Member());
|
|
|
|
$this->assertFalse($r->isValid(), 'Passing too few tests');
|
|
|
|
|
|
|
|
$r = $v->validate('aA1', new Member());
|
|
|
|
$this->assertTrue($r->isValid(), 'Passing enough tests');
|
2018-04-18 10:35:31 +12:00
|
|
|
|
|
|
|
// Ensure min score without tests works (uses default tests)
|
2024-09-24 17:44:12 +12:00
|
|
|
$v = new RulesPasswordValidator();
|
2018-04-18 10:35:31 +12:00
|
|
|
$v->setMinTestScore(3);
|
|
|
|
|
|
|
|
$r = $v->validate('aA', new Member());
|
|
|
|
$this->assertFalse($r->isValid(), 'Passing too few tests');
|
|
|
|
|
|
|
|
$r = $v->validate('aA1', new Member());
|
|
|
|
$this->assertTrue($r->isValid(), 'Passing enough tests');
|
|
|
|
|
|
|
|
// Ensure that min score is only triggered if there are any failing tests at all
|
|
|
|
$v->setMinTestScore(1000);
|
|
|
|
$r = $v->validate('aA1!', new Member());
|
|
|
|
$this->assertTrue($r->isValid(), 'Passing enough tests');
|
2016-12-16 17:34:21 +13:00
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|