![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/dev/tests/api-functional/testsuite/Magento/GraphQl/Customer/ |
<?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\Model\CustomerAuthUpdate; use Magento\Framework\Exception\AuthenticationException; use Magento\Integration\Api\CustomerTokenServiceInterface; use Magento\TestFramework\Helper\Bootstrap; use Magento\TestFramework\TestCase\GraphQlAbstract; /** * Tests for update customer */ class UpdateCustomerTest extends GraphQlAbstract { /** * @var CustomerTokenServiceInterface */ private $customerTokenService; /** * @var CustomerAuthUpdate */ private $customerAuthUpdate; /** * @var LockCustomer */ private $lockCustomer; protected function setUp(): void { parent::setUp(); $this->customerTokenService = Bootstrap::getObjectManager()->get(CustomerTokenServiceInterface::class); $this->customerAuthUpdate = Bootstrap::getObjectManager()->get(CustomerAuthUpdate::class); $this->lockCustomer = Bootstrap::getObjectManager()->get(LockCustomer::class); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateCustomer() { $currentEmail = '[email protected]'; $currentPassword = 'password'; $newPrefix = 'Dr'; $newFirstname = 'Richard'; $newMiddlename = 'Riley'; $newLastname = 'Rowe'; $newSuffix = 'III'; $newDob = '3/11/1972'; $newTaxVat = 'GQL1234567'; $newGender = 2; $newEmail = '[email protected]'; $query = <<<QUERY mutation { updateCustomer( input: { prefix: "{$newPrefix}" firstname: "{$newFirstname}" middlename: "{$newMiddlename}" lastname: "{$newLastname}" suffix: "{$newSuffix}" date_of_birth: "{$newDob}" taxvat: "{$newTaxVat}" email: "{$newEmail}" password: "{$currentPassword}" gender: {$newGender} } ) { customer { prefix firstname middlename lastname suffix date_of_birth taxvat email gender } } } QUERY; $response = $this->graphQlMutation( $query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword) ); $this->assertEquals($newPrefix, $response['updateCustomer']['customer']['prefix']); $this->assertEquals($newFirstname, $response['updateCustomer']['customer']['firstname']); $this->assertEquals($newMiddlename, $response['updateCustomer']['customer']['middlename']); $this->assertEquals($newLastname, $response['updateCustomer']['customer']['lastname']); $this->assertEquals($newSuffix, $response['updateCustomer']['customer']['suffix']); $this->assertEquals($newDob, $response['updateCustomer']['customer']['date_of_birth']); $this->assertEquals($newTaxVat, $response['updateCustomer']['customer']['taxvat']); $this->assertEquals($newEmail, $response['updateCustomer']['customer']['email']); $this->assertEquals($newGender, $response['updateCustomer']['customer']['gender']); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateCustomerIfInputDataIsEmpty() { $this->expectException(Exception::class); $this->expectExceptionMessage('"input" value should be specified'); $currentEmail = '[email protected]'; $currentPassword = 'password'; $query = <<<QUERY mutation { updateCustomer( input: { } ) { customer { firstname } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** */ public function testUpdateCustomerIfUserIsNotAuthorized() { $this->expectException(Exception::class); $this->expectExceptionMessage('The current customer isn\'t authorized.'); $newFirstname = 'Richard'; $query = <<<QUERY mutation { updateCustomer( input: { firstname: "{$newFirstname}" } ) { customer { firstname } } } QUERY; $this->graphQlMutation($query); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateCustomerIfAccountIsLocked() { $this->expectException(Exception::class); $this->expectExceptionMessage('The account is locked.'); $this->lockCustomer->execute(1); $currentEmail = '[email protected]'; $currentPassword = 'password'; $newFirstname = 'Richard'; $query = <<<QUERY mutation { updateCustomer( input: { firstname: "{$newFirstname}" } ) { customer { firstname } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateEmailIfPasswordIsMissed() { $this->expectException(Exception::class); $this->expectExceptionMessage('Provide the current "password" to change "email".'); $currentEmail = '[email protected]'; $currentPassword = 'password'; $newEmail = '[email protected]'; $query = <<<QUERY mutation { updateCustomer( input: { email: "{$newEmail}" } ) { customer { firstname } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateEmailIfPasswordIsInvalid() { $this->expectException(Exception::class); $this->expectExceptionMessage('Invalid login or password.'); $currentEmail = '[email protected]'; $currentPassword = 'password'; $invalidPassword = 'invalid_password'; $newEmail = '[email protected]'; $query = <<<QUERY mutation { updateCustomer( input: { email: "{$newEmail}" password: "{$invalidPassword}" } ) { customer { firstname } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** * @magentoApiDataFixture Magento/Customer/_files/two_customers.php */ public function testUpdateEmailIfEmailAlreadyExists() { $this->expectException(Exception::class); $this->expectExceptionMessage( 'A customer with the same email address already exists in an associated website.' ); $currentEmail = '[email protected]'; $currentPassword = 'password'; $existedEmail = '[email protected]'; $firstname = 'Richard'; $lastname = 'Rowe'; $query = <<<QUERY mutation { updateCustomer( input: { email: "{$existedEmail}" password: "{$currentPassword}" firstname: "{$firstname}" lastname: "{$lastname}" } ) { customer { firstname } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateEmailIfEmailIsInvalid() { $currentEmail = '[email protected]'; $currentPassword = 'password'; $invalidEmail = 'customer.example.com'; $query = <<<QUERY mutation { updateCustomer( input: { email: "{$invalidEmail}" password: "{$currentPassword}" } ) { customer { email } } } QUERY; $this->expectException(Exception::class); $this->expectExceptionMessage('"' . $invalidEmail . '" is not a valid email address.'); $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testEmptyCustomerName() { $this->expectException(Exception::class); $this->expectExceptionMessage('Required parameters are missing: First Name'); $currentEmail = '[email protected]'; $currentPassword = 'password'; $query = <<<QUERY mutation { updateCustomer( input: { email: "{$currentEmail}" password: "{$currentPassword}" firstname: "" } ) { customer { email } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders($currentEmail, $currentPassword)); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testEmptyCustomerLastName() { $query = <<<QUERY mutation { updateCustomer( input: { lastname: "" } ) { customer { lastname } } } QUERY; $this->expectException(Exception::class); $this->expectExceptionMessage('Required parameters are missing: Last Name'); $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders('[email protected]', 'password')); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateCustomerWithIncorrectGender() { $gender = 5; $this->expectException(Exception::class); $this->expectExceptionMessage('"' . $gender . '" is not a valid gender value.'); $query = <<<QUERY mutation { updateCustomer( input: { gender: {$gender} } ) { customer { gender } } } QUERY; $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders('[email protected]', 'password')); } /** * @magentoApiDataFixture Magento/Customer/_files/customer.php */ public function testUpdateCustomerIfDobIsInvalid() { $invalidDob = 'bla-bla-bla'; $query = <<<QUERY mutation { updateCustomer( input: { date_of_birth: "{$invalidDob}" } ) { customer { date_of_birth } } } QUERY; $this->expectException(Exception::class); $this->expectExceptionMessage('Invalid date'); $this->graphQlMutation($query, [], '', $this->getCustomerAuthHeaders('[email protected]', 'password')); } /** * @param string $email * @param string $password * @return array * @throws AuthenticationException */ private function getCustomerAuthHeaders(string $email, string $password): array { $customerToken = $this->customerTokenService->createCustomerAccessToken($email, $password); return ['Authorization' => 'Bearer ' . $customerToken]; } }