## 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
57 lines
1.7 KiB
PHP
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',
|
|
]);
|
|
}); |