mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
38c71c56a3
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@93977 467b73ca-7a2a-4603-9d3b-597d59a354a9
47 lines
1.3 KiB
PHP
47 lines
1.3 KiB
PHP
<?php
|
|
/**
|
|
* @package sapphire
|
|
* @subpackage tests
|
|
*/
|
|
class MemberAuthenticatorTest extends SapphireTest {
|
|
|
|
protected $usesDatabase = true;
|
|
|
|
function testLegacyPasswordHashMigrationUponLogin() {
|
|
$member = new Member();
|
|
$member->Email = 'test@test.com';
|
|
$member->PasswordEncryption = "sha1";
|
|
$member->Password = "mypassword";
|
|
$member->write();
|
|
|
|
$data = array(
|
|
'Email' => $member->Email,
|
|
'Password' => 'mypassword'
|
|
);
|
|
MemberAuthenticator::authenticate($data);
|
|
|
|
$member = DataObject::get_by_id('Member', $member->ID);
|
|
$this->assertEquals($member->PasswordEncryption, "sha1_v2.4");
|
|
$this->assertTrue($member->checkPassword('mypassword'));
|
|
}
|
|
|
|
function testNoLegacyPasswordHashMigrationOnIncompatibleAlgorithm() {
|
|
PasswordEncryptor::register('crc32', 'PasswordEncryptor_PHPHash("crc32")');
|
|
|
|
$member = new Member();
|
|
$member->Email = 'test@test.com';
|
|
$member->PasswordEncryption = "crc32";
|
|
$member->Password = "mypassword";
|
|
$member->write();
|
|
|
|
$data = array(
|
|
'Email' => $member->Email,
|
|
'Password' => 'mypassword'
|
|
);
|
|
MemberAuthenticator::authenticate($data);
|
|
|
|
$member = DataObject::get_by_id('Member', $member->ID);
|
|
$this->assertEquals($member->PasswordEncryption, "crc32");
|
|
$this->assertTrue($member->checkPassword('mypassword'));
|
|
}
|
|
} |