Skip to content

Commit

Permalink
remove virtualenv
Browse files Browse the repository at this point in the history
  • Loading branch information
boxydog committed Jun 9, 2024
1 parent cbb42f1 commit 2f0324d
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 48 deletions.
47 changes: 8 additions & 39 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -44,62 +44,31 @@ jobs:
pandoc-version: "2.9.2"
- name: Install tox
run: python -m pip install -U pip tox
- name: Set up virtualenv
# our tasks.py wants a virtualenv, so make one
# unfortunately, every step that uses it has to be split by
# platform, because activating it is different on unix and windows
if: runner.os != 'Windows'
run: python -m venv venv
- name: Set up virtualenv (windows)
if: runner.os == 'Windows'
- name: Install pdm
run: |
python -m venv venv
if ($LASTEXITCODE -ne 0) {
Write-Host "Virtual environment creation failed: $LASTEXITCODE"
exit $LASTEXITCODE
}
$pwd
# dir venv\Scripts
- name: Set up dependencies with invoke (not windows)
if: runner.os != 'Windows'
pdm install --dev
pdm config python.use_venv false
- name: Set up dependencies with invoke
run: |
source venv/bin/activate
python -m pip install invoke
python -m invoke setup
- name: Set up dependencies with invoke (windows)
if: runner.os == 'Windows'
run: |
$pwd
. venv\Scripts\activate
Import-Module venv
python -m pip install invoke
python -m invoke setup
echo "== PYTHON after setup =="
python --version
python -c "import pytest"
- name: Info
run: |
echo "===== PYTHON ====="
python --version
echo "===== PANDOC ====="
pandoc --version | head -2
- name: Run tests with coverage (not windows)
if: runner.os != 'Windows'
- name: Run tests with coverage
run: |
source venv/bin/activate
python -m pytest --cov=pelican
ls -l .coverage.*
env:
# control the filename to avoid issues with uploading
# see also https://github.com/actions/upload-artifact/issues/478#issuecomment-2096976037
COVERAGE_FILE: .coverage.${{ matrix.os }}.${{ matrix.python }}.${{ github.event_name }}
- name: Run tests with coverage (windows)
if: runner.os == 'Windows'
run: |
.\venv\bin\activate
python -m pytest --cov=pelican
env:
# control the filename to avoid issues with uploading
# see also https://github.com/actions/upload-artifact/issues/478#issuecomment-2096976037
COVERAGE_FILE: .coverage.${{ matrix.os }}.${{ matrix.python }}.${{ github.event_name }}

- name: Upload coverage data
uses: "actions/upload-artifact@v4"
with:
Expand Down
34 changes: 25 additions & 9 deletions tasks.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import os
import sys
from pathlib import Path
from shutil import which

Expand All @@ -15,9 +16,21 @@
VENV = str(VENV_PATH.expanduser())
VENV_BIN = Path(VENV) / Path(BIN_DIR)

PYTHON = which("python")

TOOLS = ["pdm", "pre-commit", "psutil"]
PDM = which("pdm") or VENV_BIN / "pdm"
PRECOMMIT = which("pre-commit") or VENV_BIN / "pre-commit"


def _get_pdm_path():
return which("pdm") or VENV_BIN / "pdm"


def _get_precommit_path():
return which("pre-commit") or VENV_BIN / "pre-commit"


def _get_coverage_path():
return which("coverage")


@task
Expand All @@ -41,14 +54,14 @@ def docserve(c):
@task
def tests(c):
"""Run the test suite"""
c.run(f"{VENV_BIN}/pytest", pty=PTY)
c.run(f"{PYTHON} -m pytest", pty=PTY)


@task
def coverage(c):
"""Generate code coverage of running the test suite."""
c.run(f"{VENV_BIN}/pytest --cov=pelican", pty=PTY)
c.run(f"{VENV_BIN}/coverage html", pty=PTY)
c.run(f"{PYTHON} -m pytest --cov=pelican", pty=PTY)
c.run(f"{PYTHON} -m coverage html", pty=PTY)


@task
Expand Down Expand Up @@ -87,20 +100,23 @@ def tools(c):
"""Install tools in the virtual environment if not already on PATH"""
for tool in TOOLS:
if not which(tool):
c.run(f"{VENV_BIN}/python -m pip install {tool}", pty=PTY)
c.run(f"{PYTHON} -m pip install {tool}", pty=PTY)


@task
def precommit(c):
"""Install pre-commit hooks to .git/hooks/pre-commit"""
c.run(f"{PRECOMMIT} install", pty=PTY)
precommt = _get_precommit_path()
c.run(f"{precommt} install", pty=PTY)


@task
def setup(c):
c.run(f"{VENV_BIN}/python -m pip install -U pip", pty=PTY)
c.run(f"{PYTHON} -m pip install -U pip", pty=PTY)
tools(c)
c.run(f"{PDM} install", pty=PTY)
pdm = _get_pdm_path()
print(f"***** running {pdm} install", file=sys.stderr) # noqa: T201
c.run(f"{pdm} install -v", pty=PTY, echo=True)
precommit(c)


Expand Down

0 comments on commit 2f0324d

Please sign in to comment.