Skip to content

Call CBM ContextBench candidate extractor from script #3

Call CBM ContextBench candidate extractor from script

Call CBM ContextBench candidate extractor from script #3

name: ContextBench CBM Candidates One
on:
push:
branches: [master]
paths:
- .github/workflows/contextbench-cbm-candidates-one.yml
- scripts/contextbench-cbm-candidate-pack.mjs
workflow_dispatch:
permissions:
contents: read
jobs:
cbm-candidates:
runs-on: ubuntu-latest
timeout-minutes: 20
env:
ROOT: /tmp/contextbench-cbm-candidates-one
TASK_PAYLOADS: /tmp/contextbench-cbm-candidates-one/task-payloads.json
CHECKOUT_ROOT: /tmp/contextbench-checkouts
CBM_BIN: /tmp/contextbench-cbm-candidates-one/tool/codebase-memory-mcp
steps:
- uses: actions/checkout@v4
- uses: pnpm/action-setup@v2
with:
version: 10
- uses: actions/setup-node@v4
with:
node-version: '24'
cache: pnpm
- uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install and materialize Go task quietly
shell: bash
run: |
set -euo pipefail
mkdir -p "$ROOT" "$CHECKOUT_ROOT" "$ROOT/tool" "$ROOT/pack" "$ROOT/logs"
pnpm install --frozen-lockfile > "$ROOT/logs/pnpm-install.log" 2>&1
python -m pip install "tree-sitter==0.20.4" "tree-sitter-languages==1.10.2" datasets pyarrow > "$ROOT/logs/pip-install.log" 2>&1
curl -fsSL "https://github.com/DeusData/codebase-memory-mcp/releases/download/v0.6.1/codebase-memory-mcp-linux-amd64.tar.gz" -o "$ROOT/tool/cbm.tar.gz"
tar -xzf "$ROOT/tool/cbm.tar.gz" -C "$ROOT/tool" > "$ROOT/logs/cbm-extract.log" 2>&1
chmod +x "$CBM_BIN" || true
git clone --depth 1 https://github.com/EuniAI/ContextBench.git "$ROOT/ContextBench-official" > "$ROOT/logs/contextbench-clone.log" 2>&1
node scripts/contextbench-runner.mjs --validate-fixtures > "$ROOT/logs/validate-fixtures.log" 2>&1
node scripts/contextbench-select-slice.mjs --write-task-payloads --out "$TASK_PAYLOADS" --checkout-root "$CHECKOUT_ROOT" > "$ROOT/logs/write-payloads.log" 2>&1
node scripts/contextbench-select-slice.mjs --materialize-checkouts --payloads "$TASK_PAYLOADS" --max-tasks 3 > "$ROOT/logs/materialize.log" 2>&1
echo "quiet_setup_completed"
- name: Print compact CBM candidates
shell: bash
run: node scripts/contextbench-cbm-candidate-pack.mjs
- name: Upload CBM candidate pack
if: always()
uses: actions/upload-artifact@v4
with:
name: contextbench-cbm-candidates-one
path: /tmp/contextbench-cbm-candidates-one/pack
retention-days: 14