## 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
50 lines
1.7 KiB
PHP
50 lines
1.7 KiB
PHP
<?php
|
|
|
|
use App\Support\Baselines\BaselineScope;
|
|
|
|
it('expands empty policy_types to supported policy types (excluding foundations) and defaults foundation_types to none', function () {
|
|
config()->set('tenantpilot.supported_policy_types', [
|
|
['type' => 'deviceConfiguration', 'label' => 'Device Configuration'],
|
|
['type' => 'deviceCompliancePolicy', 'label' => 'Device Compliance'],
|
|
]);
|
|
|
|
config()->set('tenantpilot.foundation_types', [
|
|
['type' => 'assignmentFilter', 'label' => 'Assignment Filter', 'baseline_compare' => ['supported' => true]],
|
|
]);
|
|
|
|
$scope = BaselineScope::fromJsonb([
|
|
'policy_types' => [],
|
|
'foundation_types' => [],
|
|
])->expandDefaults();
|
|
|
|
expect($scope->policyTypes)->toBe([
|
|
'deviceCompliancePolicy',
|
|
'deviceConfiguration',
|
|
]);
|
|
|
|
expect($scope->foundationTypes)->toBe([]);
|
|
expect($scope->allTypes())->toBe([
|
|
'deviceCompliancePolicy',
|
|
'deviceConfiguration',
|
|
]);
|
|
});
|
|
|
|
it('filters unknown types and does not allow foundations inside policy_types', function () {
|
|
config()->set('tenantpilot.supported_policy_types', [
|
|
['type' => 'deviceConfiguration'],
|
|
]);
|
|
|
|
config()->set('tenantpilot.foundation_types', [
|
|
['type' => 'assignmentFilter', 'baseline_compare' => ['supported' => true]],
|
|
]);
|
|
|
|
$scope = BaselineScope::fromJsonb([
|
|
'policy_types' => ['deviceConfiguration', 'assignmentFilter', 'unknown'],
|
|
'foundation_types' => ['assignmentFilter', 'unknown'],
|
|
])->expandDefaults();
|
|
|
|
expect($scope->policyTypes)->toBe(['deviceConfiguration']);
|
|
expect($scope->foundationTypes)->toBe(['assignmentFilter']);
|
|
expect($scope->allTypes())->toBe(['assignmentFilter', 'deviceConfiguration']);
|
|
});
|