assertEquals( $hash, auth_cryptPassword('foo' . $method, $method, 'abcdefgh12345678912345678912345678') ); } /** * @dataProvider hashes * @param $method * @param $hash */ function test_verifyPassword($method, $hash) { $this->assertTrue(auth_verifyPassword('foo' . $method, $hash)); $this->assertFalse(auth_verifyPassword('bar' . $method, $hash)); } /** * @dataProvider hashes * @param $method * @param $hash */ function test_verifySelf($method, $hash) { $hash = auth_cryptPassword('foo' . $method, $method); $this->assertTrue(auth_verifyPassword('foo' . $method, $hash)); } function test_bcrypt_self() { $hash = auth_cryptPassword('foobcrypt', 'bcrypt'); $this->assertTrue(auth_verifyPassword('foobcrypt', $hash)); } function test_verifyPassword_fixedbcrypt() { $this->assertTrue(auth_verifyPassword('foobcrypt', '$2a$12$uTWercxbq4sjp2xAzv3we.ZOxk51m5V/Bv5bp2H27oVFJl5neFQoC')); } function test_verifyPassword_nohash() { $this->assertTrue(auth_verifyPassword('foo', '$1$$n1rTiFE0nRifwV/43bVon/')); } function test_verifyPassword_fixedpmd5() { $this->assertTrue(auth_verifyPassword('test12345', '$P$9IQRaTwmfeRo7ud9Fh4E2PdI0S3r.L0')); $this->assertTrue(auth_verifyPassword('test12345', '$H$9IQRaTwmfeRo7ud9Fh4E2PdI0S3r.L0')); } function test_veryPassword_mediawiki() { $this->assertTrue(auth_verifyPassword('password', ':B:838c83e1:e4ab7024509eef084cdabd03d8b2972c')); } /** * pmd5 checking should throw an exception when a hash with a too high * iteration count is passed */ function test_verifyPassword_pmd5Exception() { $except = false; try { auth_verifyPassword('foopmd5', '$H$abcdefgh1ZbJodHxmeXVAhEzTG7IAp.'); } catch(Exception $e) { $except = true; } $this->assertTrue($except); } /** * issue #2629, support PHP's crypt() format (with rounds=0 parameter) */ function test_verifyPassword_sha512_crypt() { if(defined('CRYPT_SHA512') && CRYPT_SHA512 == 1) { $this->assertTrue(auth_verifyPassword('Qwerty123', '$6$rounds=3000$9in6UciYPFG6ydsJ$YBjypQ7XoRqvJoX1a2.spSysSVHcdreVXi1Xh5SyOxo2yNSxDjlUCun2YXrwk9.YP6vmRvCWrhp0fbPgSOT7..')); } else { $this->markTestSkipped('SHA512 not available in this PHP environment'); } } }