From c6d6dccf90418093a617f54ea636564aa12d90ac Mon Sep 17 00:00:00 2001 From: Remi Gau Date: Mon, 17 Jun 2024 15:09:19 +0200 Subject: [PATCH] [FIX] update CI validation (#503) * update validation * rm link * comment failing part of CI for now --- .github/workflows/pythonpackage.yml | 18 ++++++++++-------- docs/project-structure.md | 2 +- examples/activities/items/item2.jsonld | 1 - scripts/jsonParser.py | 1 + scripts/makeRelease.py | 2 +- 5 files changed, 13 insertions(+), 11 deletions(-) diff --git a/.github/workflows/pythonpackage.yml b/.github/workflows/pythonpackage.yml index 676a7d44c0..337730f6bd 100644 --- a/.github/workflows/pythonpackage.yml +++ b/.github/workflows/pythonpackage.yml @@ -21,17 +21,19 @@ jobs: with: python-version: 3.12 - name: Install dependencies - # TODO update to install from the latest version on reproschema - # once https://github.com/ReproNim/reproschema-py/pull/40 has been merged and a new release has been made. + # TODO This installs reproschema from source and not from pypi + # This may not be the optimal way of doing it. run: | python -m pip install --upgrade pip setuptools - pip install git+https://github.com/Remi-Gau/reproschema-py.git@skip + pip install git+https://github.com/ReproNim/reproschema-py.git - name: Test with pyshacl run: | python scripts/jsonParser.py reproschema validate examples - - name: Make a release - run: | - python scripts/makeRelease.py ci-release - pip install pytablewriter - python scripts/editProperties.py ci-release + # TODO adapt make release + # TODO use mkdocs macro to update doc content + # - name: Make a release + # run: | + # python scripts/makeRelease.py ci-release + # pip install pytablewriter + # python scripts/editProperties.py ci-release diff --git a/docs/project-structure.md b/docs/project-structure.md index dba9f337cf..8de0367ac4 100644 --- a/docs/project-structure.md +++ b/docs/project-structure.md @@ -31,7 +31,7 @@ The ReproSchema is like a blueprint for research projects, ensuring everyone col - **Activity Level:** At this stage, an entire survey or tool, made up of many items, is grouped together as an "Activity." It gives a complete overview of what the survey involves. - **Protocols Level:** The highest level, a "Protocol," bundles together all the activities a participant will do in a study, providing a comprehensive plan. -- **[Validation](https://github.com/ReproNim/reproschema/tree/main/validation):** The schema uses special standards (like SHACL files) to make sure the data and forms are up to standard and consistent. +- **Validation:** The schema uses special standards (like SHACL files) to make sure the data and forms are up to standard and consistent. - **Context Files:** These files ([`contexts`](https://github.com/ReproNim/reproschema/tree/master/contexts)and [`terms`](https://github.com/ReproNim/reproschema/tree/master/terms)) specify user-interface details and enhance schema flexibility. They define elements like input types, visibility conditions, and response options, supporting a tailored user experience. Additionally, they enable internationalization and multiple language support for broad applicability. diff --git a/examples/activities/items/item2.jsonld b/examples/activities/items/item2.jsonld index d37c68c408..e149e1418e 100644 --- a/examples/activities/items/item2.jsonld +++ b/examples/activities/items/item2.jsonld @@ -14,7 +14,6 @@ "@type": "VideoObject", "contentUrl": "http://media.freesound.org/data/0/previews/719__elmomo__12oclock_girona_preview.mp4" }, - "imageUrl": "http://example.com/sample-image.jpg", "ui": { "inputType": "float" }, diff --git a/scripts/jsonParser.py b/scripts/jsonParser.py index b275f565d5..d3ef9c78cd 100644 --- a/scripts/jsonParser.py +++ b/scripts/jsonParser.py @@ -7,6 +7,7 @@ if os.path.basename(root) in schema_dirs: for name in files: with open(os.path.join(root, name)) as fp: + print(f" trying parsing {root}/{name} as json") try: tested += 1 json.load(fp) diff --git a/scripts/makeRelease.py b/scripts/makeRelease.py index 301d9d8a01..5a81ca88ef 100644 --- a/scripts/makeRelease.py +++ b/scripts/makeRelease.py @@ -10,7 +10,7 @@ def create_release(version): # read all the terms terms = [] - for root, dirs, files in os.walk("terms"): + for root, _, files in os.walk("terms"): for name in files: terms.extend(json.loads(to_newformat(os.path.join(root, name), "jsonld")))