71 lines
2.3 KiB
PHP
71 lines
2.3 KiB
PHP
<?php
|
||
|
||
namespace Tests\Feature;
|
||
|
||
use App\Models\Admin;
|
||
use App\Models\Merchant;
|
||
use App\Models\PlatformOrder;
|
||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||
use Illuminate\Support\Arr;
|
||
use Tests\TestCase;
|
||
|
||
class AdminDashboardRecentPlatformOrdersRefundInconsistentShouldShowHintTest extends TestCase
|
||
{
|
||
use RefreshDatabase;
|
||
|
||
protected function loginAsPlatformAdmin(): void
|
||
{
|
||
$this->seed();
|
||
|
||
$this->post('/admin/login', [
|
||
'email' => 'platform.admin@demo.local',
|
||
'password' => 'Platform@123456',
|
||
])->assertRedirect('/admin');
|
||
}
|
||
|
||
public function test_dashboard_recent_platform_orders_refund_inconsistent_should_show_hint(): void
|
||
{
|
||
$this->loginAsPlatformAdmin();
|
||
|
||
$merchantId = (int) Merchant::query()->value('id');
|
||
$platformAdminId = (int) Admin::query()->where('email', 'platform.admin@demo.local')->value('id');
|
||
|
||
// 构造一条“已退款但退款总额不足(refund_total + tol < paid)”的订单
|
||
// tol 默认 0.01,因此 paid=9, refund_total=8 => 必定不一致。
|
||
$order = PlatformOrder::query()->create([
|
||
'merchant_id' => $merchantId,
|
||
'plan_id' => null,
|
||
'site_subscription_id' => null,
|
||
'created_by_admin_id' => $platformAdminId ?: null,
|
||
'order_no' => 'PO_DASH_REFUND_INCONSIST_0001',
|
||
'order_type' => 'new_purchase',
|
||
'status' => 'pending',
|
||
'payment_status' => 'refunded',
|
||
'payable_amount' => 9,
|
||
'paid_amount' => 9,
|
||
'meta' => [
|
||
'refund_summary' => [
|
||
'total_amount' => 8,
|
||
],
|
||
],
|
||
]);
|
||
|
||
$this->assertTrue($order->isRefundInconsistent(), '预期测试订单应命中 isRefundInconsistent()');
|
||
|
||
$res = $this->get('/admin');
|
||
$res->assertOk();
|
||
|
||
$res->assertSee('PO_DASH_REFUND_INCONSIST_0001');
|
||
$res->assertSee('退款不一致', false);
|
||
|
||
$url = '/admin/platform-orders?' . Arr::query([
|
||
'refund_inconsistent' => '1',
|
||
'back' => '/admin',
|
||
]);
|
||
$res->assertSee($url, false);
|
||
|
||
// 不应出现 &back=,避免回跳断链
|
||
$res->assertDontSee('&back=', false);
|
||
}
|
||
}
|