From ce4c7d1ba97189285484e21e703b193289e3b425 Mon Sep 17 00:00:00 2001 From: David Grayston Date: Tue, 17 Dec 2024 01:12:25 +0000 Subject: [PATCH] fix: Adjustment items can be omitted when adjustment type is full --- CHANGELOG.md | 6 ++ src/Client.php | 2 +- .../Operations/CreateAdjustment.php | 16 +++-- .../Adjustments/AdjustmentsClientTest.php | 41 +++++++++++++ .../create_type_full_with_no_items.json | 6 ++ .../create_type_full_with_null_items.json | 7 +++ .../create_type_partial_with_items.json | 13 +++++ .../Operations/CreateAdjustmentTest.php | 58 +++++++++++++++++++ 8 files changed, 144 insertions(+), 5 deletions(-) create mode 100644 tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_no_items.json create mode 100644 tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_null_items.json create mode 100644 tests/Functional/Resources/Adjustments/_fixtures/request/create_type_partial_with_items.json create mode 100644 tests/Unit/Resources/Adjustments/Operations/CreateAdjustmentTest.php diff --git a/CHANGELOG.md b/CHANGELOG.md index 2f8c135..1de8048 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,12 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), Check our main [developer changelog](https://developer.paddle.com/?utm_source=dx&utm_medium=paddle-php-sdk) for information about changes to the Paddle Billing platform, the Paddle API, and other developer tools. +## [1.7.2] - 2024-12-17 + +### Fixed + +- Adjustment items can be omitted for when adjustment type is full + ## [1.7.1] - 2024-12-13 ### Fixed diff --git a/src/Client.php b/src/Client.php index b8836ca..4a49986 100644 --- a/src/Client.php +++ b/src/Client.php @@ -60,7 +60,7 @@ class Client { - private const SDK_VERSION = '1.7.1'; + private const SDK_VERSION = '1.7.2'; public readonly LoggerInterface $logger; public readonly Options $options; diff --git a/src/Resources/Adjustments/Operations/CreateAdjustment.php b/src/Resources/Adjustments/Operations/CreateAdjustment.php index 9b0ef41..45f227c 100644 --- a/src/Resources/Adjustments/Operations/CreateAdjustment.php +++ b/src/Resources/Adjustments/Operations/CreateAdjustment.php @@ -22,21 +22,27 @@ class CreateAdjustment implements \JsonSerializable */ public function __construct( public readonly Action $action, - public readonly array|Undefined $items, + public readonly array|Undefined|null $items, public readonly string $reason, public readonly string $transactionId, public readonly AdjustmentType|Undefined $type = new Undefined(), ) { - if ($this->type === AdjustmentType::Partial() && ($this->items instanceof Undefined || empty($this->items))) { + $typeIsFull = AdjustmentType::Full()->equals($this->type); + + if (! $typeIsFull && ($this->items instanceof Undefined || empty($this->items))) { throw InvalidArgumentException::arrayIsEmpty('items'); } + + if ($typeIsFull && is_array($this->items)) { + throw new InvalidArgumentException('items are not allowed when the adjustment type is full'); + } } public function jsonSerialize(): array { - $items = []; + if (is_array($this->items)) { + $items = []; - if (! $this->items instanceof Undefined) { foreach ($this->items as $item) { $items[] = [ 'item_id' => $item->itemId, @@ -44,6 +50,8 @@ public function jsonSerialize(): array 'amount' => $item->amount, ]; } + } else { + $items = $this->items; } return $this->filterUndefined([ diff --git a/tests/Functional/Resources/Adjustments/AdjustmentsClientTest.php b/tests/Functional/Resources/Adjustments/AdjustmentsClientTest.php index e154311..4ed5fdb 100644 --- a/tests/Functional/Resources/Adjustments/AdjustmentsClientTest.php +++ b/tests/Functional/Resources/Adjustments/AdjustmentsClientTest.php @@ -19,6 +19,7 @@ use Paddle\SDK\Resources\Adjustments\Operations\ListAdjustments; use Paddle\SDK\Resources\Shared\Operations\List\Pager; use Paddle\SDK\Tests\Utils\ReadsFixtures; +use Paddle\SDK\Undefined; use PHPUnit\Framework\TestCase; use Psr\Http\Message\RequestInterface; use Psr\Http\Message\ResponseInterface; @@ -100,6 +101,46 @@ public static function createOperationsProvider(): \Generator new Response(200, body: self::readRawJsonFixture('response/full_entity')), self::readRawJsonFixture('request/create_full'), ]; + + yield 'Partial type with items' => [ + new CreateAdjustment( + Action::Refund(), + [new AdjustmentItem( + 'txnitm_01h8bxryv3065dyh6103p3yg28', + AdjustmentType::Partial(), + '100', + )], + 'error', + 'txn_01h8bxpvx398a7zbawb77y0kp5', + \Paddle\SDK\Entities\Adjustment\AdjustmentType::Partial(), + ), + new Response(200, body: self::readRawJsonFixture('response/minimal_entity')), + self::readRawJsonFixture('request/create_type_partial_with_items'), + ]; + + yield 'Full type with no items' => [ + new CreateAdjustment( + Action::Refund(), + new Undefined(), + 'error', + 'txn_01h8bxpvx398a7zbawb77y0kp5', + \Paddle\SDK\Entities\Adjustment\AdjustmentType::Full(), + ), + new Response(200, body: self::readRawJsonFixture('response/minimal_entity')), + self::readRawJsonFixture('request/create_type_full_with_no_items'), + ]; + + yield 'Full type with null items' => [ + new CreateAdjustment( + Action::Refund(), + null, + 'error', + 'txn_01h8bxpvx398a7zbawb77y0kp5', + \Paddle\SDK\Entities\Adjustment\AdjustmentType::Full(), + ), + new Response(200, body: self::readRawJsonFixture('response/minimal_entity')), + self::readRawJsonFixture('request/create_type_full_with_null_items'), + ]; } /** diff --git a/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_no_items.json b/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_no_items.json new file mode 100644 index 0000000..2c6d204 --- /dev/null +++ b/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_no_items.json @@ -0,0 +1,6 @@ +{ + "action": "refund", + "type": "full", + "reason": "error", + "transaction_id": "txn_01h8bxpvx398a7zbawb77y0kp5" +} diff --git a/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_null_items.json b/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_null_items.json new file mode 100644 index 0000000..09698c8 --- /dev/null +++ b/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_full_with_null_items.json @@ -0,0 +1,7 @@ +{ + "action": "refund", + "type": "full", + "items": null, + "reason": "error", + "transaction_id": "txn_01h8bxpvx398a7zbawb77y0kp5" +} diff --git a/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_partial_with_items.json b/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_partial_with_items.json new file mode 100644 index 0000000..7800085 --- /dev/null +++ b/tests/Functional/Resources/Adjustments/_fixtures/request/create_type_partial_with_items.json @@ -0,0 +1,13 @@ +{ + "action": "refund", + "type": "partial", + "items": [ + { + "item_id": "txnitm_01h8bxryv3065dyh6103p3yg28", + "type": "partial", + "amount": "100" + } + ], + "reason": "error", + "transaction_id": "txn_01h8bxpvx398a7zbawb77y0kp5" +} diff --git a/tests/Unit/Resources/Adjustments/Operations/CreateAdjustmentTest.php b/tests/Unit/Resources/Adjustments/Operations/CreateAdjustmentTest.php new file mode 100644 index 0000000..1377f12 --- /dev/null +++ b/tests/Unit/Resources/Adjustments/Operations/CreateAdjustmentTest.php @@ -0,0 +1,58 @@ + [ + [], + AdjustmentType::Partial(), + 'items cannot be empty', + ]; + yield 'Undefined' => [ + new Undefined(), + AdjustmentType::Partial(), + 'items cannot be empty', + ]; + yield 'Null' => [ + null, + AdjustmentType::Partial(), + 'items cannot be empty', + ]; + yield 'Items for full type' => [ + [], + AdjustmentType::Full(), + 'items are not allowed when the adjustment type is full', + ]; + } +}