Skip to content

Commit

Permalink
More CI cleanup
Browse files Browse the repository at this point in the history
  • Loading branch information
Archmonger committed Oct 2, 2024
1 parent ede5f09 commit 0c3c19e
Show file tree
Hide file tree
Showing 8 changed files with 49 additions and 65 deletions.
8 changes: 3 additions & 5 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# EditorConfig: http://EditorConfig.org
# http://editorconfig.org

root = true

Expand All @@ -7,8 +7,8 @@ indent_style = space
indent_size = 2
insert_final_newline = true
trim_trailing_whitespace = true
end_of_line = lf
charset = utf-8
end_of_line = lf

[*.py]
indent_size = 4
Expand All @@ -27,8 +27,6 @@ max_line_length = off
indent_size = 4
max_line_length = off

# Tests don't get a line width restriction. It's still a good idea to follow
# the 99 character rule, but in the interests of clarity, tests often need to
# violate it.
# Tests can violate line width restrictions in the interest of clarity.
[**/test_*.py]
max_line_length = off
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ jobs:
- name: Upload HTML report
uses: actions/upload-artifact@v4
with:
name: html-report
name: coverage-report
path: htmlcov

publish-docs:
Expand Down
20 changes: 7 additions & 13 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
ci:
autoupdate_schedule: monthly

repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.6.0
rev: "v4.6.0"
hooks:
- id: check-added-large-files
- id: check-case-conflict
Expand All @@ -11,11 +14,11 @@ repos:
- id: end-of-file-fixer
- id: trailing-whitespace
- repo: https://github.com/tox-dev/pyproject-fmt
rev: 2.2.4
rev: "2.2.4"
hooks:
- id: pyproject-fmt
- repo: https://github.com/asottile/pyupgrade
rev: v3.17.0
rev: "v3.17.0"
hooks:
- id: pyupgrade
args: [--py39-plus]
Expand All @@ -25,16 +28,7 @@ repos:
- id: pycln
args: [--all]
- repo: https://github.com/adamchainz/django-upgrade
rev: 1.21.0
rev: "1.21.0"
hooks:
- id: django-upgrade
args: [--target-version, "3.2"]
- repo: https://github.com/astral-sh/ruff-pre-commit
# Ruff version.
rev: v0.6.8
hooks:
# Run the linter.
- id: ruff
args: [--fix]
# Run the formatter.
- id: ruff-format
7 changes: 0 additions & 7 deletions MANIFEST.in

This file was deleted.

38 changes: 14 additions & 24 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ requires = [ "hatchling" ]
name = "servestatic"
description = "Production-grade static file server for Python web apps."
readme = "README.md"
keywords = [ "Django" ]
keywords = [ "asgi", "django", "http", "server", "static", "staticfiles", "wsgi" ]
license = "MIT"
authors = [ { name = "Mark Bakhit" } ]
requires-python = ">=3.9"
Expand All @@ -26,7 +26,6 @@ classifiers = [
"Topic :: Internet :: WWW/HTTP :: WSGI :: Middleware",
]
dynamic = [ "version" ]
dependencies = [ "django" ]
optional-dependencies.brotli = [ "brotli" ]
urls.Changelog = "https://archmonger.github.io/ServeStatic/latest/changelog/"
urls.Documentation = "https://archmonger.github.io/ServeStatic/"
Expand All @@ -36,26 +35,25 @@ urls.Homepage = "https://github.com/Archmonger/ServeStatic"
path = "src/servestatic/__init__.py"

[tool.hatch.build.targets.sdist]
include = [ "/src", "/tests" ]
include = [ "/src" ]

[tool.hatch.build.targets.wheel]
nclude = [ "/src", "/tests" ]
include = [ "/src" ]

[tool.hatch.metadata]
license-files = { paths = [ "LICENSE" ] }
license-files = { paths = [ "LICENSE.md" ] }

[tool.hatch.envs.default]
installer = "uv"

#
# Testing
#
# >>> Hatch Tests <<<

[tool.hatch.envs.hatch-test]
extra-dependencies = [ "pytest-sugar", "requests", "brotli" ]
randomize = true
matrix-name-format = "{variable}-{value}"

# Django 3.2 LTS
# Django 3.2
[[tool.hatch.envs.hatch-test.matrix]]
python = [ "3.9", "3.10" ]
django = [ "3.2" ]
Expand Down Expand Up @@ -107,9 +105,8 @@ matrix.django.dependencies = [
], value = "django~=5.1" },
]

#
# Documentation
#
# >>> Hatch Documentation <<<

