Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: Add tooling to check and validate build: #447

Merged
merged 37 commits into from
Jun 25, 2024
Merged
Show file tree
Hide file tree
Changes from 35 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
6d4f59a
docs: Add script to check for invalid links and workflow to validate …
kirkrodrigues Jun 16, 2024
ce6116d
Test invalid link.
kirkrodrigues Jun 16, 2024
ce55228
Use GitHub actions annotations to print failures.
kirkrodrigues Jun 16, 2024
5e67f6c
Move to root directory before checking violations.
kirkrodrigues Jun 16, 2024
d391d54
Tweak actions error.
kirkrodrigues Jun 16, 2024
0f7f028
Undo error.
kirkrodrigues Jun 16, 2024
9428b28
Add error.
kirkrodrigues Jun 16, 2024
16bc8fb
Switch to Python script.
kirkrodrigues Jun 16, 2024
2b2f7ba
Undo error.
kirkrodrigues Jun 16, 2024
ad92e27
Add error.
kirkrodrigues Jun 16, 2024
a602610
Edits.
kirkrodrigues Jun 16, 2024
e35aca0
Edits.
kirkrodrigues Jun 16, 2024
799dff6
Undo error.
kirkrodrigues Jun 16, 2024
f42ff3f
Add error.
kirkrodrigues Jun 16, 2024
f8ede8d
Try unbuffered streams.
kirkrodrigues Jun 16, 2024
6222a58
Try verbose.
kirkrodrigues Jun 16, 2024
6d54035
Why GH, why?
kirkrodrigues Jun 16, 2024
4744cea
Shenanigans.
kirkrodrigues Jun 16, 2024
c25d435
More shenanigans.
kirkrodrigues Jun 16, 2024
db40901
Interesting.
kirkrodrigues Jun 16, 2024
57ea074
Remove colons from errors.
kirkrodrigues Jun 16, 2024
fa7447c
Sanity check.
kirkrodrigues Jun 16, 2024
8a244d4
T & E.
kirkrodrigues Jun 16, 2024
c80aace
T & E.
kirkrodrigues Jun 16, 2024
819e70e
Try chdir.
kirkrodrigues Jun 17, 2024
0f0629e
Try filename.
kirkrodrigues Jun 17, 2024
d033963
Undo error.
kirkrodrigues Jun 17, 2024
64708f1
Add error.
kirkrodrigues Jun 17, 2024
816f7de
Try everything.
kirkrodrigues Jun 17, 2024
b7c4bb7
Try everything 2.
kirkrodrigues Jun 17, 2024
51e8f86
Undo tests.
kirkrodrigues Jun 17, 2024
db6a23d
Undo error.
kirkrodrigues Jun 17, 2024
6f00377
Add error.
kirkrodrigues Jun 17, 2024
2a50b0e
Undo error.
kirkrodrigues Jun 17, 2024
2b64bcf
Clean-up.
kirkrodrigues Jun 17, 2024
16dba5e
Apply suggestions from code review
kirkrodrigues Jun 25, 2024
97149ba
Update comment.
kirkrodrigues Jun 25, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 38 additions & 0 deletions .github/workflows/clp-docs.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
name: "clp-docs"

on:
pull_request:
push:
workflow_dispatch:

concurrency:
group: "${{github.workflow}}-${{github.ref}}"
# Cancel in-progress jobs for efficiency
cancel-in-progress: true

jobs:
build:
strategy:
matrix:
os: ["macos-latest", "ubuntu-latest"]
runs-on: "${{matrix.os}}"
steps:
- uses: "actions/checkout@v4"
with:
submodules: "recursive"

- uses: "actions/setup-python@v5"
with:
python-version: "3.10"

- name: "Install task"
shell: "bash"
run: "npm install -g @go-task/cli"

- if: "matrix.os == 'macos-latest'"
name: "Install coreutils (for md5sum)"
run: "brew install coreutils"

