Skip to content

Commit

Permalink
add CI against version check
Browse files Browse the repository at this point in the history
  • Loading branch information
alchem0x2A committed Nov 23, 2024
1 parent 0c82869 commit be05893
Show file tree
Hide file tree
Showing 3 changed files with 147 additions and 2 deletions.
32 changes: 30 additions & 2 deletions .github/workflows/build-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,41 @@ on:
workflow_dispatch:

jobs:
# Check if initialization.c is up-to-date with Changelog
package-date-check:
runs-on: ubuntu-latest
defaults:
run:
shell: bash -l {0}
steps:
- uses: actions/checkout@v4
- uses: conda-incubator/setup-miniconda@v3
with:
python-version: "3.11"
activate-environment: sparc-test
conda-build-version: "24.9.0"
miniforge-version: latest # Fix according to https://github.com/conda-incubator/setup-miniconda?tab=readme-ov-file#example-10-miniforge
channels: conda-forge,defaults
channel-priority: true
- name: Install SPARC-X-API stable version for docparser
run: |
mamba install -c conda-forge pip setuptools
pip install git+https://github.com/SPARC-X/SPARC-X-API.git@v1.0.5
- name: Convert parameters.json
run: |
python -m sparc.docparser --include-subdirs doc/.LaTeX
- name: Check missing parameters in test examples
run: |
# Usage:
# python test-outdated-package.py <parameters.json> <changelog>
python .github/workflows/test-outdated-package.py \
./parameters.json Changelog
build-linux:
runs-on: ubuntu-latest
defaults:
run:
shell: bash -l {0}
strategy:
max-parallel: 5
need: package-date-check

steps:
- uses: actions/checkout@v4
Expand Down
108 changes: 108 additions & 0 deletions .github/workflows/test-outdated-package.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
"""Test script to check if SPARC package version is older than
the latest Changelog entry
We generally do not check the other way around since sometimes a trivial bump of SPARC version may be necessary
"""
import re
import json
from datetime import datetime
from pathlib import Path


def load_parameters_json(json_path):
"""
Load the parameters from the parameters.json file.
"""
with open(json_path, 'r') as f:
parameters = json.load(f)
if "sparc_version" not in parameters:
raise KeyError("The 'sparc_version' field is missing in parameters.json")
return parameters["sparc_version"]


def extract_latest_date_from_changelog(changelog_path):
"""
Extracts the latest date from the changelog file.
"""
date_patterns = [
r"(?P<date>\b(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec) \d{1,2}, \d{4})",
r"(?P<date>\b(?:January|February|March|April|May|June|July|August|September|October|November|December) \d{1,2}, \d{4})",
]

latest_date = None
changelog_path = Path(changelog_path)

with changelog_path.open("r") as f:
content = f.read()

for pattern in date_patterns:
matches = re.findall(pattern, content)
for match in matches:
try:
# Convert matched date to datetime object
parsed_date = datetime.strptime(match, "%b %d, %Y") if "," in match else datetime.strptime(match, "%B %d, %Y")
if latest_date is None or parsed_date > latest_date:
latest_date = parsed_date
except ValueError:
continue # Skip invalid date formats

if latest_date is None:
raise ValueError("No valid date found in the changelog.")
return latest_date


def check_version_against_changelog(parameters_json_path, changelog_path):
"""
Check if the package version in parameters.json is older than the latest changelog date.
"""
# Load sparc_version from parameters.json
sparc_version = load_parameters_json(parameters_json_path)
version_date = datetime.strptime(sparc_version, "%Y.%m.%d")

# Extract the latest date from the changelog
latest_changelog_date = extract_latest_date_from_changelog(changelog_path)

if version_date < latest_changelog_date:
print("Version Check Report:")
print("-" * 60)
print(f"ERROR: SPARC version ({version_date.strftime('%Y.%m.%d')}) "
f"is older than the latest changelog date ({latest_changelog_date.strftime('%Y.%m.%d')}).")
print("Please update initialization.c!")
print("-" * 60)
return False
else:
print("Version Check Report:")
print("-" * 60)
print("SUCCESS:")
print("-" * 60)
return True


def main():
import argparse
parser = argparse.ArgumentParser(
description="Check if package version is up-to-date with the changelog."
)
parser.add_argument(
"parameters_json",
type=str,
help="Path to the parameters.json file."
)
parser.add_argument(
"changelog",
type=str,
help="Path to the changelog file."
)

args = parser.parse_args()

# Run the version check
success = check_version_against_changelog(args.parameters_json, args.changelog)
if not success:
exit(1)
else:
exit(0)


if __name__ == "__main__":
main()
9 changes: 9 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,15 @@
-Date
-Name
-changes
--------------
Nov 23, 2024
Name: Tian Tian
Changes: (doc, CI workflow)
1. Fix typo in SQ LaTeX doc
2. Add CI workflow to check missing parameters
3. Add CI workflow to validate and render LaTeX doc
4. Add CI workflow to check outdated initialization.c (SPARC version) if older than current Changelog

--------------
Nov 18, 2024
Name: Tian Tian, Lucas Timmerman
Expand Down

0 comments on commit be05893

Please sign in to comment.