Skip to main content

No project description provided

Project description

preCICE Config Checker

A library that checks a preCICE configuration file for logical errors.

How does this differ from precice-tools check? This checker only checks the configuration for logical errors.

[!NOTE] This checker assumes that precice-tools check has already been executed without an error on the configuration file.
Otherwise, the behavior of this checker is undefined.

Requirements

Installation

  1. Clone this repository:
git clone https://github.com/precice/config-check
cd config-check
  1. Create a new Python Virtual Environment (optional, but recommended):
python -m venv venv
source venv/bin/activate  # On Windows, use `venv\Scripts\activate`
  1. Install required dependencies:
pip install .

You need to force re-install the precice_config_graph-dependency on new versions, since it is downloaded directly from GitHub. To do so, run:

pip install --ignore-installed .

Project Structure

config-check
├── .github, .idea, etc…
│
├── docs                       # Documentation on rules and the inner workings of this checker
│   └── ...
│
├── preciceconfigcheck         # Main library files
│   ├── rules                  # All rules that are checked by this utility
│   │   ├── ...
│   │   └── examples           # Exemplary implementations of rules to test output format
│   │       └── ...
│   │
│   ├── tests                  # Configuration files to test rules
│   │   └── ...
│   │
│   ├── cli.py                 # Main entrypoint for this checker
│   ├── color.py               # Definition of colors for CLI output
│   ├── rule.py                # Class of a rule and logic to check all rules
│   ├── rules_processing.py    # Processes rules and handles output
│   ├── rules_utils.py         # Utility functions for rules
│   ├── severity.py            # Enum for specifying severity of output
│   └── violation.py           # Class of a violation
│
│
├── .gitignore, LICENSE, README.md
│
├── pyproject.toml             # Project configuration (dependencies etc.)
└── shell.nix                  # Dependencies for anyone using NixOS / the nix-package manager. Should be replaced by a flake in the future.

Checking a preCICE config

To check a preCICE configuration file for logical errors, run the following within the root of this repository:

python -m preciceconfigcheck.cli "path/to/precice-config.xml"

If you want more information about the checks that were performed and their results, use

python -m preciceconfigcheck.cli "path/to/precice-config.xml" --debug

Suggesting new Rules

We are always open to suggestions for new rules. When encountering a logical error that does not already get reviewed by our checker, please create a new issue on our GitHub repository and:

  • Check that the problem is not already under development (marked with TODO in docs/Rules.md)
  • Explain the problem:
    • What exactly is the problem?
    • Why is it a problem?
    • Are there cases when this setup is valid?
    • Please also provide a precice-config.xmlfile with the error you described and one with a fix of how it should be

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

precice_config_check-1.0.1.tar.gz (26.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

precice_config_check-1.0.1-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

Details for the file precice_config_check-1.0.1.tar.gz.

File metadata

  • Download URL: precice_config_check-1.0.1.tar.gz
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for precice_config_check-1.0.1.tar.gz
Algorithm Hash digest
SHA256 c9a845920bb74100bfa3e30afd495b9120ea253b5f4266994ee329684022667c
MD5 1206cca0eb747fd4cac89f2f8e106c86
BLAKE2b-256 e76a7cd26667babbaa0aa1347bdc18922adb2ce0b1a7d78bbde0a70dc7204a39

See more details on using hashes here.

Provenance

The following attestation bundles were made for precice_config_check-1.0.1.tar.gz:

Publisher: release.yml on precice/config-check

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file precice_config_check-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for precice_config_check-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bac77b40134b4646b8ace369429e67113697e9ac9d550a93727c0f4aa4464362
MD5 c728012933ca00a49b2c38546bb68a31
BLAKE2b-256 9bb55118d64b6e5c80d912f56dc1b90b0d62e6f0fddd0b60589777a08067424a

See more details on using hashes here.

Provenance

The following attestation bundles were made for precice_config_check-1.0.1-py3-none-any.whl:

Publisher: release.yml on precice/config-check

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page