251 lines
6.7 KiB
PHP
251 lines
6.7 KiB
PHP
<?php
|
|
|
|
/** DomFramework - Tests
|
|
* @package domframework
|
|
* @author Dominique Fournier <dominique@fournier38.fr>
|
|
* @license BSD
|
|
*/
|
|
|
|
namespace Domframework\Tests;
|
|
|
|
use Domframework\Password;
|
|
|
|
/** Test the Password class
|
|
*/
|
|
class PasswordTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
public function test_cryptPasswd_1()
|
|
{
|
|
$res = Password::cryptPasswd("AAA");
|
|
$this->assertSame($res[0] == "$" && strlen($res) > 8, true);
|
|
}
|
|
|
|
public function test_cryptPasswd_2()
|
|
{
|
|
// Test the randomization of the salt : must be different each time
|
|
$res1 = Password::cryptPasswd("AAA");
|
|
echo "RES1=$res1\n";
|
|
$res2 = Password::cryptPasswd("AAA");
|
|
echo "RES2=$res2\n";
|
|
$res3 = Password::cryptPasswd("AAA");
|
|
echo "RES3=$res3\n";
|
|
$this->assertSame(count(array_unique(array ($res1, $res2, $res3))), 3);
|
|
// Three passwords : each must have a different result
|
|
}
|
|
|
|
public function test_cryptPasswd_3()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::cryptPasswd(false);
|
|
}
|
|
|
|
public function test_cryptPassword_MYSQL()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "MYSQL");
|
|
$this->assertSame($res, "*5AF9D0EA5F6406FB0EDD0507F81C1D5CEBE8AC9C");
|
|
}
|
|
|
|
public function test_cryptPassword_CRYPT_STD_DES()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "CRYPT_STD_DES");
|
|
$this->assertSame(strlen($res), 13);
|
|
}
|
|
|
|
public function test_cryptPassword_CRYPT_EXT_DES()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "CRYPT_EXT_DES");
|
|
$this->assertSame(strlen($res), 13);
|
|
}
|
|
|
|
public function test_cryptPassword_CRYPT_MD5()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "CRYPT_MD5");
|
|
$this->assertSame(
|
|
substr($res, 0, 3) === "$1$" && strlen($res) === 34,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_CRYPT_BLOWFISH()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "CRYPT_BLOWFISH");
|
|
$this->assertSame(
|
|
substr($res, 0, 4) === "$2y$" && strlen($res) > 24,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_CRYPT_SHA256()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "CRYPT_SHA256");
|
|
$this->assertSame(
|
|
substr($res, 0, 10) === "$5\$rounds=" && strlen($res) === 75,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_CRYPT_SHA512()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "CRYPT_SHA512");
|
|
$this->assertSame(
|
|
substr($res, 0, 10) === "$6\$rounds=" && strlen($res) === 118,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_PASSWORD_BCRYPT()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "PASSWORD_BCRYPT");
|
|
$this->assertSame(
|
|
substr($res, 0, 7) === "$2y\$10\$" && strlen($res) === 60,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_PASSWORD_ARGON2I()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "PASSWORD_ARGON2I");
|
|
$this->assertSame(
|
|
substr($res, 0, 11) === "\$argon2i\$v=" && strlen($res) === 96,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_PASSWORD_ARGON2ID()
|
|
{
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "PASSWORD_ARGON2ID");
|
|
$this->assertSame(
|
|
substr($res, 0, 12) === "\$argon2id\$v=" && strlen($res) === 97,
|
|
true
|
|
);
|
|
}
|
|
|
|
public function test_cryptPassword_UNKNOWN()
|
|
{
|
|
$this->expectException();
|
|
$password = new password();
|
|
$res = $password->cryptPassword("AAA", "UNKNOWN");
|
|
}
|
|
|
|
public function test_checkPassword_1()
|
|
{
|
|
$res = Password::checkPassword("AAA", "AAA");
|
|
$this->assertSame($res, false);
|
|
}
|
|
|
|
public function test_checkPassword_2()
|
|
{
|
|
$crypt = Password::cryptPasswd("AAA");
|
|
$res = Password::checkPassword("AAA", $crypt);
|
|
$this->assertSame($res, true);
|
|
}
|
|
|
|
public function test_checkPassword_3()
|
|
{
|
|
$res = Password::checkPassword("AAA", Password::cryptPasswd("BBB"));
|
|
$this->assertSame($res, false);
|
|
}
|
|
|
|
public function test_checkPassword_4()
|
|
{
|
|
$res = Password::checkPassword(
|
|
"AAA",
|
|
'$2y$11$Y.E98jbjgDpV61eK..9MT.klzTeg7ulO4WH/B5yA8cAGMIh.zoNXq'
|
|
);
|
|
$this->assertSame($res, true);
|
|
}
|
|
|
|
public function test_checkPassword_invalid1()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::checkPassword(
|
|
false,
|
|
'$2y$11$Y.E98jbjgDpV61eK..9MT.klzTeg7ulO4WH/B5yA8cAGMIh.zoNXq'
|
|
);
|
|
}
|
|
|
|
public function test_checkPassword_invalid2()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::checkPassword("AAA", false);
|
|
}
|
|
|
|
public function test_generateASCII_defaultsize()
|
|
{
|
|
$res = Password::generateASCII();
|
|
$this->assertSame(strlen($res), 12);
|
|
}
|
|
|
|
public function test_generateASCII_toobig()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::generateASCII(112);
|
|
}
|
|
|
|
public function test_generateASCII_toosmall()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::generateASCII(0);
|
|
}
|
|
|
|
public function test_generateAlphanum_defaultsize()
|
|
{
|
|
$res = Password::generateAlphanum();
|
|
$this->assertSame(strlen($res), 12);
|
|
}
|
|
|
|
public function test_generateAlphanum_toobig()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::generateAlphanum(112);
|
|
}
|
|
|
|
public function test_generateAlphanum_toosmall()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::generateAlphanum(0);
|
|
}
|
|
|
|
public function test_generateAlphabetical_defaultsize()
|
|
{
|
|
$res = Password::generateAlphabetical();
|
|
$this->assertSame(strlen($res), 12);
|
|
}
|
|
|
|
public function test_generateAlphabetical_toobig()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::generateAlphabetical(112);
|
|
}
|
|
|
|
public function test_generateAlphabetical_toosmall()
|
|
{
|
|
$this->expectException();
|
|
$res = Password::generateAlphabetical(0);
|
|
}
|
|
|
|
public function test_listMethods_1()
|
|
{
|
|
$password = new password();
|
|
$res = $password->listMethods();
|
|
$this->assertSame(count($res) > 7, true);
|
|
}
|
|
|
|
public function test_salt_1()
|
|
{
|
|
$password = new password();
|
|
$res = $password->salt();
|
|
$this->assertSame(strlen($res) > 20, true);
|
|
}
|
|
}
|