Improve package usage visibility
Some checks failed
linter / quality (push) Has been cancelled
tests / ci (push) Has been cancelled
tests / ui (push) Has been cancelled

This commit is contained in:
Codex Agent
2026-01-06 14:17:27 +01:00
parent ef1773d966
commit 232302eb6f
12 changed files with 370 additions and 31 deletions

View File

@@ -3,14 +3,19 @@
namespace Tests\Feature\Tenant;
use App\Http\Controllers\Api\TenantPackageController;
use App\Models\Event;
use App\Models\EventPackage;
use App\Models\Package;
use App\Models\TenantPackage;
use Illuminate\Http\Request;
use Illuminate\Support\Carbon;
class TenantPackageOverviewTest extends TenantTestCase
{
public function test_active_package_contains_limits_and_features(): void
{
Carbon::setTestNow(Carbon::parse('2024-01-01 10:00:00'));
$package = Package::factory()->reseller()->create([
'max_photos' => 1500,
'max_guests' => 250,
@@ -29,6 +34,20 @@ class TenantPackageOverviewTest extends TenantTestCase
'used_events' => 3,
]);
$event = Event::factory()->create([
'tenant_id' => $this->tenant->id,
]);
EventPackage::create([
'event_id' => $event->id,
'package_id' => $package->id,
'purchased_price' => 199.00,
'purchased_at' => now()->subDay(),
'used_photos' => 700,
'used_guests' => 120,
'gallery_expires_at' => now()->addDays(20),
]);
$request = Request::create('/api/v1/tenant/packages', 'GET');
$request->attributes->set('tenant', $this->tenant);
@@ -43,6 +62,12 @@ class TenantPackageOverviewTest extends TenantTestCase
$this->assertTrue($payload['active_package']['package_limits']['branding_allowed']);
$this->assertFalse($payload['active_package']['package_limits']['watermark_allowed']);
$this->assertSame(['custom_branding', 'reseller_dashboard'], $payload['active_package']['package_limits']['features']);
$this->assertSame(700, $payload['active_package']['package_limits']['used_photos']);
$this->assertSame(800, $payload['active_package']['package_limits']['remaining_photos']);
$this->assertSame(120, $payload['active_package']['package_limits']['used_guests']);
$this->assertSame(130, $payload['active_package']['package_limits']['remaining_guests']);
$this->assertSame(20, $payload['active_package']['package_limits']['remaining_gallery_days']);
$this->assertSame(10, $payload['active_package']['package_limits']['used_gallery_days']);
$this->assertSame(9, $payload['active_package']['remaining_events']);
}
}