[tool.hatch.envs.docs]
template = "docs"
detached = true
Expand All @@ -136,9 +133,8 @@ linkcheck = [
deploy_latest = [ "cd docs && mike deploy --push --update-aliases {args} latest" ]
deploy_develop = [ "cd docs && mike deploy --push develop" ]

#
# pre-commit
#
# >>> Hatch pre-commit <<<

[tool.hatch.envs.precommit]
template = "pre-commit"
detached = true
Expand All @@ -148,9 +144,8 @@ dependencies = [ "pre-commit>=3,<4" ]
check = [ "pre-commit run --all-files" ]
update = [ "pre-commit autoupdate" ]

#
# pyproject-format
#
# >>> Hatch pyproject-format <<<

[tool.hatch.envs.pyproject]
template = "pyproject"
detached = true
Expand All @@ -159,9 +154,7 @@ dependencies = [ "pyproject-fmt" ]
[tool.hatch.envs.pyproject.scripts]
format = [ "pyproject-fmt pyproject.toml" ]

#
# Tools
#
# >>> Generic Tools <<<

[tool.black]
target-version = [ "py39" ]
Expand Down Expand Up @@ -197,6 +190,3 @@ source = [ "src/" ]

[tool.coverage.report]
show_missing = true

[tool.rstcheck]
report_level = "ERROR"
11 changes: 4 additions & 7 deletions scripts/generate_default_media_types.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/usr/bin/env python
# pragma: no cover
from __future__ import annotations

import argparse
Expand Down Expand Up @@ -34,16 +34,14 @@ def main() -> int:


EXTRA_MIMETYPES = {
# nginx file uses application/javascript, but HTML specification recommends
# text/javascript:
# Nginx uses application/javascript, but HTML specification recommends text/javascript:
".js": "text/javascript",
".md": "text/markdown",
".mjs": "text/javascript",
".woff": "application/font-woff",
".woff2": "font/woff2",
"apple-app-site-association": "application/pkc7-mime",
# Adobe Products - see:
# https://www.adobe.com/devnet-docs/acrobatetk/tools/AppSec/xdomain.html#policy-file-host-basics
# Adobe: https://www.adobe.com/devnet-docs/acrobatetk/tools/AppSec/xdomain.html#policy-file-host-basics
"crossdomain.xml": "text/x-cross-domain-policy",
}

Expand Down Expand Up @@ -75,8 +73,7 @@ def get_types_map() -> dict[str, str]:
types_map = {}
for match in matches:
media_type = match[0]
# This is the default media type anyway, no point specifying
# it explicitly
# This is the default media type anyway, no point specifying it explicitly
if media_type == "application/octet-stream":
continue

Expand Down
23 changes: 20 additions & 3 deletions scripts/validate_changelog.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
"""Parses Keep a Changelog format and ensures it is valid"""
# pragma: no cover
# ruff: noqa: PERF401

# /// script
# requires-python = ">=3.11"
# dependencies = []
# ///

# ruff: noqa: PERF401
import re
import sys

Expand All @@ -30,7 +30,7 @@ def validate_changelog(changelog_path="CHANGELOG.md"):
with open(changelog_path, encoding="UTF-8") as file:
changelog = file.read()

# Remove HTML comments
# Remove comments
changelog = re.sub(HTML_COMMENT_RE[0], "", changelog, flags=HTML_COMMENT_RE[1])
# Replace duplicate newlines with a single newline
changelog = re.sub(r"\n+", "\n", changelog)
Expand Down Expand Up @@ -171,8 +171,25 @@ def validate_changelog(changelog_path="CHANGELOG.md"):
f"Section '{line}' is out of order in version '{version_header}'. "
"Expected section order: [Added, Changed, Deprecated, Removed, Fixed, Security]"
)
# Additional check for duplicate sections
if section_position == current_position_in_order:
errors.append(f"Duplicate section '{line}' found in version '{version_header}'.")
current_position_in_order = section_position

# Find sections for missing bullet points
changelog_header_and_bullet_lines = [
line for line in changelog.split("\n") if line.startswith(("### ", "## ", "-"))
]
current_version = "UNKNOWN"
for position, line in enumerate(changelog_header_and_bullet_lines):
if line.startswith("## "):
current_version = line
# If it's an h3 header, report an error if the next line is not a bullet point, or if there is no next line
if line.startswith("### ") and (
position + 1 == len(changelog_header_and_bullet_lines)
or not changelog_header_and_bullet_lines[position + 1].startswith("-")
):
errors.append(f"Section '{line}' in version '{current_version}' is missing bullet points")
return errors


Expand Down
5 changes: 0 additions & 5 deletions setup.cfg

This file was deleted.

0 comments on commit 0c3c19e

Please sign in to comment.