mirror of
https://github.com/saltstack/salt.git
synced 2025-04-16 09:40:20 +00:00
123 lines
3.9 KiB
Python
Executable file
123 lines
3.9 KiB
Python
Executable file
#!/usr/bin/env python3
|
|
# pylint: skip-file
|
|
|
|
import pathlib
|
|
import re
|
|
import sys
|
|
|
|
CODE_ROOT = pathlib.Path(__file__).resolve().parent.parent
|
|
DOCS_PATH = CODE_ROOT / "doc"
|
|
TESTS_INTEGRATION_FILES_PATH = CODE_ROOT / "tests" / "integration" / "files"
|
|
CHANGELOG_ENTRIES_PATH = CODE_ROOT / "changelog"
|
|
CHANGELOG_LIKE_RE = re.compile(r"([\d]+)\.([a-z]+)$")
|
|
CHANGELOG_EXTENSIONS = (
|
|
"removed",
|
|
"deprecated",
|
|
"changed",
|
|
"fixed",
|
|
"added",
|
|
"security",
|
|
)
|
|
CHANGELOG_ENTRY_RE = re.compile(
|
|
r"([\d]+|(CVE|cve)-[\d]{{4}}-[\d]+)\.({})(\.md)?$".format(
|
|
"|".join(CHANGELOG_EXTENSIONS)
|
|
)
|
|
)
|
|
|
|
|
|
def check_changelog_entries(files):
|
|
|
|
exitcode = 0
|
|
for entry in files:
|
|
path = pathlib.Path(entry).resolve()
|
|
# Is it under changelog/
|
|
try:
|
|
path.relative_to(CHANGELOG_ENTRIES_PATH)
|
|
if path.name == ".keep":
|
|
# This is the file we use so git doesn't delete the changelog/ directory
|
|
continue
|
|
# Is it named properly
|
|
if not CHANGELOG_ENTRY_RE.match(path.name):
|
|
print(
|
|
"The changelog entry '{}' should have one of the following extensions: {}.".format(
|
|
path.relative_to(CODE_ROOT),
|
|
", ".join(f"{ext}.md" for ext in CHANGELOG_EXTENSIONS),
|
|
),
|
|
file=sys.stderr,
|
|
flush=True,
|
|
)
|
|
exitcode = 1
|
|
continue
|
|
if not path.suffix == ".md":
|
|
print(
|
|
f"Please rename '{path.relative_to(CODE_ROOT)}' to "
|
|
f"'{path.relative_to(CODE_ROOT)}.md'",
|
|
file=sys.stderr,
|
|
flush=True,
|
|
)
|
|
exitcode = 1
|
|
continue
|
|
except ValueError:
|
|
# No, carry on
|
|
pass
|
|
# Does it look like a changelog entry
|
|
if CHANGELOG_LIKE_RE.match(path.name) and not CHANGELOG_ENTRY_RE.match(
|
|
path.name
|
|
):
|
|
try:
|
|
# Is this under doc/
|
|
path.relative_to(DOCS_PATH)
|
|
# Yes, carry on
|
|
continue
|
|
except ValueError:
|
|
# No, resume the check
|
|
pass
|
|
try:
|
|
# Is this under tests/integration/files
|
|
path.relative_to(TESTS_INTEGRATION_FILES_PATH)
|
|
# Yes, carry on
|
|
continue
|
|
except ValueError:
|
|
# No, resume the check
|
|
pass
|
|
print(
|
|
"The changelog entry '{}' should have one of the following extensions: {}.".format(
|
|
path.relative_to(CODE_ROOT),
|
|
", ".join(f"{ext}.md" for ext in CHANGELOG_EXTENSIONS),
|
|
),
|
|
file=sys.stderr,
|
|
flush=True,
|
|
)
|
|
exitcode = 1
|
|
continue
|
|
# Is it a changelog entry
|
|
if not CHANGELOG_ENTRY_RE.match(path.name):
|
|
# No? Carry on
|
|
continue
|
|
# Is the changelog entry in the right path?
|
|
try:
|
|
path.relative_to(CHANGELOG_ENTRIES_PATH)
|
|
except ValueError:
|
|
exitcode = 1
|
|
print(
|
|
"The changelog entry '{}' should be placed under '{}/', not '{}'".format(
|
|
path.name,
|
|
CHANGELOG_ENTRIES_PATH.relative_to(CODE_ROOT),
|
|
path.relative_to(CODE_ROOT).parent,
|
|
),
|
|
file=sys.stderr,
|
|
flush=True,
|
|
)
|
|
if not path.suffix == ".md":
|
|
print(
|
|
f"Please rename '{path.relative_to(CODE_ROOT)}' to "
|
|
f"'{path.relative_to(CODE_ROOT)}.md'",
|
|
file=sys.stderr,
|
|
flush=True,
|
|
)
|
|
exitcode = 1
|
|
sys.exit(exitcode)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
check_changelog_entries(sys.argv[1:])
|