309 lines
8.2 KiB
PHP
Executable File
309 lines
8.2 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Copyright © Magento, Inc. All rights reserved.
|
|
* See COPYING.txt for license details.
|
|
*/
|
|
declare(strict_types=1);
|
|
|
|
namespace Magento\GraphQl\Customer;
|
|
|
|
use Exception;
|
|
use Magento\Customer\Api\AccountManagementInterface;
|
|
use Magento\Customer\Model\AccountManagement;
|
|
use Magento\Customer\Model\CustomerRegistry;
|
|
use Magento\Framework\Exception\LocalizedException;
|
|
use Magento\Framework\Exception\NoSuchEntityException;
|
|
use Magento\Framework\ObjectManagerInterface;
|
|
use Magento\TestFramework\Helper\Bootstrap;
|
|
use Magento\TestFramework\TestCase\GraphQlAbstract;
|
|
|
|
/**
|
|
* Class reset password for customer account
|
|
*/
|
|
class ResetPasswordTest extends GraphQlAbstract
|
|
{
|
|
const CUSTOMER_EMAIL = "customer@example.com";
|
|
|
|
const CUSTOMER_NEW_PASSWORD = "new_password123";
|
|
|
|
/** @var ObjectManagerInterface */
|
|
private $objectManager;
|
|
|
|
/** @var AccountManagementInterface */
|
|
private $accountManagement;
|
|
|
|
/** @var CustomerRegistry */
|
|
private $customerRegistry;
|
|
|
|
/**
|
|
* @var LockCustomer
|
|
*/
|
|
private $lockCustomer;
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
protected function setUp(): void
|
|
{
|
|
$this->objectManager = Bootstrap::getObjectManager();
|
|
$this->accountManagement = $this->objectManager->get(AccountManagementInterface::class);
|
|
$this->customerRegistry = $this->objectManager->get(CustomerRegistry::class);
|
|
$this->lockCustomer = Bootstrap::getObjectManager()->get(LockCustomer::class);
|
|
parent::setUp();
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @return void
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
*
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testResetCustomerAccountPasswordSuccessfully(): void
|
|
{
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: "{$this->getNewPassword()}"
|
|
)
|
|
}
|
|
QUERY;
|
|
$response = $this->graphQlMutation($query);
|
|
self::assertArrayHasKey('resetPassword', $response);
|
|
self::assertTrue($response['resetPassword']);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testEmailAvailableEmptyValue()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('You must specify an email address.');
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: ""
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: "{$this->getNewPassword()}"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testEmailInvalidValue()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('The email address has an invalid format.');
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "invalid-email"
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: "{$this->getNewPassword()}"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testResetPasswordTokenEmptyValue()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('resetPasswordToken must be specified');
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: ""
|
|
newPassword: "{$this->getNewPassword()}"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testResetPasswordTokenMismatched()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('The password token is mismatched. Reset and try again');
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: "1234567890XYZ"
|
|
newPassword: "{$this->getNewPassword()}"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testNewPasswordEmptyValue()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('newPassword must be specified');
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: ""
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testNewPasswordCheckMinLength()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('The password needs at least 8 characters. Create a new password and try again');
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: "new_"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws NoSuchEntityException
|
|
* @throws Exception
|
|
* @throws LocalizedException
|
|
*/
|
|
public function testNewPasswordCheckCharactersStrength()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage(
|
|
'Minimum of different classes of characters in password is 3. ' .
|
|
'Classes of characters: Lower Case, Upper Case, Digits, Special Characters.'
|
|
);
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: "new_password"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* Check password reset for lock customer
|
|
*
|
|
* @magentoApiDataFixture Magento/Customer/_files/customer.php
|
|
*
|
|
* @throws LocalizedException
|
|
* @throws NoSuchEntityException
|
|
*/
|
|
public function testPasswordResetForLockCustomer()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('The account is locked');
|
|
$this->lockCustomer->execute(1);
|
|
$query = <<<QUERY
|
|
mutation {
|
|
resetPassword (
|
|
email: "{$this->getCustomerEmail()}"
|
|
resetPasswordToken: "{$this->getResetPasswordToken()}"
|
|
newPassword: "{$this->getNewPassword()}"
|
|
)
|
|
}
|
|
QUERY;
|
|
$this->graphQlMutation($query);
|
|
}
|
|
|
|
/**
|
|
* Get reset password token
|
|
*
|
|
* @return string
|
|
*
|
|
* @throws LocalizedException
|
|
* @throws NoSuchEntityException
|
|
*/
|
|
private function getResetPasswordToken()
|
|
{
|
|
$this->accountManagement->initiatePasswordReset(
|
|
$this->getCustomerEmail(),
|
|
AccountManagement::EMAIL_RESET,
|
|
1
|
|
);
|
|
|
|
$customerSecure = $this->customerRegistry->retrieveSecureData(1);
|
|
return $customerSecure->getRpToken();
|
|
}
|
|
|
|
/**
|
|
* Get customer email
|
|
*
|
|
* @return string
|
|
*/
|
|
private function getCustomerEmail()
|
|
{
|
|
return self::CUSTOMER_EMAIL;
|
|
}
|
|
|
|
/**
|
|
* Get new password for customer account
|
|
*
|
|
* @return string
|
|
*/
|
|
private function getNewPassword()
|
|
{
|
|
return self::CUSTOMER_NEW_PASSWORD;
|
|
}
|
|
}
|