Skip to content

fix(opencode): no response handling#29966

Open
SoShymKing wants to merge 7 commits into
anomalyco:devfrom
SoShymKing:robust-no-response-handling
Open

fix(opencode): no response handling#29966
SoShymKing wants to merge 7 commits into
anomalyco:devfrom
SoShymKing:robust-no-response-handling

Conversation

@SoShymKing
Copy link
Copy Markdown

@SoShymKing SoShymKing commented May 30, 2026

Issue for this PR

Fixes #17717
Addresses the bug described in #17717.
This is a template-compliant follow-up to #17719, which attempted the same fix but was automatically closed for not using the required PR template.

Type of change

  • Bug fix
  • New feature
  • Refactor / code improvement
  • Documentation

What does this PR do?

This addresses the unexpected abort and no-response behavior reported in #17717 and previously attempted in #17719.

When the model or provider raises an abort while the session itself has not been cancelled, OpenCode now treats that case as a transient provider/client-side abort rather than a user cancellation.
These errors are routed through the existing retry and backoff path, while explicit user or session cancellations still terminate immediately without retrying.

The change also improves handling for stalled post-tool continuations and empty assistant streams.
OpenCode now detects post-tool continuation failures after completed tool calls, converts no-response cases into typed errors with diagnostics, and retries blank or structural-only assistant turns instead of persisting them as successful empty responses.

How did you verify your code works?

Ran from 'packages/opencode':
'''bash
bun test test/session/retry.test.ts test/session/message-v2.test.ts test/session/processor-effect.test.ts
bun typecheck
'''

Screenshots / recordings

If this is a UI change, please include a screenshot or recording.

Checklist

  • I have tested my changes locally
  • I have not included unrelated changes in this PR

If you do not follow this template your PR will be automatically rejected.

@github-actions
Copy link
Copy Markdown
Contributor

Thanks for your contribution!

This PR doesn't have a linked issue. All PRs must reference an existing issue.

Please:

  1. Open an issue describing the bug/feature (if one doesn't exist)
  2. Add Fixes #<number> or Closes #<number> to this PR description

See CONTRIBUTING.md for details.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Retry unexpected MessageAbortedError instead of stopping the session

1 participant