From be292c404ce2d11a506c22c7ce9eb9e79af68317 Mon Sep 17 00:00:00 2001 From: Pierlou Ramade <48205215+Pierlou@users.noreply.github.com> Date: Thu, 4 Apr 2024 15:04:05 +0200 Subject: [PATCH] feat: add version testing (#1) * feat: add version testing * fix: add failsafe * fix: fix check * refactor: minor change * fix: display all errors * fix: standardize schemas versions * refactor: apply black and upgrade yml --- .github/workflows/assert_version.py | 64 ++++++++++++++++++++++++++++ .github/workflows/assert_version.yml | 19 +++++++++ table1/schema.json | 2 +- table2/schema.json | 2 +- 4 files changed, 85 insertions(+), 2 deletions(-) create mode 100755 .github/workflows/assert_version.py create mode 100644 .github/workflows/assert_version.yml diff --git a/.github/workflows/assert_version.py b/.github/workflows/assert_version.py new file mode 100755 index 0000000..496b15e --- /dev/null +++ b/.github/workflows/assert_version.py @@ -0,0 +1,64 @@ +import json +import re +import os + +pattern = r"v?\d+\.\d+\.\d+" + + +def check(obj, version, parents=""): + """ + This functions recursively parses all fields in the schema looking for + version names that would not be the same as the one mentionned + in the 'version' field + """ + errors = [] + # if field is a string, we check for a potential version + if isinstance(obj, str): + tmp = re.search(pattern, obj) + if tmp and tmp[0] != version: + errors += [(parents, tmp[0])] + # if field is a list, we check every item + elif isinstance(obj, list): + for idx, k in enumerate(obj): + errors += check(k, version, parents=parents + f"[{str(idx)}]") + # if field is a dict, we check every value + elif isinstance(obj, dict): + for k in obj: + # not checking the fields + if k != "fields": + errors += check( + obj[k], + version, + parents=parents + "." + k if parents else k + ) + return errors + + +to_check = [] + +if "schema.json" in os.listdir(): + to_check.append("schema.json") + +elif "datapackage.json" in os.listdir(): + with open("datapackage.json", "r") as f: + datapackage = json.load(f) + for r in datapackage["resources"]: + to_check.append(r["schema"]) + +else: + raise Exception("No required file found") + +for schema_path in to_check: + with open(schema_path, "r") as f: + schema = json.load(f) + version = schema["version"] + + errors = check(schema, version) + if errors: + message = ( + f"Versions are mismatched within the schema '{schema['name']}', " + f"expected version '{version}' but:" + ) + for e in errors: + message += f"\n- {e[0]} has version '{e[1]}'" + raise Exception(message) diff --git a/.github/workflows/assert_version.yml b/.github/workflows/assert_version.yml new file mode 100644 index 0000000..2bd821e --- /dev/null +++ b/.github/workflows/assert_version.yml @@ -0,0 +1,19 @@ +name: Vérification de la cohérence des versions dans tous les champs du schéma + +on: + push: + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - name: Checkout Repository + uses: actions/checkout@v4 + + - name: Set up Python + uses: actions/setup-python@v5 + with: + python-version: "3.10" + + - run: python .github/workflows/assert_version.py diff --git a/table1/schema.json b/table1/schema.json index 6863362..85a4a36 100644 --- a/table1/schema.json +++ b/table1/schema.json @@ -25,7 +25,7 @@ ], "created": "2024-02-08", "lastModified": "2024-02-08", - "version": "0.0.1", + "version": "v0.0.1", "contributors": [ { "title": "Test Test", diff --git a/table2/schema.json b/table2/schema.json index 71e0bbb..8b1ec07 100644 --- a/table2/schema.json +++ b/table2/schema.json @@ -25,7 +25,7 @@ ], "created": "2024-02-08", "lastModified": "2024-02-08", - "version": "0.0.1", + "version": "v0.0.1", "contributors": [ { "title": "Test Test",