Skip to content

Fix: OpenCode event ingestion compatibility (fixes hanging "working..." state with OpenCode Adapter)#2704

Open
eersnington wants to merge 1 commit into
pingdotgg:mainfrom
eersnington:fix/opencode-global-event-compatible
Open

Fix: OpenCode event ingestion compatibility (fixes hanging "working..." state with OpenCode Adapter)#2704
eersnington wants to merge 1 commit into
pingdotgg:mainfrom
eersnington:fix/opencode-global-event-compatible

Conversation

@eersnington
Copy link
Copy Markdown

@eersnington eersnington commented May 14, 2026

Heya, I started using T3 code 2 days ago with the Openchud integration and I was quite surprised at it not working at all. I've forked T3 code to fix a lot of issues and I'm using the local build for now, but this change would make OpenCode adapter from currently unusable to slightly above usable.

What Changed

  • use/global/event from Opencood for runtime event ingestion and filter wrapped events by session directory
  • ignore malformed global event payloads before provider event projection
  • fall back to legacy /event subscription when global events are unavailable (a lot of chaps within the issue thread below downgraded to <=0.14.40, so this fix would make it work for older sessions too)

Why

Fixes #2644

UI Changes

(sound on 👁️👃👁️🦻)

t3code.pr.1.mp4

Checklist

  • [yep] This PR is small and focused
  • [sí] I explained what changed and why
  • [oui oui] I included before/after screenshots for any UI changes
  • [ya po my Chile hombre] I included a video for animation/interaction changes

Note

Medium Risk
Changes OpenCode session event ingestion to prefer a new global event stream and adds fallback logic, which can affect turn completion and session lifecycle behavior if event formats or error detection differ across OpenCode versions.

Overview
Switches the OpenCode adapter’s event pump to prefer global.event (wrapped events) and projects provider runtime events only after filtering by session directory and validating the wrapped payload shape.

Adds compatibility fallback: if global.event is unavailable (e.g. 404 / TypeError), the adapter falls back to event.subscribe (now called with { directory }). Updates tests to cover global ingestion, directory filtering, malformed payload handling, and the fallback path.

Reviewed by Cursor Bugbot for commit bd4ac1a. Bugbot is set up for automated code reviews on this repo. Configure here.

Note

Fix hanging "waiting..." state in OpenCode adapter by preferring global.event stream over legacy event.subscribe

  • The event pump in OpenCodeAdapter.ts now first attempts to stream events from a global.event endpoint, filtering by context.directory to ignore events from other sessions and skipping malformed payloads.
  • Falls back to the legacy event.subscribe path (passing { directory } as a parameter) when global.event returns a 404 or a TypeError indicating the method is absent.
  • Both paths use a session-scoped AbortController that is cancelled on scope close.
  • Test coverage in OpenCodeAdapter.test.ts adds four new cases covering global events, directory filtering, malformed payload tolerance, and legacy fallback.

Macroscope summarized bd4ac1a.

@coderabbitai
Copy link
Copy Markdown

coderabbitai Bot commented May 14, 2026

Important

Review skipped

Auto reviews are disabled on this repository. Please check the settings in the CodeRabbit UI or the .coderabbit.yaml file in this repository. To trigger a single review, invoke the @coderabbitai review command.

⚙️ Run configuration

Configuration used: Repository UI

Review profile: CHILL

Plan: Pro

Run ID: 3257aff6-b5d0-448c-ae0c-8b1a639b1871

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

Use the checkbox below for a quick retry:

  • 🔍 Trigger review
✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests

Tip

💬 Introducing Slack Agent: The best way for teams to turn conversations into code.

Slack Agent is built on CodeRabbit's deep understanding of your code, so your team can collaborate across the entire SDLC without losing context.

  • Generate code and open pull requests
  • Plan features and break down work
  • Investigate incidents and troubleshoot customer tickets together
  • Automate recurring tasks and respond to alerts with triggers
  • Summarize progress and report instantly

Built for teams:

  • Shared memory across your entire org—no repeating context
  • Per-thread sandboxes to safely plan and execute work
  • Governance built-in—scoped access, auditability, and budget controls

One agent for your entire SDLC. Right inside Slack.

👉 Get started


Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@github-actions github-actions Bot added vouch:unvouched PR author is not yet trusted in the VOUCHED list. size:L 100-499 changed lines (additions + deletions). labels May 14, 2026
@eersnington
Copy link
Copy Markdown
Author

This PR might seem like a duplicate of #2673, and it kind of is, but 2673 removes the old event stream which would break and regress T3 code experience for users on Opencode versions that are lesser than <=0.14.40 (which relatively recent)

@macroscopeapp
Copy link
Copy Markdown
Contributor

macroscopeapp Bot commented May 14, 2026

Approvability

Verdict: Needs human review

This PR modifies runtime event ingestion behavior by introducing a new global event API with fallback to legacy subscription. While well-tested with comprehensive coverage, changes to event processing pipelines that affect session state tracking warrant human review.

You can customize Macroscope's approvability policy. Learn more.

@eersnington eersnington changed the title Fix: OpenCode event ingestion compatibility (fixes hanging "waiting..." state with OpenCode Adapter) Fix: OpenCode event ingestion compatibility (fixes hanging "working..." state with OpenCode Adapter) May 14, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:L 100-499 changed lines (additions + deletions). vouch:unvouched PR author is not yet trusted in the VOUCHED list.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Chat shows 'working...' indefinitely after opencode CLI already finished responding

1 participant