magento2-docker/dev/tests/api-functional/testsuite/Magento/GraphQl/Customer/ResetPasswordTest.php

309 lines
8.2 KiB
PHP

<?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;
}
}