fix(acp): prepend $HOME/.local/bin to agent subprocess PATH #988
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Docker Smoke Test | |
| on: | |
| pull_request: | |
| paths: | |
| - 'Dockerfile*' | |
| - 'src/**' | |
| - 'Cargo.*' | |
| jobs: | |
| smoke-test: | |
| strategy: | |
| fail-fast: false | |
| matrix: | |
| variant: | |
| - { dockerfile: Dockerfile, suffix: "", agent: "kiro-cli", agent_args: "acp --trust-all-tools" } | |
| - { dockerfile: Dockerfile.claude, suffix: "-claude", agent: "claude-agent-acp", agent_args: "" } | |
| - { dockerfile: Dockerfile.codex, suffix: "-codex", agent: "codex-acp", agent_args: "" } | |
| - { dockerfile: Dockerfile.gemini, suffix: "-gemini", agent: "gemini", agent_args: "--acp" } | |
| - { dockerfile: Dockerfile.copilot, suffix: "-copilot", agent: "copilot", agent_args: "--acp" } | |
| - { dockerfile: Dockerfile.opencode, suffix: "-opencode", agent: "opencode", agent_args: "acp" } | |
| - { dockerfile: Dockerfile.cursor, suffix: "-cursor", agent: "cursor-agent", agent_args: "acp" } | |
| - { dockerfile: Dockerfile.hermes, suffix: "-hermes", agent: "hermes-acp", agent_args: "" } | |
| - { dockerfile: Dockerfile.grok, suffix: "-grok", agent: "grok", agent_args: "agent stdio" } | |
| - { dockerfile: Dockerfile.antigravity, suffix: "-antigravity", agent: "agy-acp", agent_args: "" } | |
| - { dockerfile: Dockerfile.pi, suffix: "-pi", agent: "pi-acp", agent_args: "" } | |
| - { dockerfile: openshell/Dockerfile, suffix: "-native-sandbox", agent: "openab-agent", agent_args: "" } | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v6 | |
| - name: Build image | |
| run: docker build -t openab-test${{ matrix.variant.suffix }} -f ${{ matrix.variant.dockerfile }} . | |
| - name: Verify openab CMD does not crash | |
| run: | | |
| OUTPUT=$(docker run --rm openab-test${{ matrix.variant.suffix }} 2>&1 || true) | |
| if echo "$OUTPUT" | grep -q "unrecognized subcommand"; then | |
| echo "❌ CMD regression: $OUTPUT" | |
| exit 1 | |
| fi | |
| echo "✅ openab CMD ok" | |
| - name: Verify agent CLI exists | |
| run: docker run --rm --entrypoint which openab-test${{ matrix.variant.suffix }} ${{ matrix.variant.agent }} | |
| - name: Verify agent responds | |
| run: | | |
| INIT='{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2025-03-26","clientCapabilities":{},"clientInfo":{"name":"ci-test","version":"0.0.1"}}}' | |
| # Start agent in background, send init, capture output with timeout | |
| CID=$(docker run -d -i --entrypoint sh openab-test${{ matrix.variant.suffix }} -c 'exec ${{ matrix.variant.agent }} ${{ matrix.variant.agent_args }} 2>/dev/null') | |
| echo "$INIT" | docker attach --no-stdin=false "$CID" & | |
| sleep 5 | |
| RESPONSE=$(docker logs "$CID" 2>/dev/null | grep -m1 '^{' || true) | |
| docker rm -f "$CID" >/dev/null 2>&1 | |
| echo "Response: $RESPONSE" | |
| if [ -n "$RESPONSE" ] && echo "$RESPONSE" | jq -e '.result.agentInfo.name' > /dev/null 2>&1; then | |
| AGENT_NAME=$(echo "$RESPONSE" | jq -r '.result.agentInfo.name') | |
| echo "✅ ACP handshake ok — agent=$AGENT_NAME" | |
| else | |
| echo "⚠️ ACP handshake returned no response — falling back to CLI check" | |
| docker run --rm --entrypoint ${{ matrix.variant.agent }} \ | |
| openab-test${{ matrix.variant.suffix }} --help >/dev/null 2>&1 | |
| echo "✅ Agent CLI responds (ACP skipped — likely needs auth)" | |
| fi |