-
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.
NTR: PISHPW-231: Add satispay payment
- Loading branch information
Vitalij Mik
committed
Sep 9, 2024
1 parent
5bb317a
commit dcf232e
Showing
6 changed files
with
169 additions
and
0 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,25 @@ | ||
<?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 Satispay extends AbstractPayment implements PaymentInterface | ||
{ | ||
|
||
/** | ||
*/ | ||
public function __construct() | ||
{ | ||
parent::__construct( | ||
new AddressConverter(), | ||
new LineItemConverter(), | ||
PaymentMethod::SATISPAY | ||
); | ||
} | ||
} |
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
138 changes: 138 additions & 0 deletions
138
Tests/PHPUnit/Services/Mollie/Payments/Requests/SatispayTest.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,138 @@ | ||
<?php | ||
|
||
namespace MollieShopware\Tests\PHPUnit\Services\Mollie\Payments\Requests; | ||
|
||
use MollieShopware\Components\Constants\PaymentMethod; | ||
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\Satispay; | ||
use MollieShopware\Services\Mollie\Payments\Requests\Twint; | ||
use MollieShopware\Tests\Utils\Traits\PaymentTestTrait; | ||
use PHPUnit\Framework\TestCase; | ||
|
||
class SatispayTest 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 Satispay(); | ||
|
||
$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() | ||
{ | ||
$expected = [ | ||
'method' => PaymentMethod::SATISPAY, | ||
'amount' => [ | ||
'currency' => 'CHF', | ||
'value' => '49.98', | ||
], | ||
'description' => 'Payment UUID-123', | ||
'redirectUrl' => 'https://local/redirect', | ||
'webhookUrl' => 'https://local/notify', | ||
'locale' => 'de_DE', | ||
]; | ||
|
||
$requestBody = $this->payment->buildBodyPaymentsAPI(); | ||
|
||
$this->assertEquals($expected, $requestBody); | ||
} | ||
|
||
/** | ||
* This test verifies that the Orders-API request | ||
* for our payment is correct. | ||
*/ | ||
public function testOrdersAPI() | ||
{ | ||
$expected = [ | ||
'method' => PaymentMethod::SATISPAY, | ||
'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']); | ||
} | ||
} |