MassDeleteTest.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. declare(strict_types=1);
  7. namespace Magento\Customer\Controller\Adminhtml\Index;
  8. use Magento\Backend\Model\Session;
  9. use Magento\Customer\Api\CustomerRepositoryInterface;
  10. use Magento\Customer\Api\Data\CustomerInterface;
  11. use PHPUnit\Framework\Constraint\Constraint;
  12. use Magento\Framework\Message\MessageInterface;
  13. use Magento\TestFramework\Helper\Bootstrap;
  14. use Magento\Framework\App\Request\Http as HttpRequest;
  15. use Magento\TestFramework\TestCase\AbstractBackendController;
  16. /**
  17. * @magentoAppArea adminhtml
  18. */
  19. class MassDeleteTest extends AbstractBackendController
  20. {
  21. /**
  22. * @var CustomerRepositoryInterface
  23. */
  24. private $customerRepository;
  25. /**
  26. * Base controller URL
  27. *
  28. * @var string
  29. */
  30. private $baseControllerUrl = 'http://localhost/index.php/backend/customer/index/index';
  31. /**
  32. * @inheritDoc
  33. *
  34. * @throws \Magento\Framework\Exception\AuthenticationException
  35. */
  36. protected function setUp()
  37. {
  38. parent::setUp();
  39. $this->customerRepository = Bootstrap::getObjectManager()->get(CustomerRepositoryInterface::class);
  40. }
  41. /**
  42. * @inheritDoc
  43. */
  44. protected function tearDown()
  45. {
  46. /**
  47. * Unset customer data
  48. */
  49. Bootstrap::getObjectManager()->get(Session::class)->setCustomerData(null);
  50. /**
  51. * Unset messages
  52. */
  53. Bootstrap::getObjectManager()->get(Session::class)->getMessages(true);
  54. }
  55. /**
  56. * Validates failure attempts to delete customers from grid.
  57. *
  58. * @param array|null $ids
  59. * @param Constraint $constraint
  60. * @param string|null $messageType
  61. * @magentoDataFixture Magento/Customer/_files/five_repository_customers.php
  62. * @magentoDbIsolation disabled
  63. * @dataProvider failedRequestDataProvider
  64. */
  65. public function testFailedMassDeleteAction($ids, Constraint $constraint, $messageType)
  66. {
  67. $this->massDeleteAssertions($ids, $constraint, $messageType);
  68. }
  69. /**
  70. * Validates success attempt to delete customer from grid.
  71. *
  72. * @param array $emails
  73. * @param Constraint $constraint
  74. * @param string $messageType
  75. * @magentoDataFixture Magento/Customer/_files/five_repository_customers.php
  76. * @magentoDbIsolation disabled
  77. * @dataProvider successRequestDataProvider
  78. */
  79. public function testSuccessMassDeleteAction(array $emails, Constraint $constraint, string $messageType)
  80. {
  81. $ids = [];
  82. foreach ($emails as $email) {
  83. /** @var CustomerInterface $customer */
  84. $customer = $this->customerRepository->get($email);
  85. $ids[] = $customer->getId();
  86. }
  87. $this->massDeleteAssertions(
  88. $ids,
  89. $constraint,
  90. $messageType
  91. );
  92. }
  93. /**
  94. * Performs required request and assertions.
  95. *
  96. * @param array|null $ids
  97. * @param Constraint $constraint
  98. * @param string|null $messageType
  99. */
  100. private function massDeleteAssertions($ids, Constraint $constraint, $messageType)
  101. {
  102. $requestData = [
  103. 'selected' => $ids,
  104. 'namespace' => 'customer_listing',
  105. ];
  106. $this->getRequest()->setParams($requestData)->setMethod(HttpRequest::METHOD_POST);
  107. $this->dispatch('backend/customer/index/massDelete');
  108. $this->assertSessionMessages(
  109. $constraint,
  110. $messageType
  111. );
  112. $this->assertRedirect($this->stringStartsWith($this->baseControllerUrl));
  113. }
  114. /**
  115. * Provides sets of data for unsuccessful attempts.
  116. *
  117. * @return array
  118. */
  119. public function failedRequestDataProvider(): array
  120. {
  121. return [
  122. [
  123. 'ids' => [],
  124. 'constraint' => self::equalTo(['An item needs to be selected. Select and try again.']),
  125. 'messageType' => MessageInterface::TYPE_ERROR,
  126. ],
  127. [
  128. 'ids' => [111],
  129. 'constraint' => self::isEmpty(),
  130. 'messageType' => null,
  131. ],
  132. [
  133. 'ids' => null,
  134. 'constraint' => self::equalTo(['An item needs to be selected. Select and try again.']),
  135. 'messageType' => MessageInterface::TYPE_ERROR,
  136. ]
  137. ];
  138. }
  139. /**
  140. * Provides sets of data for successful attempts.
  141. *
  142. * @return array
  143. */
  144. public function successRequestDataProvider(): array
  145. {
  146. return [
  147. [
  148. 'customerEmails' => ['customer1@example.com'],
  149. 'constraint' => self::equalTo(['A total of 1 record(s) were deleted.']),
  150. 'messageType' => MessageInterface::TYPE_SUCCESS,
  151. ],
  152. [
  153. 'customerEmails' => ['customer2@example.com', 'customer3@example.com'],
  154. 'constraint' => self::equalTo(['A total of 2 record(s) were deleted.']),
  155. 'messageType' => MessageInterface::TYPE_SUCCESS,
  156. ],
  157. ];
  158. }
  159. }