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.2.tar.gz (27.0 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.2-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: precice_config_check-1.0.2.tar.gz
  • Upload date:
  • Size: 27.0 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.2.tar.gz
Algorithm Hash digest
SHA256 66be3db19833eafe9e49027c752e53bd5ec71b98325dbb846b24f9a79d0cccea
MD5 fb887c1454c2fb0c9b92501dbd9ec06a
BLAKE2b-256 eb21c01b5714542212b52ef2596b2a4755096b263cb483399995f0c0d2cd5d21

See more details on using hashes here.

Provenance

The following attestation bundles were made for precice_config_check-1.0.2.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.2-py3-none-any.whl.

File metadata

File hashes

Hashes for precice_config_check-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fbe3a67a78b3cd4f02c88663ce5392ed70eee042f275b19e1eb26c22166641fd
MD5 0f1306c9b8006edb510f2c8b95703fe9
BLAKE2b-256 ba9332e5d9fa96d5561f4f66891deb11bd4e186ce29a5759b5fb6d94ed715d5d

See more details on using hashes here.

Provenance

The following attestation bundles were made for precice_config_check-1.0.2-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