8cb0531959
* fix(lint): organize imports in queen_orchestrator.create_queen Ruff I001 blocks CI on every PR against main. The deferred imports inside create_queen were not in alphabetical order between the queen package and the framework package; ruff auto-fix moves framework.config below the framework.agents.queen.nodes block. No behavior change. * fix(ci): install Playwright Chromium before Test Tools job The new chart_tools smoke tests added infeabf327require a Chromium build for ECharts/Mermaid rendering, but the test-tools workflow only ran `uv sync` and went straight to pytest. Three tests (test_render_echarts_bar_chart, test_render_echarts_accepts_string_spec, test_render_mermaid_flowchart) crash on every PR with: BrowserType.launch: Executable doesn't exist at /home/runner/.cache/ms-playwright/chromium_headless_shell-1208/... Split the install/run into separate steps and add `playwright install chromium` before pytest. Use `--with-deps` on Linux to pull system libraries; Windows runners only need the browser binary. * fix(tests): adapt test_file_state_cache to new file_ops API The file_ops rewrite infeabf327dropped the standalone hashline_edit tool (the file_system_toolkits/hashline_edit/ directory was removed) and switched edit_file to a mode-first signature (mode, path, old_string, new_string, ...). The test fixture still tried to look up "hashline_edit" via the MCP tool manager and crashed with KeyError before any test could run, and the edit_file calls were positional in the old order so they hit "unknown mode 'e.py'" once the fixture was fixed. Drop the stale hashline_edit lookup and pass mode="replace" explicitly to every edit_file call. All 11 tests pass locally. * fix(tests): skip terminal_tools tests on Windows (POSIX-only) The new terminal_tools package added infeabf327imports the Unix-only `resource` module in tools/src/terminal_tools/common/limits.py to set RLIMIT_CPU / RLIMIT_AS / RLIMIT_FSIZE on subprocesses. Five of the six terminal_tools test files therefore crash on windows-latest with `ModuleNotFoundError: No module named 'resource'` once their fixtures trigger the import chain. test_terminal_tools_pty.py already has the right module-level skip (PTY is POSIX-only). Apply the same `pytestmark = skipif(win32)` to the other five so the whole suite skips cleanly on Windows. The terminal-tools package is bash-only by design (zsh refused at the shell-resolver level), so a Windows port is out of scope.
158 lines
3.8 KiB
YAML
158 lines
3.8 KiB
YAML
name: CI
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
pull_request:
|
|
branches: [main]
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
lint:
|
|
name: Lint Python
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Setup Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: '3.11'
|
|
|
|
- name: Install uv
|
|
uses: astral-sh/setup-uv@v4
|
|
with:
|
|
enable-cache: true
|
|
|
|
- name: Install dependencies
|
|
run: uv sync --project core --group dev
|
|
|
|
- name: Ruff lint
|
|
run: |
|
|
uv run --project core ruff check core/
|
|
uv run --project core ruff check tools/
|
|
|
|
- name: Ruff format
|
|
run: |
|
|
uv run --project core ruff format --check core/
|
|
uv run --project core ruff format --check tools/
|
|
|
|
test:
|
|
name: Test Python Framework
|
|
runs-on: ${{ matrix.os }}
|
|
strategy:
|
|
matrix:
|
|
os: [ubuntu-latest, windows-latest]
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Setup Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: '3.11'
|
|
|
|
- name: Install uv
|
|
uses: astral-sh/setup-uv@v4
|
|
with:
|
|
enable-cache: true
|
|
|
|
- name: Install dependencies and run tests
|
|
working-directory: core
|
|
run: |
|
|
uv sync
|
|
uv run pytest tests/ -v --ignore=tests/dummy_agents
|
|
|
|
test-tools:
|
|
name: Test Tools (${{ matrix.os }})
|
|
runs-on: ${{ matrix.os }}
|
|
strategy:
|
|
matrix:
|
|
os: [ubuntu-latest, windows-latest]
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Setup Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: '3.11'
|
|
|
|
- name: Install uv
|
|
uses: astral-sh/setup-uv@v4
|
|
with:
|
|
enable-cache: true
|
|
|
|
- name: Install dependencies
|
|
working-directory: tools
|
|
run: uv sync --extra dev
|
|
|
|
- name: Install Playwright Chromium (Linux)
|
|
if: runner.os == 'Linux'
|
|
working-directory: tools
|
|
run: uv run playwright install --with-deps chromium
|
|
|
|
- name: Install Playwright Chromium (Windows)
|
|
if: runner.os == 'Windows'
|
|
working-directory: tools
|
|
run: uv run playwright install chromium
|
|
|
|
- name: Run tests
|
|
working-directory: tools
|
|
run: uv run pytest tests/ -v
|
|
|
|
validate:
|
|
name: Validate Agent Exports
|
|
runs-on: ubuntu-latest
|
|
needs: [lint, test, test-tools]
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Setup Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: '3.11'
|
|
|
|
- name: Install uv
|
|
uses: astral-sh/setup-uv@v4
|
|
with:
|
|
enable-cache: true
|
|
|
|
- name: Install dependencies
|
|
working-directory: core
|
|
run: |
|
|
uv sync
|
|
|
|
- name: Validate exported agents
|
|
run: |
|
|
# Check that agent exports have valid structure
|
|
if [ ! -d "exports" ]; then
|
|
echo "No exports/ directory found, skipping validation"
|
|
exit 0
|
|
fi
|
|
|
|
shopt -s nullglob
|
|
agent_dirs=(exports/*/)
|
|
shopt -u nullglob
|
|
|
|
if [ ${#agent_dirs[@]} -eq 0 ]; then
|
|
echo "No agent directories in exports/, skipping validation"
|
|
exit 0
|
|
fi
|
|
|
|
validated=0
|
|
for agent_dir in "${agent_dirs[@]}"; do
|
|
if [ -f "$agent_dir/agent.json" ]; then
|
|
echo "Validating $agent_dir"
|
|
uv run python -c "import json; json.load(open('$agent_dir/agent.json'))"
|
|
validated=$((validated + 1))
|
|
fi
|
|
done
|
|
|
|
if [ "$validated" -eq 0 ]; then
|
|
echo "No agent.json files found in exports/, skipping validation"
|
|
else
|
|
echo "Validated $validated agent(s)"
|
|
fi
|