Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix order line observer #1732

Merged
merged 4 commits into from
Aug 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions packages/core/src/Observers/OrderLineObserver.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ class OrderLineObserver
*/
public function creating(OrderLine $orderLine)
{
if ($orderLine->type != 'shipping' && ! $orderLine->purchasable instanceof Purchasable) {
if (! in_array(Purchasable::class, class_implements($orderLine->purchasable_type, true))) {
throw new NonPurchasableItemException($orderLine->purchasable_type);
}
}
Expand All @@ -27,7 +27,7 @@ public function creating(OrderLine $orderLine)
*/
public function updating(OrderLine $orderLine)
{
if ($orderLine->type != 'shipping' && ! $orderLine->purchasable instanceof Purchasable) {
if (! in_array(Purchasable::class, class_implements($orderLine->purchasable_type, true))) {
throw new NonPurchasableItemException($orderLine->purchasable_type);
}
}
Expand Down
139 changes: 139 additions & 0 deletions packages/core/tests/Stubs/DataTypes/TestPurchasable.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,139 @@
<?php

namespace Lunar\Tests\Stubs\DataTypes;

use Illuminate\Support\Collection;
use Lunar\Base\Purchasable;
use Lunar\DataTypes\Price;
use Lunar\Models\TaxClass;

class TestPurchasable implements Purchasable
{
public function __construct(
public $name,
public $description,
public $identifier,
public Price $price,
public TaxClass $taxClass,
public $taxReference = null,
public $option = null,
public bool $collect = false,
public $meta = null
) {
// ..
}

/**
* Get the price for the purchasable item.
*
* @return \Lunar\DataTypes\Price
*/
public function getPrice()
{
return $this->price;
}

/**
* Get prices for the purchasable item.
*/
public function getPrices(): Collection
{
return collect([
$this->price,
]);
}

/**
* Return the purchasable unit quantity.
*/
public function getUnitQuantity(): int
{
return 1;
}

/**
* Return the purchasable tax class.
*/
public function getTaxClass(): TaxClass
{
return $this->taxClass;
}

/**
* Return the purchasable tax reference.
*
* @return string|null
*/
public function getTaxReference()
{
return $this->taxReference;
}

/**
* Return what type of purchasable this is, i.e. physical,digital,shipping.
*
* @return string
*/
public function getType()
{
return 'test-purchsable';
}

/**
* Return the name for the purchasable.
*
* @return string
*/
public function getName()
{
return $this->name;
}

/**
* Return the description for the purchasable.
*
* @return string
*/
public function getDescription()
{
return $this->description;
}

/**
* Return the option for this purchasable.
*
* @return string|null
*/
public function getOption()
{
return $this->option;
}

/**
* Return a unique string which identifies the purchasable item.
*
* @return string
*/
public function getIdentifier()
{
return $this->identifier;
}

/**
* Returns whether the purchasable item is shippable.
*
* @return bool
*/
public function isShippable()
{
return false;
}

/**
* {@inheritDoc}
*/
public function getThumbnail()
{
return null;
}
}
72 changes: 72 additions & 0 deletions packages/core/tests/Unit/Models/OrderLineTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,17 @@
namespace Lunar\Tests\Unit\Models;

use Illuminate\Foundation\Testing\RefreshDatabase;
use Lunar\DataTypes\Price;
use Lunar\DataTypes\ShippingOption;
use Lunar\Exceptions\NonPurchasableItemException;
use Lunar\Models\CartLine;
use Lunar\Models\Channel;
use Lunar\Models\Currency;
use Lunar\Models\Order;
use Lunar\Models\OrderLine;
use Lunar\Models\ProductVariant;
use Lunar\Models\TaxClass;
use Lunar\Tests\Stubs\DataTypes\TestPurchasable;
use Lunar\Tests\TestCase;

/**
Expand Down Expand Up @@ -91,4 +95,72 @@ public function only_purchasables_can_be_added_to_an_order()

$this->assertDatabaseMissing((new CartLine())->getTable(), $data);
}

/** @test */
public function purchasable_non_eloquent_models_can_be_added_to_an_order()
{
$order = Order::factory()->create();

$currency = Currency::factory()->create([
'default' => true,
]);

$taxClass = TaxClass::factory()->create();

$shippingOption = new ShippingOption(
name: 'Basic Delivery',
description: 'Basic Delivery',
identifier: 'BASDEL',
price: new Price(500, $currency, 1),
taxClass: $taxClass
);

$data = [
'order_id' => $order->id,
'quantity' => 1,
'type' => $shippingOption->getType(),
'purchasable_type' => ShippingOption::class,
'purchasable_id' => $shippingOption->getIdentifier(),
'unit_price' => $shippingOption->getPrice()->value,
'unit_quantity' => $shippingOption->getUnitQuantity(),
];

$orderLine = OrderLine::factory()->create($data);

$this->assertDatabaseHas(
(new OrderLine())->getTable(),
$data
);

$this->assertEquals(5.0, $orderLine->unit_price->decimal);
$this->assertEquals(5.0, $orderLine->unit_price->unitDecimal);

$testPurchasable = new TestPurchasable(
name: 'Test Purchasable',
description: 'Test Purchasable',
identifier: 'TESTPUR',
price: new Price(650, $currency, 1),
taxClass: $taxClass
);

$data = [
'order_id' => $order->id,
'quantity' => 1,
'type' => $testPurchasable->getType(),
'purchasable_type' => TestPurchasable::class,
'purchasable_id' => $testPurchasable->getIdentifier(),
'unit_price' => $testPurchasable->getPrice()->value,
'unit_quantity' => $testPurchasable->getUnitQuantity(),
];

$orderLine = OrderLine::factory()->create($data);

$this->assertDatabaseHas(
(new OrderLine())->getTable(),
$data
);

$this->assertEquals(6.5, $orderLine->unit_price->decimal);
$this->assertEquals(6.5, $orderLine->unit_price->unitDecimal);
}
}
Loading