TenantAtlas/apps/platform/tests/Feature/Retention/PruneBaselineEvidencePolicyVersionsTest.php
ahmido ce0615a9c1 Spec 182: relocate Laravel platform to apps/platform (#213)
## Summary
- move the Laravel application into `apps/platform` and keep the repository root for orchestration, docs, and tooling
- update the local command model, Sail/Docker wiring, runtime paths, and ignore rules around the new platform location
- add relocation quickstart/contracts plus focused smoke coverage for bootstrap, command model, routes, and runtime behavior

## Validation
- `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/PlatformRelocation`
- integrated browser smoke validated `/up`, `/`, `/admin`, `/admin/choose-workspace`, and tenant route semantics for `200`, `403`, and `404`

## Remaining Rollout Checks
- validate Dokploy build context and working-directory assumptions against the new `apps/platform` layout
- confirm web, queue, and scheduler processes all start from the expected working directory in staging/production
- verify no legacy volume mounts or asset-publish paths still point at the old root-level `public/` or `storage/` locations

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #213
2026-04-08 08:40:47 +00:00

69 lines
2.5 KiB
PHP

<?php
declare(strict_types=1);
use App\Models\BaselineProfile;
use App\Models\Policy;
use App\Models\PolicyVersion;
use App\Models\Tenant;
use App\Support\Baselines\PolicyVersionCapturePurpose;
use Illuminate\Foundation\Testing\RefreshDatabase;
uses(RefreshDatabase::class);
it('prunes baseline-purpose policy versions past retention but keeps backups', function (): void {
config()->set('tenantpilot.baselines.full_content_capture.retention_days', 30);
$tenant = Tenant::factory()->create();
$policy = Policy::factory()->create([
'tenant_id' => (int) $tenant->getKey(),
]);
$profile = BaselineProfile::factory()->active()->create([
'workspace_id' => (int) $tenant->workspace_id,
]);
$oldBaselineCompare = PolicyVersion::factory()->create([
'tenant_id' => (int) $tenant->getKey(),
'policy_id' => (int) $policy->getKey(),
'version_number' => 1,
'capture_purpose' => PolicyVersionCapturePurpose::BaselineCompare->value,
'baseline_profile_id' => (int) $profile->getKey(),
'captured_at' => now()->subDays(45),
]);
$oldBaselineCapture = PolicyVersion::factory()->create([
'tenant_id' => (int) $tenant->getKey(),
'policy_id' => (int) $policy->getKey(),
'version_number' => 2,
'capture_purpose' => PolicyVersionCapturePurpose::BaselineCapture->value,
'baseline_profile_id' => (int) $profile->getKey(),
'captured_at' => now()->subDays(45),
]);
$recentBaselineCompare = PolicyVersion::factory()->create([
'tenant_id' => (int) $tenant->getKey(),
'policy_id' => (int) $policy->getKey(),
'version_number' => 3,
'capture_purpose' => PolicyVersionCapturePurpose::BaselineCompare->value,
'baseline_profile_id' => (int) $profile->getKey(),
'captured_at' => now()->subDays(10),
]);
$oldBackup = PolicyVersion::factory()->create([
'tenant_id' => (int) $tenant->getKey(),
'policy_id' => (int) $policy->getKey(),
'version_number' => 4,
'capture_purpose' => PolicyVersionCapturePurpose::Backup->value,
'captured_at' => now()->subDays(45),
]);
$this->artisan('tenantpilot:baseline-evidence:prune')->assertExitCode(0);
expect($oldBaselineCompare->refresh()->trashed())->toBeTrue();
expect($oldBaselineCapture->refresh()->trashed())->toBeTrue();
expect($recentBaselineCompare->refresh()->trashed())->toBeFalse();
expect($oldBackup->refresh()->trashed())->toBeFalse();
});