71 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
<?php
 | 
						|
/**
 | 
						|
 * Copyright © Magento, Inc. All rights reserved.
 | 
						|
 * See COPYING.txt for license details.
 | 
						|
 */
 | 
						|
declare(strict_types=1);
 | 
						|
 | 
						|
namespace Magento\Framework\Encryption;
 | 
						|
 | 
						|
class ModelTest extends \PHPUnit\Framework\TestCase
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @var \Magento\Framework\Encryption\Encryptor
 | 
						|
     */
 | 
						|
    protected $_model;
 | 
						|
 | 
						|
    protected function setUp(): void
 | 
						|
    {
 | 
						|
        $this->_model = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()->create(
 | 
						|
            \Magento\Framework\Encryption\Encryptor::class
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    public function testEncryptDecrypt()
 | 
						|
    {
 | 
						|
        $encryptor = $this->_model;
 | 
						|
 | 
						|
        $this->assertEquals('', $encryptor->decrypt($encryptor->encrypt('')));
 | 
						|
        $this->assertEquals('test', $encryptor->decrypt($encryptor->encrypt('test')));
 | 
						|
    }
 | 
						|
 | 
						|
    public function testEncryptDecrypt2()
 | 
						|
    {
 | 
						|
        $encryptor = $this->_model;
 | 
						|
 | 
						|
        // md5() here is not for cryptographic use just generate random string.
 | 
						|
        // phpcs:ignore Magento2.Security.InsecureFunction
 | 
						|
        $initial = md5(uniqid());
 | 
						|
        $encrypted = $encryptor->encrypt($initial);
 | 
						|
        $this->assertNotEquals($initial, $encrypted);
 | 
						|
        $this->assertEquals($initial, $encryptor->decrypt($encrypted));
 | 
						|
    }
 | 
						|
 | 
						|
    public function testValidateKey()
 | 
						|
    {
 | 
						|
        // md5() have to be use here.
 | 
						|
        // phpcs:ignore Magento2.Security.InsecureFunction
 | 
						|
        $validKey = md5(uniqid());
 | 
						|
        $this->_model->validateKey($validKey);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     */
 | 
						|
    public function testValidateKeyInvalid()
 | 
						|
    {
 | 
						|
        $this->expectException(\Exception::class);
 | 
						|
 | 
						|
        $invalidKey = '----    ';
 | 
						|
        $this->_model->validateKey($invalidKey);
 | 
						|
    }
 | 
						|
 | 
						|
    public function testGetValidateHash()
 | 
						|
    {
 | 
						|
        $password = uniqid();
 | 
						|
        $hash = $this->_model->getHash($password, true);
 | 
						|
 | 
						|
        $this->assertIsString($hash);
 | 
						|
        $this->assertTrue($this->_model->validateHash($password, $hash));
 | 
						|
    }
 | 
						|
}
 |