## 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
63 lines
3.2 KiB
PHP
63 lines
3.2 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use Tests\Support\TestLaneManifest;
|
|
use Tests\Support\TestLaneReport;
|
|
|
|
it('keeps profiling serial and artifact-rich for slow-test drift analysis', function (): void {
|
|
$lane = TestLaneManifest::lane('profiling');
|
|
$command = TestLaneManifest::buildCommand('profiling');
|
|
$configurationPath = TestLaneManifest::laneConfigurationPath('profiling');
|
|
$configurationContents = (string) file_get_contents(TestLaneManifest::absolutePath($configurationPath));
|
|
|
|
expect($lane['governanceClass'])->toBe('support')
|
|
->and($lane['parallelMode'])->toBe('forbidden')
|
|
->and($lane['artifacts'])->toContain('profile-top', 'junit-xml', 'summary', 'budget-report')
|
|
->and($command)->toContain('--profile')
|
|
->and($command)->not->toContain('--parallel')
|
|
->and($command)->toContain('--configuration='.$configurationPath)
|
|
->and($configurationContents)->toContain('tests/Feature/Filament/PolicyResourceAdminSearchParityTest.php')
|
|
->and($configurationContents)->not->toContain('tests/Browser/Spec190BaselineCompareMatrixSmokeTest.php');
|
|
});
|
|
|
|
it('builds top 10 attribution-rich profiling reports for mixed workflow and governance files', function (): void {
|
|
$durationsByFile = [
|
|
'tests/Feature/Baselines/BaselineCompareMatrixCompareAllActionTest.php' => 22.4,
|
|
'tests/Feature/Baselines/BaselineCompareMatrixBuilderTest.php' => 20.1,
|
|
'tests/Feature/Rbac/OnboardingWizardUiEnforcementTest.php' => 18.5,
|
|
'tests/Feature/Guards/ActionSurfaceContractTest.php' => 17.3,
|
|
'tests/Feature/Filament/PolicyResourceAdminSearchParityTest.php' => 16.2,
|
|
'tests/Feature/Filament/PolicyVersionAdminSearchParityTest.php' => 15.1,
|
|
'tests/Feature/Rbac/BackupItemsRelationManagerUiEnforcementTest.php' => 13.7,
|
|
'tests/Feature/Rbac/WorkspaceMembershipsRelationManagerUiEnforcementTest.php' => 12.8,
|
|
'tests/Feature/Filament/TenantReviewHeaderDisciplineTest.php' => 11.4,
|
|
'tests/Feature/Filament/BackupSetAdminTenantParityTest.php' => 9.6,
|
|
];
|
|
|
|
$slowestEntries = collect($durationsByFile)
|
|
->map(static fn (float $seconds, string $file): array => [
|
|
'label' => $file.'::synthetic',
|
|
'subject' => $file.'::synthetic',
|
|
'filePath' => $file,
|
|
'durationSeconds' => $seconds,
|
|
'wallClockSeconds' => $seconds,
|
|
'laneId' => 'profiling',
|
|
])
|
|
->values()
|
|
->all();
|
|
|
|
$report = TestLaneReport::buildReport(
|
|
laneId: 'profiling',
|
|
wallClockSeconds: 181.7,
|
|
slowestEntries: $slowestEntries,
|
|
durationsByFile: $durationsByFile,
|
|
);
|
|
|
|
expect($report['slowestEntries'])->toHaveCount(10)
|
|
->and($report['slowestEntries'][0]['wallClockSeconds'])->toBeGreaterThanOrEqual($report['slowestEntries'][1]['wallClockSeconds'])
|
|
->and(collect($report['classificationAttribution'])->pluck('classificationId')->all())
|
|
->toContain('ui-light', 'ui-workflow', 'surface-guard', 'discovery-heavy')
|
|
->and(collect($report['familyAttribution'])->pluck('familyId')->all())
|
|
->toContain('baseline-compare-matrix-workflow', 'action-surface-contract', 'backup-set-admin-tenant-parity');
|
|
}); |