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