WeakPasswordHasherTest.php 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  5. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  6. *
  7. * Licensed under The MIT License
  8. * For full copyright and license information, please see the LICENSE.txt
  9. * Redistributions of files must retain the above copyright notice.
  10. *
  11. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  12. * @link https://cakephp.org CakePHP(tm) Project
  13. * @since 3.0.0
  14. * @license https://opensource.org/licenses/mit-license.php MIT License
  15. */
  16. namespace Cake\Test\TestCase\Auth;
  17. use Cake\Auth\WeakPasswordHasher;
  18. use Cake\TestSuite\TestCase;
  19. use Cake\Utility\Security;
  20. /**
  21. * Test case for WeakPasswordHasher
  22. */
  23. class WeakPasswordHasherTest extends TestCase
  24. {
  25. /**
  26. * setUp method
  27. */
  28. public function setUp(): void
  29. {
  30. parent::setUp();
  31. Security::setSalt('YJfIxfs2guVoUubWDYhG93b0qyJfIxfs2guwvniR2G0FgaC9mia1390as13dla8kjasdlwerpoiASf');
  32. }
  33. /**
  34. * Tests that any password not produced by WeakPasswordHasher needs
  35. * to be rehashed
  36. */
  37. public function testNeedsRehash(): void
  38. {
  39. $hasher = new WeakPasswordHasher();
  40. $this->assertTrue($hasher->needsRehash(md5('foo')));
  41. $this->assertTrue($hasher->needsRehash('bar'));
  42. $this->assertFalse($hasher->needsRehash('$2y$10$juOA0XVFpvZa0KTxRxEYVuX5kIS7U1fKDRcxyYhhUQECN1oHYnBMy'));
  43. }
  44. /**
  45. * Tests hash() and check()
  46. */
  47. public function testHashAndCheck(): void
  48. {
  49. $hasher = new WeakPasswordHasher();
  50. $hasher->setConfig('hashType', 'md5');
  51. $password = $hasher->hash('foo');
  52. $this->assertTrue($hasher->check('foo', $password));
  53. $this->assertFalse($hasher->check('bar', $password));
  54. $hasher->setConfig('hashType', 'sha1');
  55. $this->assertFalse($hasher->check('foo', $password));
  56. }
  57. }