rocrate-validator (available as roc-validator on PyPI) is a Python package to validate RO-Crates
against different profiles, including the base RO-Crate profile and various extensions.
- Validates RO-Crates against the profiles they declare to conform to. Currently, validation for the following profiles is implemented:
- Filters profile validation rules by requirement level (i.e., REQUIRED,RECOMMENDED,OPTIONAL).
- Provides detailed information about the issues found during validation.
- Supports validation of RO-Crates stored locally as directories or as ZIP archives (.zipfiles) or remotely accessible via HTTP or HTTPS (e.g.,http://example.com/ro-crate.zip).
- Supports CLI-based validation as well as programmatic validation (so it can easily be used by Python code).
- Extensible framework: new RO-Crate profiles can be added, implementing profile requirements as SHACL shapes and/or Python code.
You can install the package using pip or poetry. The following instructions assume you have Python 3.9 or later installed.
It’s recommended to create a virtual environment before installing the package to avoid dependency conflicts. You can create one using the following command:
python3 -m venv .venvThen, activate the virtual environment:
- On Unix or macOS:
source .venv/bin/activate- On Windows (Command Prompt):
.venv\Scripts\activate- On Windows (PowerShell):
.venv\Scripts\Activate.ps1You can install the package using pip:
pip install roc-validatorClone the repository:
git clone https://github.com/crs4/rocrate-validator.gitNavigate to the project directory:
cd rocrate-validatorEnsure you have Poetry installed. If not, follow the instructions here. Then, install the package using poetry:
poetry installAfter installation, use the rocrate-validator command to validate RO-Crates. You can run this in an active virtual environment (if created in the optional step above) or without a virtual environment if none was created.
Run the validator using the following command:
rocrate-validator validate <path_to_rocrate>where <path_to_rocrate> is the path to the RO-Crate you want to validate.
Type rocrate-validator --help for more information.
Run the validator using the following command:
poetry run rocrate-validator validate <path_to_rocrate>where <path_to_rocrate> is the path to the RO-Crate you want to validate.
Type rocrate-validator --help for more information.
You can also integrate the package programmatically in your Python code.
Here's an example:
# Import the `services` and `models` module from the rocrate_validator package
from rocrate_validator import services, models
# Create an instance of `ValidationSettings` class to configure the validation
settings = services.ValidationSettings(
    # Set the path to the RO-Crate root directory
    rocrate_uri='/path/to/ro-crate',
    # Set the identifier of the RO-Crate profile to use for validation.
    # If not set, the system will attempt to automatically determine the appropriate validation profile.
    profile_identifier='ro-crate-1.1',
    # Set the requirement level for the validation
    requirement_severity=models.Severity.REQUIRED,
)
# Call the validation service with the settings
result = services.validate(settings)
# Check if the validation was successful
if not result.has_issues():
    print("RO-Crate is valid!")
else:
    print("RO-Crate is invalid!")
    # Explore the issues
    for issue in result.get_issues():
        # Every issue object has a reference to the check that failed, the severity of the issue, and a message describing the issue.
        print(f"Detected issue of severity {issue.severity.name} with check \"{issue.check.identifier}\": {issue.message}")The following is a possible output:
RO-Crate is invalid!
Detected issue of severity REQUIRED with check "ro-crate-1.1:root_entity_exists: The RO-Crate must contain a root entity.To run the rocrate-validator tests, use the following command:
poetry run pytestThis project is licensed under the terms of the Apache License 2.0. See the LICENSE file for details.
This work has been partially funded by the following sources:
- the BY-COVID project (HORIZON Europe grant agreement number 101046203);
- the LIFEMap project, funded by the Italian Ministry of Health (Piano Operative Salute, Trajectory 3).
- the Italian Research Center on High Performance Computing, Big Data and Quantum Computing - Spoke 9.
