## 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
72 lines
4.6 KiB
PHP
72 lines
4.6 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use Tests\Support\TestLaneManifest;
|
|
|
|
it('keeps composer lane commands wired to the checked-in lane inventory', function (): void {
|
|
$composer = json_decode((string) file_get_contents(base_path('composer.json')), true, 512, JSON_THROW_ON_ERROR);
|
|
$scripts = $composer['scripts'] ?? [];
|
|
|
|
expect($scripts)->toHaveKeys([
|
|
'test',
|
|
'test:fast',
|
|
'test:confidence',
|
|
'test:browser',
|
|
'test:heavy',
|
|
'test:profile',
|
|
'test:junit',
|
|
'test:report',
|
|
'test:report:confidence',
|
|
'test:report:browser',
|
|
'test:report:heavy',
|
|
'test:report:profile',
|
|
'sail:test',
|
|
])
|
|
->and(TestLaneManifest::commandRef('fast-feedback'))->toBe('test')
|
|
->and(TestLaneManifest::commandRef('confidence'))->toBe('test:confidence')
|
|
->and(TestLaneManifest::commandRef('browser'))->toBe('test:browser')
|
|
->and(TestLaneManifest::commandRef('heavy-governance'))->toBe('test:heavy')
|
|
->and(TestLaneManifest::commandRef('profiling'))->toBe('test:profile')
|
|
->and(TestLaneManifest::commandRef('junit'))->toBe('test:junit');
|
|
});
|
|
|
|
it('keeps the host-side lane runner and report scripts checked in at repo root', function (): void {
|
|
expect(file_exists(repo_path('scripts/platform-test-lane')))->toBeTrue()
|
|
->and(file_exists(repo_path('scripts/platform-test-report')))->toBeTrue();
|
|
});
|
|
|
|
it('routes the foundational lane commands through stable artisan arguments', function (): void {
|
|
$fastFeedbackConfig = TestLaneManifest::laneConfigurationPath('fast-feedback');
|
|
$fastFeedbackContents = (string) file_get_contents(TestLaneManifest::absolutePath($fastFeedbackConfig));
|
|
$confidenceConfig = TestLaneManifest::laneConfigurationPath('confidence');
|
|
$confidenceContents = (string) file_get_contents(TestLaneManifest::absolutePath($confidenceConfig));
|
|
$browserConfig = TestLaneManifest::laneConfigurationPath('browser');
|
|
$browserContents = (string) file_get_contents(TestLaneManifest::absolutePath($browserConfig));
|
|
$heavyConfig = TestLaneManifest::laneConfigurationPath('heavy-governance');
|
|
$heavyContents = (string) file_get_contents(TestLaneManifest::absolutePath($heavyConfig));
|
|
|
|
expect(TestLaneManifest::buildCommand('fast-feedback'))->toContain('--parallel')
|
|
->and(TestLaneManifest::buildCommand('fast-feedback'))->toContain('--configuration='.$fastFeedbackConfig)
|
|
->and($fastFeedbackContents)->not->toContain('tests/Feature/Drift/DriftBulkAcknowledgeAllMatchingConfirmationTest.php')
|
|
->and($fastFeedbackContents)->not->toContain('tests/Feature/Findings/FindingBulkActionsTest.php')
|
|
->and($fastFeedbackContents)->not->toContain('tests/Feature/Guards/ActionSurfaceContractTest.php')
|
|
->and(TestLaneManifest::buildCommand('confidence'))->toContain('--configuration='.$confidenceConfig)
|
|
->and($confidenceContents)->toContain('tests/Feature/Baselines/BaselineCompareMatrixCompareAllActionTest.php')
|
|
->and($confidenceContents)->not->toContain('tests/Feature/Drift/DriftBulkAcknowledgeAllMatchingConfirmationTest.php')
|
|
->and($confidenceContents)->not->toContain('tests/Feature/Filament/BaselineActionAuthorizationTest.php')
|
|
->and($confidenceContents)->not->toContain('tests/Feature/Filament/BaselineProfileCaptureStartSurfaceTest.php')
|
|
->and($confidenceContents)->not->toContain('tests/Feature/Filament/BaselineProfileCompareStartSurfaceTest.php')
|
|
->and($confidenceContents)->not->toContain('tests/Feature/Findings/FindingBulkActionsTest.php')
|
|
->and($confidenceContents)->not->toContain('tests/Feature/Guards/ActionSurfaceContractTest.php')
|
|
->and(TestLaneManifest::buildCommand('browser'))->toContain('--configuration='.$browserConfig)
|
|
->and($browserContents)->toContain('tests/Browser/Spec190BaselineCompareMatrixSmokeTest.php')
|
|
->and(TestLaneManifest::buildCommand('heavy-governance'))->toContain('--configuration='.$heavyConfig)
|
|
->and($heavyContents)->toContain('tests/Feature/Drift/DriftBulkAcknowledgeAllMatchingConfirmationTest.php')
|
|
->and($heavyContents)->toContain('tests/Feature/Filament/BaselineActionAuthorizationTest.php')
|
|
->and($heavyContents)->toContain('tests/Feature/Filament/BaselineProfileCaptureStartSurfaceTest.php')
|
|
->and($heavyContents)->toContain('tests/Feature/Filament/BaselineProfileCompareStartSurfaceTest.php')
|
|
->and($heavyContents)->toContain('tests/Feature/Findings/FindingBulkActionsTest.php')
|
|
->and($heavyContents)->toContain('tests/Feature/Guards/ActionSurfaceContractTest.php')
|
|
->and(TestLaneManifest::buildCommand('junit'))->toContain('--parallel');
|
|
}); |