From 3c3a726a96836031fad3f62ef75bcab6d13d267e Mon Sep 17 00:00:00 2001 From: Jeremiah Lowin <153965+jlowin@users.noreply.github.com> Date: Fri, 5 Apr 2024 09:55:55 -0400 Subject: [PATCH 1/3] Add tests --- .github/workflows/run-tests.yml | 64 +++++++++++++++++++++++++++ .github/workflows/static-analysis.yml | 31 +++++++++++++ pyproject.toml | 30 +++++++++---- 3 files changed, 116 insertions(+), 9 deletions(-) create mode 100644 .github/workflows/run-tests.yml create mode 100644 .github/workflows/static-analysis.yml diff --git a/.github/workflows/run-tests.yml b/.github/workflows/run-tests.yml new file mode 100644 index 00000000..583c6faf --- /dev/null +++ b/.github/workflows/run-tests.yml @@ -0,0 +1,64 @@ +name: Run Tests + +env: + # enable colored output + # https://github.com/pytest-dev/pytest/issues/7443 + PY_COLORS: 1 + +on: + push: + branches: ["main"] + paths: + - .github/workflows/run-tests.yml + - src/** + - tests/** + - pyproject.toml + - setup.py + + pull_request: + paths: + - .github/workflows/run-tests.yml + - src** + - tests/** + - pyproject.toml + - setup.py + + workflow_dispatch: + +permissions: + contents: read + +jobs: + run_tests: + name: Python ${{ matrix.python-version }} on ${{ matrix.os }} + timeout-minutes: 15 + strategy: + matrix: + # run no_llm tests across all python versions and oses + os: [ubuntu-latest, macos-latest, windows-latest] + python-version: ['3.9', '3.10', '3.11', '3.12'] + + include: + # Run LLM tests on 3.9 + - python-version: '3.9' + os: 'ubuntu-latest' + + + runs-on: ${{ matrix.os }} + + env: + CONTROLFLOW_OPENAI_API_KEY: ${{ secrets.CONTROLFLOW_OPENAI_API_KEY }} + + steps: + - uses: actions/checkout@v4 + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.python-version }} + cache: "pip" + - name: Install ControlFlow + run: pip install ".[tests]" + + - name: Run tests + run: pytest -n auto -vv + if: ${{ !(github.event.pull_request.head.repo.fork) }} \ No newline at end of file diff --git a/.github/workflows/static-analysis.yml b/.github/workflows/static-analysis.yml new file mode 100644 index 00000000..18f6d773 --- /dev/null +++ b/.github/workflows/static-analysis.yml @@ -0,0 +1,31 @@ +name: Run static analysis + +env: + # enable colored output + # https://github.com/pytest-dev/pytest/issues/7443 + PY_COLORS: 1 + +on: + push: + branches: ["main"] + pull_request: + workflow_dispatch: + +permissions: + contents: read + +jobs: + + static_analysis: + timeout-minutes: 1 + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + - name: Set up Python + uses: actions/setup-python@v5 + with: + python-version: "3.9" + - name: Run pre-commit + uses: pre-commit/action@v3.0.1 diff --git a/pyproject.toml b/pyproject.toml index c49e5f13..b9892c38 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -6,8 +6,9 @@ authors = [ { name = "Jeremiah Lowin", email = "153965+jlowin@users.noreply.github.com" } ] dependencies = [ - "marvin>=2.3.1", + "marvin @ git+https://github.com/prefecthq/marvin@main", "prefect @ git+https://github.com/prefecthq/prefect@main", + # can remove when prefect fully migrates to pydantic 2 "pydantic>=2", ] readme = "README.md" @@ -17,19 +18,30 @@ keywords = ["ai", "chatbot", "llm", "NLP", "natural language processing", "prefe [project.urls] Code = "https://github.com/jlowin/ControlFlow" +[project.optional-dependencies] +tests = [ + "pytest-asyncio>=0.18.2,!=0.22.0,<0.23.0", + "pytest-env>=0.8,<2.0", + "pytest-rerunfailures>=10,<14", + "pytest-sugar>=0.9,<2.0", + "pytest>=8.1.1", + "pytest-timeout", + "pytest-xdist", + "pre-commit>=3.7.0", +] +dev = [ + "control_flow[tests]", + "ipython>=8.22.2", + "pdbpp>=0.10.3", + "ruff>=0.3.4", +] + [build-system] requires = ["hatchling"] build-backend = "hatchling.build" [tool.rye] -managed = true -dev-dependencies = [ - "ipython>=8.22.2", - "pdbpp>=0.10.3", - "pre-commit>=3.7.0", - "ruff>=0.3.4", - "pytest>=8.1.1", -] +managed = true [tool.hatch.metadata] allow-direct-references = true From 5e86b1976e65b3a8876f19ec8f5aecefe5d8949b Mon Sep 17 00:00:00 2001 From: Jeremiah Lowin <153965+jlowin@users.noreply.github.com> Date: Fri, 5 Apr 2024 09:57:00 -0400 Subject: [PATCH 2/3] Update run-tests.yml --- .github/workflows/run-tests.yml | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/.github/workflows/run-tests.yml b/.github/workflows/run-tests.yml index 583c6faf..32a753aa 100644 --- a/.github/workflows/run-tests.yml +++ b/.github/workflows/run-tests.yml @@ -35,13 +35,10 @@ jobs: strategy: matrix: # run no_llm tests across all python versions and oses - os: [ubuntu-latest, macos-latest, windows-latest] - python-version: ['3.9', '3.10', '3.11', '3.12'] - - include: - # Run LLM tests on 3.9 - - python-version: '3.9' - os: 'ubuntu-latest' + # os: [ubuntu-latest, macos-latest, windows-latest] + # python-version: ['3.9', '3.10', '3.11', '3.12'] + os: [ubuntu-latest] + python-version: ['3.9'] runs-on: ${{ matrix.os }} From 7534c0d2956d1c8db6e12b58d9dbae23c7e58f79 Mon Sep 17 00:00:00 2001 From: Jeremiah Lowin <153965+jlowin@users.noreply.github.com> Date: Fri, 5 Apr 2024 10:12:57 -0400 Subject: [PATCH 3/3] Update run-tests.yml --- .github/workflows/run-tests.yml | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/.github/workflows/run-tests.yml b/.github/workflows/run-tests.yml index 32a753aa..b0d2cb5b 100644 --- a/.github/workflows/run-tests.yml +++ b/.github/workflows/run-tests.yml @@ -1,4 +1,4 @@ -name: Run Tests +name: Run tests env: # enable colored output @@ -48,13 +48,17 @@ jobs: steps: - uses: actions/checkout@v4 + - name: Set up Python ${{ matrix.python-version }} uses: actions/setup-python@v5 with: python-version: ${{ matrix.python-version }} - cache: "pip" + + - name: download uv + run: curl -LsSf https://astral.sh/uv/install.sh | sh + - name: Install ControlFlow - run: pip install ".[tests]" + run: uv pip install --system ".[tests]" - name: Run tests run: pytest -n auto -vv