Skip to content

Commit

Permalink
Merge pull request #3108 from pajod/patch-githubactions
Browse files Browse the repository at this point in the history
restore, and from now on CI-test for entry point
  • Loading branch information
tilgovi committed Dec 29, 2023
2 parents b5d78e8 + 611746e commit f9e61b1
Show file tree
Hide file tree
Showing 9 changed files with 49 additions and 8 deletions.
6 changes: 5 additions & 1 deletion .github/workflows/lint.yml
Expand Up @@ -2,6 +2,9 @@ name: lint
on: [push, pull_request]
permissions:
contents: read # to fetch code (actions/checkout)
env:
# note that some tools care only for the name, not the value
FORCE_COLOR: 1
jobs:
lint:
name: tox-${{ matrix.toxenv }}
Expand All @@ -14,9 +17,10 @@ jobs:
steps:
- uses: actions/checkout@v4
- name: Using Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: pip
- name: Install Dependencies
run: |
python -m pip install --upgrade pip
Expand Down
10 changes: 9 additions & 1 deletion .github/workflows/tox.yml
Expand Up @@ -2,6 +2,9 @@ name: tox
on: [push, pull_request]
permissions:
contents: read # to fetch code (actions/checkout)
env:
# note that some tools care only for the name, not the value
FORCE_COLOR: 1
jobs:
tox:
name: ${{ matrix.os }} / ${{ matrix.python-version }}
Expand All @@ -14,11 +17,16 @@ jobs:
steps:
- uses: actions/checkout@v4
- name: Using Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: pip
cache-dependency-path: requirements_test.txt
check-latest: true
- name: Install Dependencies
run: |
python -m pip install --upgrade pip
python -m pip install tox
- run: tox -e run-module
- run: tox -e run-entrypoint
- run: tox -e py
5 changes: 5 additions & 0 deletions appveyor.yml
Expand Up @@ -7,6 +7,11 @@ environment:
PYTHON: "C:\\Python38-x64"
- TOXENV: pycodestyle
PYTHON: "C:\\Python38-x64"
# Windows cannot even import the module when they unconditionally import, see below.
#- TOXENV: run-module
# PYTHON: "C:\\Python38-x64"
#- TOXENV: run-entrypoint
# PYTHON: "C:\\Python38-x64"
# Windows is not ready for testing!!!
# Python's fcntl, grp, pwd, os.geteuid(), and socket.AF_UNIX are all Unix-only.
#- TOXENV: py35
Expand Down
6 changes: 5 additions & 1 deletion gunicorn/__main__.py
Expand Up @@ -4,4 +4,8 @@
# See the NOTICE for more information.

from gunicorn.app.wsgiapp import run
run()

if __name__ == "__main__":
# see config.py - argparse defaults to basename(argv[0]) == "__main__.py"
# todo: let runpy.run_module take care of argv[0] rewriting
run(prog="gunicorn")
4 changes: 2 additions & 2 deletions gunicorn/app/wsgiapp.py
Expand Up @@ -58,13 +58,13 @@ def load(self):
return self.load_wsgiapp()


def run():
def run(prog=None):
"""\
The ``gunicorn`` command line runner for launching Gunicorn with
generic WSGI applications.
"""
from gunicorn.app.wsgiapp import WSGIApplication
WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]").run()
WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]", prog=prog).run()


if __name__ == '__main__':
Expand Down
10 changes: 9 additions & 1 deletion pyproject.toml
Expand Up @@ -57,13 +57,21 @@ setproctitle = ["setproctitle"]
testing = [
"gevent",
"eventlet",
"cryptography",
"coverage",
"pytest",
"pytest-cov",
]

[project.scripts]
# duplicates "python -m gunicorn" handling in __main__.py
gunicorn = "gunicorn.app.wsgiapp:run"

# note the quotes around "paste.server_runner" to escape the dot
[project.entry-points."paste.server_runner"]
main = "gunicorn.app.pasterapp:serve"

[tool.pytest.ini_options]
# # can override these: python -m pytest --override-ini="addopts="
norecursedirs = ["examples", "lib", "local", "src"]
testpaths = ["tests/"]
addopts = "--assert=plain --cov=gunicorn --cov-report=xml"
Expand Down
5 changes: 5 additions & 0 deletions requirements_dev.txt
@@ -1,4 +1,9 @@
-r requirements_test.txt

# setuptools v68.0 fails hard on invalid pyproject.toml
# which a developer would want to know
# otherwise, oldest known-working version is 61.2
setuptools>=68.0

sphinx
sphinx_rtd_theme
1 change: 0 additions & 1 deletion requirements_test.txt
@@ -1,6 +1,5 @@
gevent
eventlet
cryptography
coverage
pytest
pytest-cov
10 changes: 9 additions & 1 deletion tox.ini
@@ -1,5 +1,5 @@
[tox]
envlist = py{37,38,39,310,311,py3}, lint, docs-lint, pycodestyle
envlist = py{37,38,39,310,311,py3}, lint, docs-lint, pycodestyle, run-entrypoint, run-module
skipsdist = false
; Can't set skipsdist and use_develop in tox v4 to true due to https://github.com/tox-dev/tox/issues/2730

Expand All @@ -9,6 +9,14 @@ commands = pytest --cov=gunicorn {posargs}
deps =
-rrequirements_test.txt

[testenv:run-entrypoint]
# entry point: console script (provided by setuptools from pyproject.toml)
commands = python -c 'import subprocess; cmd_out = subprocess.check_output(["gunicorn", "--version"])[:79].decode("utf-8", errors="replace"); print(cmd_out); assert cmd_out.startswith("gunicorn ")'

[testenv:run-module]
# runpy (provided by module.__main__)
commands = python -c 'import sys,subprocess; cmd_out = subprocess.check_output([sys.executable, "-m", "gunicorn", "--version"])[:79].decode("utf-8", errors="replace"); print(cmd_out); assert cmd_out.startswith("gunicorn ")'

[testenv:lint]
commands =
pylint -j0 \
Expand Down

0 comments on commit f9e61b1

Please sign in to comment.