Example BuildingSync files and tools for writing and validating BuildingSync use cases as schematron files.
Project description
testsuite
A tool for writing and validating BuildingSync use cases as Schematron files. See the BuildingSync use-cases repository for current Schematron and example files for particular use cases.
Command line validation
Setup
Install from pypi
pip install testsuite
Install from source
Poetry is required to install testsuite.
# Copy repo
git clone https://github.com/BuildingSync/TestSuite.git
# install the package
cd TestSuite
poetry install
# Test that it works, you should see a message describing the usage
poetry run testsuite
Usage
Python
from testsuite.validate_sch import validate_schematron
# run basic validation
# returns an array of testsuite.validate_sch.Failures
failures = validate_schematron('my_schematron.sch', 'my_xml.xml')
# save the svrl result file
failures = validate_schematron('my_schematron.sch', 'my_xml.xml', result_path='validation_result.svrl')
# run a specific phase in schematron
failures = validate_schematron('my_schematron.sch', 'my_xml.xml', phase='MyPhaseID')
# report unfired rules as errors
failures = validate_schematron('my_schematron.sch', 'my_xml.xml', strict_context=True)
# fetch a file from the use-cases repo and use it for validation
import urllib.request
schematron_url = 'https://raw.githubusercontent.com/BuildingSync/use-cases/main/SEED/schematron/SEED-1.0.0.sch'
schematron_filename = 'local_schematron.sch'
urllib.request.urlretrieve(schematron_url, filename=schematron_filename)
failures = validate_schematron(schematron_filename, 'my_xml.xml')
CLI
testsuite validate my_schematron.sch my_xml.xml
# see all options
testsuite validate --help
Development
Generate Schematron
First create a CSV file that meets the required structure:
phase title,phase see,pattern title,pattern see,rule title,rule context,assert test,assert description,assert severity,notes
See the CSV files in this repo for examples.
Hierarchy is implied by the lack of text in a column. If no phase data is added to a row, it's considered to be the same phase as the row above. If no pattern data is present, it's assumed to be the same pattern as above. If no rule context is given, it's assumed to be the same as the one above.
The generator expects a "exemplary" xml file which should pass the validation. This is used to make sure all rules are applied (schematron will skip rules if the rule context doesn't match or if it only matches nodes that have already been matched within that pattern). If no exemplary file is provided no rule context checks will be made.
poetry run testsuite generate path_to_csv [path_to_exemplary_xml]
Testing
poetry run pytest
To autoformat and check file formats run
poetry run pre-commit --all-files
Releasing
- Create a branch with the prepared release change log.
- Update version in
pyproject.toml - Create CHANGELOG in GitHub, paste in updates into CHANGELOG.md
- Run
pre-commitlocally, and commit back changes - Test as needed
- Merge release prep PR to develop
- To release, from the command line merge latest develop into latest main
git checkout main; git pull; git merge --ff-only origin develop. This will point the HEAD of main to latest develop. Then push the main branch to GitHub withgit push, which may require a developer with elevated privileges to push to main. - Back on GitHub create a new tag in GitHub against main and copy the change log notes into the tag description.
- Tag on GitHub, copy over the correct version (format vX.Y.Z) and CHANGELOG content.
- Verify the release was published to PyPI https://pypi.org/project/testsuite/
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file testsuite-0.1.5.tar.gz.
File metadata
- Download URL: testsuite-0.1.5.tar.gz
- Upload date:
- Size: 14.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6a7ee3adf8c831e43401a8c12a24053b1b8b010cda302f7edbbf21711c5b6a9b
|
|
| MD5 |
ae08b742d0edca653805c5463726cf01
|
|
| BLAKE2b-256 |
f758171952849c8fda888215a20ed6512e65f22811665c9bae4d3c176fbab583
|
Provenance
The following attestation bundles were made for testsuite-0.1.5.tar.gz:
Publisher:
pypi_release.yml on BuildingSync/TestSuite
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
testsuite-0.1.5.tar.gz -
Subject digest:
6a7ee3adf8c831e43401a8c12a24053b1b8b010cda302f7edbbf21711c5b6a9b - Sigstore transparency entry: 564048929
- Sigstore integration time:
-
Permalink:
BuildingSync/TestSuite@e70d2c626b45f5b74fb0a8722ac0c5b1ee8cab13 -
Branch / Tag:
refs/tags/v0.1.5 - Owner: https://github.com/BuildingSync
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi_release.yml@e70d2c626b45f5b74fb0a8722ac0c5b1ee8cab13 -
Trigger Event:
release
-
Statement type:
File details
Details for the file testsuite-0.1.5-py3-none-any.whl.
File metadata
- Download URL: testsuite-0.1.5-py3-none-any.whl
- Upload date:
- Size: 17.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dae0acb1bbabe9e8c8d4d5a05d28c3a02b94f35b4d3933a5603086cb58ac8f86
|
|
| MD5 |
18b837f619d0f0b743a6e68f4591b462
|
|
| BLAKE2b-256 |
34396e5df9301709e8c2f0d57d83a56c33f653f3d6b272d6a69f2fdd27cc6c2b
|
Provenance
The following attestation bundles were made for testsuite-0.1.5-py3-none-any.whl:
Publisher:
pypi_release.yml on BuildingSync/TestSuite
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
testsuite-0.1.5-py3-none-any.whl -
Subject digest:
dae0acb1bbabe9e8c8d4d5a05d28c3a02b94f35b4d3933a5603086cb58ac8f86 - Sigstore transparency entry: 564048944
- Sigstore integration time:
-
Permalink:
BuildingSync/TestSuite@e70d2c626b45f5b74fb0a8722ac0c5b1ee8cab13 -
Branch / Tag:
refs/tags/v0.1.5 - Owner: https://github.com/BuildingSync
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi_release.yml@e70d2c626b45f5b74fb0a8722ac0c5b1ee8cab13 -
Trigger Event:
release
-
Statement type: