1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
<?php
use MediaWiki\Password\PasswordError;
use MediaWiki\Password\PasswordFactory;
abstract class Pbkdf2PasswordTestCase extends PasswordTestCase {
abstract protected static function getPbkdf2PasswordClass();
protected function getTypeConfigs() {
return [ 'pbkdf2' => [
'class' => static::getPbkdf2PasswordClass(),
'algo' => 'sha256',
'cost' => '1000',
'length' => '128',
] ];
}
public static function providePasswordTests() {
return [
[ true, ":pbkdf2:sha512:1:20:c2FsdA==:hn9wzxreAs/zdSWZo6U9xK80x6Y=", 'password' ],
[ true, ":pbkdf2:sha512:2:20:c2FsdA==:4dnBaqaBcIpF9cfE4hXOtm4BGi4=", 'password' ],
[ true, ":pbkdf2:sha512:4096:20:c2FsdA==:0Zexsz2wFD4BixLz0dFHnmzevcw=", 'password' ],
[ true, ":pbkdf2:sha512:4096:16:c2EAbHQ=:nZ6cTNIf5L4k1bgkTHWWZQ==", "pass\x00word" ],
];
}
public function testCryptThrowsOnInvalidAlgo() {
$factory = new PasswordFactory();
$class = static::getPbkdf2PasswordClass();
$password = new $class(
$factory,
[
'type' => 'pbkdf2',
'algo' => 'fail',
'cost' => '10000',
'length' => '128',
]
);
$this->expectException( PasswordError::class );
$this->expectExceptionMessage( 'Unknown or unsupported algo: fail' );
$password->crypt( 'whatever' );
}
public function testCryptThrowsOnInvalidCost() {
$factory = new PasswordFactory();
$class = static::getPbkdf2PasswordClass();
$password = new $class(
$factory,
[
'type' => 'pbkdf2',
'algo' => 'sha256',
'cost' => '0',
'length' => '128',
]
);
$this->expectException( PasswordError::class );
$this->expectExceptionMessage( 'Invalid number of rounds.' );
$password->crypt( 'whatever' );
}
public function testCryptThrowsOnInvalidLength() {
$factory = new PasswordFactory();
$class = static::getPbkdf2PasswordClass();
$password = new $class(
$factory,
[
'type' => 'pbkdf2',
'algo' => 'sha256',
'cost' => '10000',
'length' => '0',
]
);
$this->expectException( PasswordError::class );
$this->expectExceptionMessage( 'Invalid length.' );
$password->crypt( 'whatever' );
}
}
|