File: Pbkdf2PasswordTestCase.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (77 lines) | stat: -rw-r--r-- 2,108 bytes parent folder | download
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' );
	}
}