test: cover process bootstrap exit diagnostics

This commit is contained in:
777genius 2026-05-19 20:38:32 +03:00
parent 0f5b819aed
commit 5fcefb9b07
2 changed files with 74 additions and 0 deletions

View file

@ -141,6 +141,56 @@ describe('ProcessBootstrapTransportEvidence', () => {
);
});
it('treats runtime failure after mailbox write as terminal without marking bootstrap submitted', () => {
const summary = summarizeProcessBootstrapTransportEvents([
{
type: 'mailbox_bootstrap_written',
timestamp: '2026-05-07T10:00:00.000Z',
detail: 'messageId=bootstrap-1',
},
{
type: 'failed',
timestamp: '2026-05-07T10:00:01.000Z',
detail: 'teammate process exited before inbox_poller_ready',
},
]);
expect(summary).toMatchObject({
submitted: false,
hasProgress: true,
lastStage: 'runtime failed: teammate process exited before inbox_poller_ready',
terminalFailure: {
kind: 'runtime_failed_before_confirmation',
reason: 'runtime failed: teammate process exited before inbox_poller_ready',
},
});
});
it('treats process exit after submit attempt as terminal without durable submit proof', () => {
const summary = summarizeProcessBootstrapTransportEvents([
{
type: 'bootstrap_submit_attempted',
timestamp: '2026-05-07T10:00:00.000Z',
detail: 'submitting bootstrap prompt',
},
{
type: 'exited',
timestamp: '2026-05-07T10:00:01.000Z',
detail: 'process exited before bootstrap_submitted',
},
]);
expect(summary).toMatchObject({
submitted: false,
hasProgress: true,
lastStage: 'runtime exited: process exited before bootstrap_submitted',
terminalFailure: {
kind: 'process_exited_before_confirmation',
reason: 'runtime exited: process exited before bootstrap_submitted',
},
});
});
it('distinguishes submitted bootstrap prompts from not-submitted transport timeouts', () => {
const summary = summarizeProcessBootstrapTransportEvents([
{

View file

@ -241,6 +241,30 @@ describe('TeamLaunchFailureArtifactPack', () => {
});
});
it('keeps process exits after bootstrap transport evidence out of stdin_missing classification', () => {
const input = {
teamName: 'artifact-team',
runId: 'run-submit-attempt-process-exit',
reason:
'alice: Teammate process alice@signal-ops did not submit bootstrap prompt: teammate process exited before bootstrap_submitted; last transport stage: bootstrap_submit_attempted: submitting bootstrap prompt Last stderr: Warning: no stdin data received in 3s, proceeding without it.',
progressTraceLines: [
'mailbox_bootstrap_written detail=messageId=bootstrap-alice-1',
'bootstrap_submit_attempted detail=submitting bootstrap prompt',
'process exited before bootstrap_submitted',
'Warning: no stdin data received in 3s, proceeding without it.',
],
};
expect(classifyLaunchFailureArtifact(input).code).toBe('model_no_bootstrap');
expect(extractLaunchBootstrapTransportBreadcrumb(input)).toMatchObject({
lastTransportStage: expect.stringContaining(
'bootstrap_submit_attempted: submitting bootstrap prompt'
),
noStdinWarning: true,
bootstrapSubmitted: false,
});
});
it('classifies provider quota separately from protocol errors', () => {
expect(
classifyLaunchFailureArtifact({