Skip to content

Commit 1b84e5b

Browse files
authored
Merge pull request PAYONE-GmbH#342 from FatchipRobert/MAG2-169-CustomerValidationProblemsAmazonPay
MAG2-169 - Added plugin to prevent customer validation exceptions for…
2 parents cdf5a23 + 52fb62e commit 1b84e5b

File tree

3 files changed

+150
-0
lines changed

3 files changed

+150
-0
lines changed

Model/Plugins/QuoteValidator.php

Lines changed: 52 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,52 @@
1+
<?php
2+
3+
/**
4+
* PAYONE Magento 2 Connector is free software: you can redistribute it and/or modify
5+
* it under the terms of the GNU Lesser General Public License as published by
6+
* the Free Software Foundation, either version 3 of the License, or
7+
* (at your option) any later version.
8+
*
9+
* PAYONE Magento 2 Connector is distributed in the hope that it will be useful,
10+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12+
* GNU Lesser General Public License for more details.
13+
*
14+
* You should have received a copy of the GNU Lesser General Public License
15+
* along with PAYONE Magento 2 Connector. If not, see <http://www.gnu.org/licenses/>.
16+
*
17+
* PHP version 5
18+
*
19+
* @category Payone
20+
* @package Payone_Magento2_Plugin
21+
* @author FATCHIP GmbH <[email protected]>
22+
* @copyright 2003 - 2020 Payone GmbH
23+
* @license <http://www.gnu.org/licenses/> GNU Lesser General Public License
24+
* @link http://www.payone.de
25+
*/
26+
27+
namespace Payone\Core\Model\Plugins;
28+
29+
use Magento\Quote\Model\Quote;
30+
use Magento\Quote\Model\QuoteValidator as OrigQuoteValidator;
31+
use Payone\Core\Model\PayoneConfig;
32+
33+
class QuoteValidator
34+
{
35+
/**
36+
* This softens the customer validation for AmazonPay
37+
*
38+
* Since AmazonPay doesnt provide all information that can be configured as required in Magento2 this is needed for
39+
* some shop configurations because otherwise Magento2 will throw an exception and the AmazonPay cant be created
40+
*
41+
* @param OrigQuoteValidator $subject
42+
* @param callable $proceed
43+
* @param Quote $quote
44+
* @return OrigQuoteValidator
45+
*/
46+
public function aroundValidateBeforeSubmit(OrigQuoteValidator $subject, callable $proceed, Quote $quote) {
47+
if ($quote->getPayment()->getMethod() == PayoneConfig::METHOD_AMAZONPAY) {
48+
return $subject;
49+
}
50+
return $proceed($quote);
51+
}
52+
}
Lines changed: 95 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,95 @@
1+
<?php
2+
3+
/**
4+
* PAYONE Magento 2 Connector is free software: you can redistribute it and/or modify
5+
* it under the terms of the GNU Lesser General Public License as published by
6+
* the Free Software Foundation, either version 3 of the License, or
7+
* (at your option) any later version.
8+
*
9+
* PAYONE Magento 2 Connector is distributed in the hope that it will be useful,
10+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12+
* GNU Lesser General Public License for more details.
13+
*
14+
* You should have received a copy of the GNU Lesser General Public License
15+
* along with PAYONE Magento 2 Connector. If not, see <http://www.gnu.org/licenses/>.
16+
*
17+
* PHP version 5
18+
*
19+
* @category Payone
20+
* @package Payone_Magento2_Plugin
21+
* @author FATCHIP GmbH <[email protected]>
22+
* @copyright 2003 - 2020 Payone GmbH
23+
* @license <http://www.gnu.org/licenses/> GNU Lesser General Public License
24+
* @link http://www.payone.de
25+
*/
26+
27+
namespace Payone\Core\Test\Unit\Model\Plugins;
28+
29+
use Magento\Quote\Model\Quote;
30+
use Payone\Core\Model\PayoneConfig;
31+
use Payone\Core\Model\Plugins\QuoteValidator as ClassToTest;
32+
use Magento\Framework\TestFramework\Unit\Helper\ObjectManager;
33+
use Payone\Core\Test\Unit\BaseTestCase;
34+
use Payone\Core\Test\Unit\PayoneObjectManager;
35+
use Magento\Quote\Model\QuoteValidator as OrigQuoteValidator;
36+
use Magento\Quote\Model\Quote\Payment;
37+
38+
class QuoteValidatorTest extends BaseTestCase
39+
{
40+
/**
41+
* @var ClassToTest
42+
*/
43+
private $classToTest;
44+
45+
/**
46+
* @var ObjectManager|PayoneObjectManager
47+
*/
48+
private $objectManager;
49+
50+
/**
51+
* @var ScopeConfigInterface
52+
*/
53+
private $scopeConfig;
54+
55+
protected function setUp(): void
56+
{
57+
$this->objectManager = $this->getObjectManager();
58+
59+
$this->classToTest = $this->objectManager->getObject(ClassToTest::class);
60+
}
61+
62+
public function testAroundValidateBeforeSubmit()
63+
{
64+
$payment = $this->getMockBuilder(Payment::class)->disableOriginalConstructor()->getMock();
65+
$payment->method('getMethod')->willReturn(PayoneConfig::METHOD_INVOICE);
66+
67+
$quote = $this->getMockBuilder(Quote::class)->disableOriginalConstructor()->getMock();
68+
$quote->method('getPayment')->willReturn($payment);
69+
70+
$subject = $this->getMockBuilder(OrigQuoteValidator::class)->disableOriginalConstructor()->getMock();
71+
$proceed = function ($quote) use ($subject) {
72+
return $subject;
73+
};
74+
75+
$result = $this->classToTest->aroundValidateBeforeSubmit($subject, $proceed, $quote);
76+
$this->assertInstanceOf(OrigQuoteValidator::class, $result);
77+
}
78+
79+
public function testAroundValidateBeforeSubmitAmazonPay()
80+
{
81+
$payment = $this->getMockBuilder(Payment::class)->disableOriginalConstructor()->getMock();
82+
$payment->method('getMethod')->willReturn(PayoneConfig::METHOD_AMAZONPAY);
83+
84+
$quote = $this->getMockBuilder(Quote::class)->disableOriginalConstructor()->getMock();
85+
$quote->method('getPayment')->willReturn($payment);
86+
87+
$subject = $this->getMockBuilder(OrigQuoteValidator::class)->disableOriginalConstructor()->getMock();
88+
$proceed = function ($quote) use ($subject) {
89+
return $subject;
90+
};
91+
92+
$result = $this->classToTest->aroundValidateBeforeSubmit($subject, $proceed, $quote);
93+
$this->assertInstanceOf(OrigQuoteValidator::class, $result);
94+
}
95+
}

etc/di.xml

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -92,6 +92,9 @@
9292
<type name="Magento\Payment\Helper\Data">
9393
<plugin sortOrder="5" name="payonePaymentData" type="Payone\Core\Model\Plugins\PaymentHelper"/>
9494
</type>
95+
<type name="Magento\Quote\Model\QuoteValidator">
96+
<plugin name="payoneQuoteValidator" type="Payone\Core\Model\Plugins\QuoteValidator" sortOrder="5"/>
97+
</type>
9598
<type name="Payone\Core\Model\Logger\Info">
9699
<arguments>
97100
<argument name="filesystem" xsi:type="object">Magento\Framework\Filesystem\Driver\File</argument>

0 commit comments

Comments
 (0)