TenantAtlas/apps/platform/tests/Unit/Support/TestLaneBudgetTest.php
ahmido 0d5d1fc9f4 Spec 208: finalize heavy suite segmentation (#241)
## Summary
- add the checked-in Spec 208 heavy-suite classification and family manifest with config-driven lane generation, attribution, and budget reporting
- update Pest grouping, guard coverage, wrapper/report contracts, and spec artifacts for the segmented lane model
- complete the targeted follow-up pass that re-homes the remaining in-scope confidence hotspots into explicit heavy-governance families

## Acceptance
- confidence is repaired and now measures 389.613832s, down from 587.446894s and below the 450s lane budget
- confidence is also slightly below the post-Spec-207 baseline of 394.383441s (delta -4.769609s)
- this closes the central Spec 208 acceptance issue that had kept the spec open

## Intentionally Re-homed Families
- finding-bulk-actions-workflow
- drift-bulk-triage-all-matching
- baseline-profile-start-surfaces
- workspace-settings-slice-management
- findings-workflow-surfaces
- workspace-only-admin-surface-independence

## Explicit Residual Risk
- heavy-governance now measures 318.296962s, above its documented 300s threshold
- the cost was not removed; it was moved into the correct lane and made visible on clearly named heavy families
- this is documented residual debt, not an open Spec 208 failure

## Validation
- focused guard/support validation: 206 passed (3607 assertions)
- lane wrapper/report validation completed for confidence and heavy-governance
- no full-suite run was performed in this pass by request

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #241
2026-04-17 09:53:55 +00:00

57 lines
1.7 KiB
PHP

<?php
declare(strict_types=1);
use Tests\Support\TestLaneBudget;
use Tests\Support\TestLaneManifest;
it('evaluates lane budgets into within-budget, warning, and over-budget states', function (): void {
$warnBudget = TestLaneBudget::fromArray([
'thresholdSeconds' => 30,
'baselineSource' => 'measured-current-suite',
'enforcement' => 'warn',
'lifecycleState' => 'documented',
]);
$hardFailBudget = TestLaneBudget::fromArray([
'thresholdSeconds' => 30,
'baselineSource' => 'measured-current-suite',
'enforcement' => 'hard-fail',
'lifecycleState' => 'documented',
]);
expect($warnBudget->evaluate(24.5)['budgetStatus'])->toBe('within-budget')
->and($warnBudget->evaluate(31.2)['budgetStatus'])->toBe('warning')
->and($hardFailBudget->evaluate(31.2)['budgetStatus'])->toBe('over-budget');
});
it('evaluates family targets through the generic budget target path', function (): void {
$familyTargets = array_values(array_filter(
TestLaneManifest::budgetTargets(),
static fn (array $target): bool => $target['targetType'] === 'family',
));
$evaluations = TestLaneBudget::evaluateBudgetTargets(
$familyTargets,
0.0,
[],
[
'ops-ux-governance' => 18.4,
'action-surface-contract' => 7.8,
'browser-smoke' => 14.2,
],
);
expect($evaluations)->not->toBeEmpty()
->and($evaluations[0])->toHaveKeys([
'budgetId',
'targetType',
'targetId',
'thresholdSeconds',
'baselineSource',
'enforcement',
'lifecycleState',
'measuredSeconds',
'budgetStatus',
]);
});