170 lines
5.9 KiB
PHP
Executable File
170 lines
5.9 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Copyright © Magento, Inc. All rights reserved.
|
|
* See COPYING.txt for license details.
|
|
*/
|
|
declare(strict_types=1);
|
|
|
|
namespace Magento\Customer\Controller;
|
|
|
|
use Magento\Customer\Model\CustomerRegistry;
|
|
use Magento\Customer\Model\ResourceModel\Customer as CustomerResource;
|
|
use Magento\Customer\Model\Session;
|
|
use Magento\Framework\Intl\DateTimeFactory;
|
|
use Magento\Framework\Math\Random;
|
|
use Magento\Framework\Message\MessageInterface;
|
|
use Magento\Framework\ObjectManagerInterface;
|
|
use Magento\Framework\Stdlib\DateTime;
|
|
use Magento\Framework\View\LayoutInterface;
|
|
use Magento\Store\Api\WebsiteRepositoryInterface;
|
|
use Magento\TestFramework\Helper\Bootstrap;
|
|
use Magento\TestFramework\TestCase\AbstractController;
|
|
|
|
/**
|
|
* Class checks password forgot scenarios
|
|
*
|
|
* @magentoDbIsolation enabled
|
|
*/
|
|
class CreatePasswordTest extends AbstractController
|
|
{
|
|
/** @var ObjectManagerInterface */
|
|
private $objectManager;
|
|
|
|
/** @var Session */
|
|
private $session;
|
|
|
|
/** @var LayoutInterface */
|
|
private $layout;
|
|
|
|
/** @var Random */
|
|
private $random;
|
|
|
|
/** @var CustomerResource */
|
|
private $customerResource;
|
|
|
|
/** @var CustomerRegistry */
|
|
private $customerRegistry;
|
|
|
|
/** @var DateTimeFactory */
|
|
private $dateTimeFactory;
|
|
|
|
/** @var WebsiteRepositoryInterface */
|
|
private $websiteRepository;
|
|
|
|
/** @var int */
|
|
private $customerId;
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
protected function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->objectManager = Bootstrap::getObjectManager();
|
|
$this->session = $this->objectManager->get(Session::class);
|
|
$this->layout = $this->objectManager->get(LayoutInterface::class);
|
|
$this->random = $this->objectManager->get(Random::class);
|
|
$this->customerResource = $this->objectManager->get(CustomerResource::class);
|
|
$this->customerRegistry = $this->objectManager->get(CustomerRegistry::class);
|
|
$this->dateTimeFactory = $this->objectManager->get(DateTimeFactory::class);
|
|
$this->websiteRepository = $this->objectManager->get(WebsiteRepositoryInterface::class);
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
protected function tearDown(): void
|
|
{
|
|
$this->customerRegistry->remove($this->customerId);
|
|
|
|
parent::tearDown();
|
|
}
|
|
|
|
/**
|
|
* @magentoDataFixture Magento/Customer/_files/customer_with_website.php
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testCreatePassword(): void
|
|
{
|
|
$defaultWebsite = $this->websiteRepository->get('base')->getId();
|
|
$customer = $this->customerRegistry->retrieveByEmail('john.doe@magento.com', $defaultWebsite);
|
|
$this->customerId = $customer->getId();
|
|
$token = $this->random->getUniqueHash();
|
|
$customer->changeResetPasswordLinkToken($token);
|
|
$customer->setData('confirmation', 'confirmation');
|
|
$this->customerResource->save($customer);
|
|
$this->session->setRpToken($token);
|
|
$this->session->setRpCustomerId($customer->getId());
|
|
$this->dispatch('customer/account/createPassword');
|
|
$block = $this->layout->getBlock('resetPassword');
|
|
$this->assertEquals($token, $block->getResetPasswordLinkToken());
|
|
}
|
|
|
|
/**
|
|
* @magentoDataFixture Magento/Customer/_files/customer_with_website.php
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testTokenHasExpired(): void
|
|
{
|
|
$defaultWebsite = $this->websiteRepository->get('base')->getId();
|
|
$customer = $this->customerRegistry->retrieveByEmail('john.doe@magento.com', $defaultWebsite);
|
|
$this->customerId = $customer->getId();
|
|
$token = $this->random->getUniqueHash();
|
|
$tooLongAgo = $this->dateTimeFactory->create()
|
|
->sub(\DateInterval::createFromDateString('1 month'))
|
|
->format(DateTime::DATETIME_PHP_FORMAT);
|
|
|
|
$customer->changeResetPasswordLinkToken($token);
|
|
$customer->setData('confirmation', 'confirmation');
|
|
$customerSecure = $this->customerRegistry->retrieveSecureData($this->customerId);
|
|
$customerSecure->setRpTokenCreatedAt($tooLongAgo);
|
|
$this->customerResource->save($customer);
|
|
|
|
$this->session->setRpToken($token);
|
|
$this->session->setRpCustomerId($this->customerId);
|
|
|
|
$this->dispatch('customer/account/createPassword');
|
|
|
|
$this->assertRedirect($this->stringContains('customer/account/forgotpassword'));
|
|
$this->assertSessionMessages(
|
|
$this->equalTo(['Your password reset link has expired.']),
|
|
MessageInterface::TYPE_ERROR
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @magentoDataFixture Magento/Customer/_files/customer_with_website.php
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testTokenExtendedOnPageLoad(): void
|
|
{
|
|
$defaultWebsite = $this->websiteRepository->get('base')->getId();
|
|
$customer = $this->customerRegistry->retrieveByEmail('john.doe@magento.com', $defaultWebsite);
|
|
$this->customerId = $customer->getId();
|
|
$token = $this->random->getUniqueHash();
|
|
$anHourAgo = $this->dateTimeFactory->create()
|
|
->sub(\DateInterval::createFromDateString('1 hour'))
|
|
->format(DateTime::DATETIME_PHP_FORMAT);
|
|
|
|
$customer->changeResetPasswordLinkToken($token);
|
|
$customer->setData('confirmation', 'confirmation');
|
|
$customerSecure = $this->customerRegistry->retrieveSecureData($this->customerId);
|
|
$customerSecure->setRpTokenCreatedAt($anHourAgo);
|
|
$this->customerResource->save($customer);
|
|
|
|
$this->session->setRpToken($token);
|
|
$this->session->setRpCustomerId($this->customerId);
|
|
|
|
$this->dispatch('customer/account/createPassword');
|
|
$block = $this->layout->getBlock('resetPassword');
|
|
$this->assertEquals($token, $block->getResetPasswordLinkToken());
|
|
|
|
$customerSecure = $this->customerRegistry->retrieveSecureData($this->customerId);
|
|
$this->assertNotEquals($anHourAgo, $customerSecure->getRpTokenCreatedAt());
|
|
}
|
|
}
|