-
Notifications
You must be signed in to change notification settings - Fork 17
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
PISHPS-226: Add riverty payment (#422)
* NTR: PISHPW-226: add riverty payment * NTR: remove girpoay from cypress --------- Co-authored-by: Vitalij Mik <[email protected]>
- Loading branch information
1 parent
b15fe1e
commit a5b724c
Showing
7 changed files
with
169 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
<?php | ||
|
||
namespace MollieShopware\Services\Mollie\Payments\Requests; | ||
|
||
use MollieShopware\Components\Constants\PaymentMethod; | ||
use MollieShopware\Services\Mollie\Payments\AbstractPayment; | ||
use MollieShopware\Services\Mollie\Payments\Converters\AddressConverter; | ||
use MollieShopware\Services\Mollie\Payments\Converters\LineItemConverter; | ||
use MollieShopware\Services\Mollie\Payments\Exceptions\ApiNotSupportedException; | ||
use MollieShopware\Services\Mollie\Payments\PaymentInterface; | ||
|
||
class Riverty extends AbstractPayment implements PaymentInterface | ||
{ | ||
|
||
/** | ||
*/ | ||
public function __construct() | ||
{ | ||
parent::__construct( | ||
new AddressConverter(), | ||
new LineItemConverter(), | ||
PaymentMethod::RIVERTY | ||
); | ||
} | ||
|
||
/** | ||
* @throws ApiNotSupportedException | ||
* @return mixed[]|void | ||
*/ | ||
public function buildBodyPaymentsAPI() | ||
{ | ||
throw new ApiNotSupportedException('Klarna One does not support the Payments API!'); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
127 changes: 127 additions & 0 deletions
127
Tests/PHPUnit/Services/Mollie/Payments/Requests/RivertyTest.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
<?php | ||
|
||
namespace MollieShopware\Tests\PHPUnit\Services\Mollie\Payments\Requests; | ||
|
||
use MollieShopware\Components\Constants\PaymentMethod; | ||
use MollieShopware\Services\Mollie\Payments\Exceptions\ApiNotSupportedException; | ||
use MollieShopware\Services\Mollie\Payments\Models\Payment; | ||
use MollieShopware\Services\Mollie\Payments\Models\PaymentAddress; | ||
use MollieShopware\Services\Mollie\Payments\Models\PaymentLineItem; | ||
use MollieShopware\Services\Mollie\Payments\Requests\Riverty; | ||
use MollieShopware\Services\Mollie\Payments\Requests\Twint; | ||
use MollieShopware\Tests\Utils\Traits\PaymentTestTrait; | ||
use PHPUnit\Framework\TestCase; | ||
|
||
class RivertyTest extends TestCase | ||
{ | ||
use PaymentTestTrait; | ||
|
||
|
||
/** | ||
* @var Twint | ||
*/ | ||
private $payment; | ||
|
||
/** | ||
* @var PaymentAddress | ||
*/ | ||
private $addressInvoice; | ||
|
||
/** | ||
* @var PaymentAddress | ||
*/ | ||
private $addressShipping; | ||
|
||
/** | ||
* @var PaymentLineItem | ||
*/ | ||
private $lineItem; | ||
|
||
/** | ||
* | ||
*/ | ||
public function setUp(): void | ||
{ | ||
$this->payment = new Riverty(); | ||
|
||
$this->addressInvoice = $this->getAddressFixture1(); | ||
$this->addressShipping = $this->getAddressFixture2(); | ||
$this->lineItem = $this->getLineItemFixture(); | ||
|
||
$this->payment->setPayment( | ||
new Payment( | ||
'UUID-123', | ||
'Payment UUID-123', | ||
'20004', | ||
$this->addressInvoice, | ||
$this->addressShipping, | ||
49.98, | ||
[$this->lineItem], | ||
'CHF', | ||
'de_DE', | ||
'https://local/redirect', | ||
'https://local/notify' | ||
) | ||
); | ||
} | ||
|
||
/** | ||
* This test verifies that the Payments-API request | ||
* for our payment is correct. | ||
* Please note, Twint does not work with the payments API | ||
* so this is just an empty array | ||
*/ | ||
public function testPaymentsAPI() | ||
{ | ||
$this->expectException(ApiNotSupportedException::class); | ||
|
||
$this->payment->buildBodyPaymentsAPI(); | ||
} | ||
|
||
/** | ||
* This test verifies that the Orders-API request | ||
* for our payment is correct. | ||
*/ | ||
public function testOrdersAPI() | ||
{ | ||
$expected = [ | ||
'method' => PaymentMethod::RIVERTY, | ||
'amount' => [ | ||
'currency' => 'CHF', | ||
'value' => '49.98', | ||
], | ||
'redirectUrl' => 'https://local/redirect', | ||
'webhookUrl' => 'https://local/notify', | ||
'locale' => 'de_DE', | ||
'orderNumber' => '20004', | ||
'payment' => [ | ||
'webhookUrl' => 'https://local/notify', | ||
], | ||
'billingAddress' => $this->getExpectedAddressStructure($this->addressInvoice), | ||
'shippingAddress' => $this->getExpectedAddressStructure($this->addressShipping), | ||
'lines' => [ | ||
$this->getExpectedLineItemStructure($this->lineItem), | ||
], | ||
'metadata' => [], | ||
]; | ||
|
||
$requestBody = $this->payment->buildBodyOrdersAPI(); | ||
|
||
$this->assertSame($expected, $requestBody); | ||
} | ||
|
||
/** | ||
* This test verifies that we can set a custom expiration date | ||
* for our Orders API request. | ||
*/ | ||
public function testExpirationDate() | ||
{ | ||
$dueInDays = 5; | ||
$expectedDueDate = date('Y-m-d', strtotime(' + ' . $dueInDays . ' day')); | ||
|
||
$this->payment->setExpirationDays($dueInDays); | ||
$request = $this->payment->buildBodyOrdersAPI(); | ||
|
||
$this->assertEquals($expectedDueDate, $request['expiresAt']); | ||
} | ||
} |