- name: "Build docs"
shell: "bash"
run: "task docs:site"
2 changes: 1 addition & 1 deletion components/log-viewer-webui/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,6 @@ A webapp that allows us to serve the [log-viewer] and integrate it with CLP's [w

See the [docs] for more details.

[docs]: https://docs.yscope.com/clp/main/dev-guide/components-log-viewer-webui.md
[docs]: https://docs.yscope.com/clp/main/dev-guide/components-log-viewer-webui
[log-viewer]: https://github.com/y-scope/yscope-log-viewer
[webui]: ../webui
4 changes: 4 additions & 0 deletions docs/tasks.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,16 @@ tasks:
# Call `clean` before building since `sphinx-build --write-all --fresh-env` isn't always
# equivalent to building from scratch.
- task: "clean"
- "python3 '{{.ROOT_DIR}}/tools/scripts/find-broken-docs-links.py'"
- |-
. "{{.G_DOCS_VENV_DIR}}/bin/activate"
sphinx-build \
--write-all \
--fresh-env \
--conf-dir conf \
--nitpicky \
--fail-on-warning \
--keep-going \
--builder html \
src "{{.OUTPUT_DIR}}"
# This command must be last
Expand Down
117 changes: 117 additions & 0 deletions tools/scripts/find-broken-docs-links.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
import os
import subprocess
import sys
from pathlib import Path


def main(argv):
repo_root = _get_repo_root()

found_violation = False

# Check for https://docs.yscope.com links with ".md" suffixes
if _check_tracked_files(
r"https://docs\.yscope\.com/.+\.md",
kirkrodrigues marked this conversation as resolved.
Show resolved Hide resolved
repo_root,
repo_root,
"https://docs.yscope.com links cannot have \".md\" suffixes."
kirkrodrigues marked this conversation as resolved.
Show resolved Hide resolved
):
found_violation = True

# Check for sphinx :link: attributes that have ".md" suffixes
if _check_tracked_files(
r":link:[[:space:]]*.+\.md",
repo_root,
repo_root / "docs",
"sphinx :link: attributes cannot have \".md\" suffixes"
):
found_violation = True

if found_violation:
return 1

return 0


def _get_repo_root() -> Path:
path_str = subprocess.check_output(
["git", "rev-parse", "--show-toplevel"],
cwd=Path(__file__).parent,
text=True
)
return Path(path_str.strip())


def _check_tracked_files(
pattern: str,
repo_root: Path,
dir_to_search: Path,
error_msg: str
) -> bool:
"""
Check for a pattern in all tracked files in the repo (except this script).
:param pattern: The pattern to search for.
:param repo_root: The root of the repository.
:param dir_to_search: The directory to search in.
:param error_msg: Error message if the pattern is found.
:return: Whether the pattern was found in any file.
"""
found_matches = False

# NOTE: "-z" ensures the paths won't be quoted (while delimiting them using '\0')
for path_str in subprocess.check_output(
[
"git",
"ls-files",
"--cached",
"--exclude-standard",
"-z",
str(dir_to_search.relative_to(repo_root))
],
cwd=repo_root,
text=True,
).split("\0"):
path = Path(path_str)

# Skip directories and this script
if path == __file__ or (repo_root / path).is_dir():
continue

try:
for match in subprocess.check_output(
[
"grep",
"--extended-regexp",
"--line-number",
"--with-filename",
pattern,
path
],
cwd=repo_root,
text=True,
).splitlines():
_parse_and_print_match(match, error_msg)
found_matches = True
except subprocess.CalledProcessError:
pass

return found_matches


def _parse_and_print_match(match: str, error_msg: str):
"""
Parses and prints grep matches in a format relevant to the current environment.
:param match: The match to parse and print.
:param error_msg: Error message if the pattern is found.
"""
if os.getenv("GITHUB_ACTIONS") == "true":
# Print a GitHub Actions error annotation
file, line, _ = match.split(":", 2)
print(f"::error file={file},line={line}::{error_msg}")
else:
print(error_msg, file=sys.stderr)
print(match, file=sys.stderr)


if "__main__" == __name__:
sys.exit(main(sys.argv))