Skip to content

Commit

Permalink
CI: Add very simple CI
Browse files Browse the repository at this point in the history
  • Loading branch information
klieret committed Jun 28, 2024
1 parent 68d8059 commit e0a7f5b
Show file tree
Hide file tree
Showing 2 changed files with 70 additions and 0 deletions.
57 changes: 57 additions & 0 deletions .github/workflows/pytest.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@

name: Pytest

env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

on:
push:
branches:
- main
- "test-ci/**"
paths-ignore:
- 'docs/**'
- 'README.md'
- 'mkdocs.yml'
pull_request:
branches:
- main
paths-ignore:
- 'docs/**'
- 'README.md'
- 'mkdocs.yml'

# Not possible to test windows capability:
# https://github.com/orgs/community/discussions/25491
jobs:
test:
runs-on: ubuntu-latest
defaults:
run:
shell: bash -l {0}
steps:
- name: Checkout code
uses: actions/checkout@v2
- uses: actions/setup-python@v5
with:
python-version: '3.9'
- name: Install uv
run: |
curl -LsSf https://astral.sh/uv/install.sh | sh
- name: Install dependencies
run: |
uv pip install --python ${Python_ROOT_DIR} '.'
- name: Install dev dependencies
run: |
uv pip install --python ${Python_ROOT_DIR} pytest pytest-cov
- name: Run pytest
uses: sjvrijn/pytest-last-failed@v2
with:
pytest-args: '--exitfirst --cov'
- name: Explicitly convert coverage to xml
run: coverage xml
- name: Upload coverage reports to Codecov
uses: codecov/[email protected]
with:
token: ${{ secrets.CODECOV_TOKEN }}
slug: princeton-nlp/SWE-bench
13 changes: 13 additions & 0 deletions tests/test_cli.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
import subprocess


def test_smoke_test():
cmd = ["python", "-m", "swebench.harness.run_evaluation", "--help"]
result = subprocess.run(cmd, capture_output=True)
assert result.returncode == 0


def test_one_instance():
cmd = ["python", "-m", "swebench.harness.run_evaluation", "--predictions_path", "gold", "--max_workers", "1", "--instance_ids", "sympy__sympy-20590", "--run_id", "validate-gold"]
result = subprocess.run(cmd, capture_output=True)
assert result.returncode == 0

0 comments on commit e0a7f5b

Please sign in to comment.