Skip to main content

Behavioural verification of evolving systems under controlled variation.

Project description

Vigil

PyPi

Vigil is a small framework for behavioural verification under controlled variation.

It executes a system across declared variations, evaluates the resulting behaviour with checks, and records everything in a single structured report.
Vigil is system-agnostic and focuses on behavioural properties rather than performance benchmarks.

Running Vigil

Run Vigil on a project directory:

vigil [project_dir] [--trace]

Vigil opens an interactive menu to:

  • select a specification
  • run all variations and checks
  • inspect previous reports

Reports are written next to the specification file.

Project layout

A project directory contains:

  • exactly one backend
  • one or more specifications
  • optional local checks and variations
project/
  llm_backend.py
  language.yml
  prompts.yml
  checks/
    entity_types_agree.py
  variations/
    differ_language.py

Files ending in *.report.yml are treated as results, not specs.

Specification

A specification defines what behaviour is tested.

At minimum it contains:

  • hypothesis
  • inputs
  • variations
  • checks

Optional metadata:

  • title
title: Behavioural verification of DatsLlm with respect to language
hypothesis: Annotation behaviour remains stable across language routing

inputs:
  - text: "Hello world"

variations:
  - type: update_input_keys
    input:
      language: de

checks:
  - matches_baseline

Backend

A backend wraps the system under evaluation.

It combines:

  • function configuration (what is executed)
  • environment configuration (how and where it runs)

Backends implement:

update_environment(environment)
compute(input, function) -> output

The framework manages execution, isolation, and cleanup automatically.

Variations

Variations introduce controlled changes.

Each variation targets exactly one domain:

  • input
  • function
  • environment

Variations:

  • transform inputs or patch configuration
  • are applied explicitly and sequentially
  • never inspect outputs

Baseline execution is represented explicitly with none.

Vigil also supports a small convenience expansion:

variations: [{ type: repeat, times: N, do: [...] }]

This expands into a flat list by repeating the entries in do N times.

Syntactic sugar

The specification format provides light syntactic sugar for common patterns. This sugar expands into ordinary variations and does not add new semantics.

Supported forms include:

  • repetition of a variation block

These constructs exist purely to reduce duplication in specs. After parsing, the engine operates only on plain variations.

Checks

Checks evaluate observed behaviour.

Three intents exist:

  • unary
  • reference
  • group

Checks may be:

  • assertive (produce PASS / WARN / ERROR)
  • diagnostic (INFO only)

Checks operate only on recorded slices and never trigger execution.

Reports

Each run produces a single structured report containing:

  • metadata (title, hypothesis, timestamps)
  • backend configuration
  • all inputs and variations
  • all check results

Reports are YAML by default and meant for inspection, comparison, and archiving.

Vigil is intentionally small, explicit, and extensible.
New backends, variations, and checks can be added without modifying the core.

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

vigil_bv-0.1.0.tar.gz (21.4 kB view details)

Uploaded Source

Built Distribution

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

vigil_bv-0.1.0-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file vigil_bv-0.1.0.tar.gz.

File metadata

  • Download URL: vigil_bv-0.1.0.tar.gz
  • Upload date:
  • Size: 21.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vigil_bv-0.1.0.tar.gz
Algorithm Hash digest
SHA256 118f582278b0cf7e89411d7ea0e08932eb0bed0b5d1974421795575d23029f82
MD5 fd08ce014bc3c103adbf0d338bfd5243
BLAKE2b-256 5f78faf287ba7c910feed2f457f048ab340248d013fba0f79362133a13e90a2d

See more details on using hashes here.

Provenance

The following attestation bundles were made for vigil_bv-0.1.0.tar.gz:

Publisher: publish.yml on leo-lem/vigil

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

File details

Details for the file vigil_bv-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: vigil_bv-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vigil_bv-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 debabd25e26211ea292832f11f26fb6b1334de60f4196ea8f15979d8b726238f
MD5 047b6ebe13ca2ff9f1a91496d48a9ef1
BLAKE2b-256 0a02f05ab7e9b97426e8a35983046c65bbdf6f3b37683ca7beaeb62fbee4675e

See more details on using hashes here.

Provenance

The following attestation bundles were made for vigil_bv-0.1.0-py3-none-any.whl:

Publisher: publish.yml on leo-lem/vigil

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