Skip to content

Commit

Permalink
Use antsibull-docutils and remove code moved there.
Browse files Browse the repository at this point in the history
  • Loading branch information
felixfontein committed Aug 21, 2024
1 parent c15ad61 commit 8cf3dc9
Show file tree
Hide file tree
Showing 11 changed files with 65 additions and 1,267 deletions.
5 changes: 5 additions & 0 deletions .github/workflows/nox.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,11 @@ jobs:
uses: actions/checkout@v4
with:
path: antsibull-changelog
- name: Check out dependent project antsibull-docutils
uses: actions/checkout@v4
with:
repository: ansible-community/antsibull-docutils
path: antsibull-docutils
- name: Install extra packages
if: "matrix.packages != ''"
run: |
Expand Down
3 changes: 3 additions & 0 deletions changelogs/fragments/174-antsibull-docutils.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
minor_changes:
- "Antsibull-changelog now depends on the new package antsibull-docutils. This should not have any visible impact,
expect potentially improved MarkDown output (https://github.com/ansible-community/antsibull-changelog/pull/174)."
46 changes: 41 additions & 5 deletions noxfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
# SPDX-License-Identifier: GPL-3.0-or-later
# SPDX-FileCopyrightText: 2023 Maxwell G <maxwell@gtmx.me>

from __future__ import annotations

import contextlib
import os
import tempfile
Expand All @@ -11,6 +13,7 @@

import nox

DEFAULT_MODE = os.environ.get("OTHER_ANTSIBULL_MODE", "auto")
IN_CI = "GITHUB_ACTIONS" in os.environ
ALLOW_EDITABLE = os.environ.get("ALLOW_EDITABLE", str(not IN_CI)).lower() in (
"1",
Expand All @@ -34,9 +37,42 @@ def install(session: nox.Session, *args, editable=False, **kwargs):
session.install(*args, "-U", **kwargs)


def other_antsibull(
mode: str | None = None,
) -> list[str | Path]:
if mode is None:
mode = DEFAULT_MODE
to_install: list[str | Path] = []
args = ("antsibull-docutils",)
for project in args:
path = Path("../", project)
path_exists = path.is_dir()
if mode == "auto":
if path_exists:
mode = "local"
else:
mode = "git"
if mode == "local":
if not path_exists:
raise ValueError(f"Cannot install {project}! {path} does not exist!")
if ALLOW_EDITABLE:
to_install.append("-e")
to_install.append(path)
elif mode == "git":
to_install.append(
f"{project} @ "
f"https://github.com/ansible-community/{project}/archive/main.tar.gz"
)
elif mode == "pypi":
to_install.append(project)
else:
raise ValueError(f"install_other_antsibull: invalid argument mode={mode!r}")
return to_install


@nox.session(python=["3.9", "3.10", "3.11", "3.12"])
def test(session: nox.Session):
install(session, ".[test, coverage]", editable=True)
install(session, ".[test, coverage]", *other_antsibull(), editable=True)
covfile = Path(session.create_tmp(), ".coverage")
more_args = []
if session.python == "3.12":
Expand All @@ -60,7 +96,7 @@ def integration(session: nox.Session):
`antsibull-changelog lint-changelog-yaml` against antsibull-changelog
changelog and community.general's changelogs
"""
install(session, ".[coverage]", editable=True)
install(session, ".[coverage]", *other_antsibull(), editable=True)
tmp = Path(session.create_tmp())
covfile = tmp / ".coverage"
env = {"COVERAGE_FILE": f"{covfile}", **session.env}
Expand Down Expand Up @@ -132,7 +168,7 @@ def lint(session: nox.Session):

@nox.session
def formatters(session: nox.Session):
install(session, ".[formatters]")
install(session, ".[formatters]", *other_antsibull())
posargs = list(session.posargs)
if IN_CI:
posargs.append("--check")
Expand All @@ -142,7 +178,7 @@ def formatters(session: nox.Session):

@nox.session
def codeqa(session: nox.Session):
install(session, ".[codeqa]", editable=True)
install(session, ".[codeqa]", *other_antsibull(), editable=True)
session.run("flake8", "src/antsibull_changelog", *session.posargs)
session.run(
"pylint",
Expand All @@ -158,7 +194,7 @@ def codeqa(session: nox.Session):

@nox.session
def typing(session: nox.Session):
install(session, ".[typing]")
install(session, ".[typing]", *other_antsibull())
session.run("mypy", "src/antsibull_changelog")


Expand Down
1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ dependencies = [
"PyYAML",
"rstcheck >= 3.0.0, < 7.0.0",
"semantic_version",
"antsibull-docutils < 2.0.0", # TODO: lower bound!
]

[project.urls]
Expand Down
3 changes: 2 additions & 1 deletion src/antsibull_changelog/rendering/_document.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,10 @@

import abc

from antsibull_docutils.utils import ensure_newline_after_last_content

from ..config import TextFormat
from .document import AbstractRenderer, DocumentRenderer
from .utils import ensure_newline_after_last_content


class BaseContent(abc.ABC):
Expand Down
Loading

0 comments on commit 8cf3dc9

Please sign in to comment.