From 2bcbd4868e97309cccc13da6e40467cb500e398c Mon Sep 17 00:00:00 2001 From: langevin-usgs Date: Sun, 24 Sep 2023 07:43:28 -0500 Subject: [PATCH] ci(msvs): workflow to verify msvs project files are complete (#1365) * ci(msvs): workflow to verify msvs project files are complete * add check for srcbmi and cleanup * fix renamed reference * implement suggested change, run black and isort --- .github/common/msvs_vfproj_check.py | 68 +++++++++++++++++++++++++++++ .github/workflows/ci.yml | 3 ++ msvs/mf6core.vfproj | 2 +- 3 files changed, 72 insertions(+), 1 deletion(-) create mode 100644 .github/common/msvs_vfproj_check.py diff --git a/.github/common/msvs_vfproj_check.py b/.github/common/msvs_vfproj_check.py new file mode 100644 index 00000000000..80c1f3d719d --- /dev/null +++ b/.github/common/msvs_vfproj_check.py @@ -0,0 +1,68 @@ +import xml.etree.ElementTree as ET +from pathlib import Path + + +def get_source_files(src_folder): + p = Path(".") + src_files = [] + print(f"Processing {src_folder} folder") + ftypes = ("*.[fF]9[05]", "*.inc") + src_files = [] + for ft in ftypes: + src_files.extend(p.glob(f"{src_folder}/**/{ft}")) + return src_files + + +def get_msvs_files(vfproj_file): + print(f"Processing {vfproj_file}") + tree = ET.parse(vfproj_file) + root = tree.getroot() + msvs_files = [] + for f in root.iter("File"): + s = f.attrib["RelativePath"] + s = s.replace("\\", "/") + s = s.replace("../", "") + fpath = Path(s) + msvs_files.append(fpath) + return msvs_files + + +def check_files(name, src_files, msvs_files): + print( + f"Verifying {name} files referenced in msvs project files are in src folder..." + ) + s, m = set(src_files), set(msvs_files) + diff = s ^ m + from pprint import pformat + + assert not any(diff), ( + f"{name} src files don't match msvs project file\n" + f"=> symmetric difference:\n{pformat(diff)}\n" + f"=> src - msvs:\n{pformat(s - m)}\n" + f"=> msvs - src:\n{pformat(m - s)}\n" + "Check to make sure msvs project file is consistent with source files." + ) + + +def check_mf6(): + # get list of source files and files referenced in msvs project files + src_files = get_source_files("src") + msvs_files = [] + for vfproj in ["./msvs/mf6core.vfproj", "./msvs/mf6.vfproj"]: + msvs_files.extend(get_msvs_files(vfproj)) + check_files("MF6", src_files, msvs_files) + + +def check_bmi(): + # get list of source files and files referenced in msvs project files + src_files = get_source_files("srcbmi") + msvs_files = [] + for vfproj in ["./msvs/mf6bmi.vfproj"]: + msvs_files.extend(get_msvs_files(vfproj)) + check_files("BMI", src_files, msvs_files) + + +if __name__ == "__main__": + check_mf6() + check_bmi() + print("msvs project (vfproj) files appear up-to-date...") diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a51323a4452..499d00595d1 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -61,6 +61,9 @@ jobs: - name: Check Fortran source formatting run: python .github/common/fortran_format_check.py + - name: Check msvs project files + run: python .github/common/msvs_vfproj_check.py + build: name: Build runs-on: ubuntu-22.04 diff --git a/msvs/mf6core.vfproj b/msvs/mf6core.vfproj index 81b2dccb5fc..ee13f7fa521 100644 --- a/msvs/mf6core.vfproj +++ b/msvs/mf6core.vfproj @@ -204,7 +204,7 @@ - +