Skip to content

Commit c929f34

Browse files
committed
ACP2E-1215: Customer has no any vault token save, but vault payment method appears in admin checkout
1 parent 5bfb8b0 commit c929f34

File tree

1 file changed

+102
-0
lines changed

1 file changed

+102
-0
lines changed
Lines changed: 102 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,102 @@
1+
<?php
2+
/**
3+
* Copyright © Magento, Inc. All rights reserved.
4+
* See COPYING.txt for license details.
5+
*/
6+
declare(strict_types=1);
7+
8+
namespace Magento\Vault\Test\Unit\Plugin;
9+
10+
use Magento\Payment\Api\Data\PaymentMethodInterface;
11+
use Magento\Payment\Block\Form\Container;
12+
use Magento\Vault\Model\VaultPaymentInterface;
13+
use Magento\Vault\Plugin\PaymentMethodProcess;
14+
use Magento\Vault\Model\Ui\Adminhtml\TokensConfigProvider;
15+
use Magento\Vault\Model\Ui\TokenUiComponentInterface;
16+
use PHPUnit\Framework\MockObject\MockObject;
17+
use PHPUnit\Framework\TestCase;
18+
19+
class PaymentMethodProcessTest extends TestCase
20+
{
21+
/**
22+
* @const string
23+
*/
24+
public const PAYMENT_METHOD_CHECKMO = 'checkmo';
25+
26+
/**
27+
* @const string
28+
*/
29+
public const PAYMENT_METHOD_PAYFLOWPRO_CC_VAULT = 'payflowpro_cc_vault';
30+
31+
/**
32+
* @var TokensConfigProvider|MockObject
33+
*/
34+
private TokensConfigProvider $tokensConfigProviderMock;
35+
36+
/**
37+
* @var PaymentMethodProcess
38+
*/
39+
private $subject;
40+
41+
/**
42+
* @inheritdoc
43+
*/
44+
protected function setUp(): void
45+
{
46+
$this->tokensConfigProviderMock = $this->getMockBuilder(TokensConfigProvider::class)
47+
->disableOriginalConstructor()
48+
->getMock();
49+
50+
$this->subject = new PaymentMethodProcess($this->tokensConfigProviderMock);
51+
}
52+
53+
/**
54+
* Test retrieve available payment methods
55+
*
56+
* @param TokenUiComponentInterface|null $tokenInterface
57+
* @param int $availableMethodsCount
58+
* @dataProvider afterGetMethodsDataProvider
59+
*/
60+
public function testAfterGetMethods($tokenInterface, $availableMethodsCount)
61+
{
62+
$checkmoPaymentMethod = $this->getMockBuilder(PaymentMethodInterface::class)
63+
->disableOriginalConstructor()
64+
->setMethods(['getCode'])
65+
->getMockForAbstractClass();
66+
$checkmoPaymentMethod->expects($this->any())->method('getCode')
67+
->willReturn(self::PAYMENT_METHOD_CHECKMO);
68+
69+
$payflowCCVaultTPaymentMethod = $this->getMockBuilder(VaultPaymentInterface::class)
70+
->disableOriginalConstructor()
71+
->setMethods(['getCode'])
72+
->getMockForAbstractClass();
73+
$payflowCCVaultTPaymentMethod->expects($this->any())->method('getCode')
74+
->willReturn(self::PAYMENT_METHOD_PAYFLOWPRO_CC_VAULT);
75+
$methods = [$checkmoPaymentMethod, $payflowCCVaultTPaymentMethod];
76+
$containerMock = $this->getMockBuilder(Container::class)
77+
->disableOriginalConstructor()
78+
->getMock();
79+
80+
$this->tokensConfigProviderMock->method('getTokensComponents')
81+
->with(self::PAYMENT_METHOD_PAYFLOWPRO_CC_VAULT)
82+
->willReturn($tokenInterface);
83+
84+
$result = $this->subject->afterGetMethods($containerMock, $methods);
85+
$this->assertEquals($availableMethodsCount, count($result));
86+
}
87+
88+
/**
89+
* Data Provider
90+
*/
91+
public function afterGetMethodsDataProvider()
92+
{
93+
$tokenUiComponentInterface = $this->getMockBuilder(TokenUiComponentInterface::class)
94+
->disableOriginalConstructor()
95+
->getMock();
96+
97+
return [
98+
[null, 1],
99+
[$tokenUiComponentInterface, 2],
100+
];
101+
}
102+
}

0 commit comments

Comments
 (0)