TenantAtlas/apps/platform/tests/Unit/Support/CanonicalNavigationContextTest.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

55 lines
1.7 KiB
PHP

<?php
declare(strict_types=1);
use App\Support\Navigation\CanonicalNavigationContext;
use Illuminate\Http\Request;
it('serializes canonical navigation query data', function (): void {
$context = new CanonicalNavigationContext(
sourceSurface: 'finding.detail_section',
canonicalRouteName: 'admin.operations.view',
tenantId: 44,
backLinkLabel: 'Back to finding',
backLinkUrl: '/admin/findings/12',
filterPayload: [
'tableFilters' => [
'tenant_id' => ['value' => '44'],
],
],
);
expect($context->toQuery())
->toMatchArray([
'tableFilters' => [
'tenant_id' => ['value' => '44'],
],
'nav' => [
'source_surface' => 'finding.detail_section',
'canonical_route_name' => 'admin.operations.view',
'tenant_id' => 44,
'back_label' => 'Back to finding',
'back_url' => '/admin/findings/12',
],
]);
});
it('round trips from a request payload', function (): void {
$request = Request::create('/admin/operations/12', 'GET', [
'nav' => [
'source_surface' => 'backup_set.detail_section',
'canonical_route_name' => 'admin.operations.view',
'tenant_id' => 22,
'back_label' => 'Back to backup set',
'back_url' => '/admin/backup-sets/8',
],
]);
$context = CanonicalNavigationContext::fromRequest($request);
expect($context)->not->toBeNull()
->and($context?->tenantId)->toBe(22)
->and($context?->backLinkLabel)->toBe('Back to backup set')
->and($context?->backLinkUrl)->toBe('/admin/backup-sets/8');
});