Skip to main content

Python automated test framework

Project description

vault88

vault88 is a Python automated test framework designed for structured hardware and software validation in CI/CD pipelines. Tests are written as Python classes, organised into stages, and results can be published through configurable reporters.

Architecture

Component Role
Loader Discovers test classes from files or directories; supports tag-based include/exclude filtering
Logger Centralised logging with rotating file handler and optional verbose (debug) output
Runner Instantiates and executes a test class through its full lifecycle: selfChecksetuprunteardown
Reporter Pluggable reporters loaded from the config file; built-in reporters include JUnit XML and log archive

Test results are grouped into named stages within each test, and each result records an action, expected value, actual value, outcome, timestamp, and optional requirement references.

Installation

pip install vault88

Or with uv:

uv add vault88

Writing a test

Subclass Test and implement the four lifecycle methods:

from vault88 import Test

class MyTest(Test):
    name = "My Test"
    tags = ["smoke"]

    def selfCheck(self) -> bool:
        # Return False to skip the test entirely
        return True

    def setup(self) -> bool:
        # Prepare resources; return False to abort
        return True

    def run(self) -> None:
        self.newStage("Basic checks")
        self.assertEqual("Verify result", expected=42, actual=compute())

    def teardown(self) -> None:
        pass

Available assertion helpers: assertEqual, assertNotEqual, assertTrue, assertFalse, assertGreaterThan, assertLessThan, assertGreaterThanOrEqual, assertLessThanOrEqual, assertIn, assertNotIn, assertIsNone, assertIsNotNone.

Running tests

vault88 <testpath> [options]
Option Description
testpath Path to a test file or directory
-t TAG [TAG ...] Only run tests that have at least one of these tags
-nt TAG [TAG ...] Exclude tests that have any of these tags
-r Recursively search directories for tests
-l FILE Log file path (default: ./test_execution.log)
-v Verbose / debug logging
--env PATH_OR_URL Load an environment from a JSON file or HTTP(S) URL
--junit Generate a testresults.xml JUnit report in the current directory

Environments

An environment passes host addresses, service details, and credentials into tests at runtime so the same test class can run against different targets without code changes.

Environment file format

Environments are defined as JSON. The top-level hosts list is the main entry point; each host can carry services and credentials:

{
  "name": "staging",
  "hosts": [
    {
      "name": "app-server",
      "address": "10.0.1.10",
      "credential": {
        "username": "deploy",
        "key_path": "/home/ci/.ssh/id_rsa"
      },
      "services": [
        {
          "name": "api",
          "port": 8080,
          "url": "http://10.0.1.10:8080"
        }
      ]
    }
  ]
}

All fields other than name and address (on a host) are optional.

Loading an environment

Pass the file path or an HTTP(S) URL to --env:

# from a local file
vault88 tests/ --env ./staging.json

# from an API endpoint
vault88 tests/ --env https://inventory.example.com/envs/staging

The API loader expects the endpoint to return the same JSON structure.

Using the environment in a test

The loaded Environment object is available as self.environment. Walk the hosts list or look up a host by name:

from vault88 import Test

class DeploymentTest(Test):
    name = "Deployment smoke test"
    tags = ["smoke"]

    def selfCheck(self) -> bool:
        return self.environment is not None

    def setup(self) -> bool:
        return True

    def run(self) -> None:
        self.newStage("Connectivity")

        host = next(h for h in self.environment.hosts if h.name == "app-server")
        api = next(s for s in host.services if s.name == "api")

        response = requests.get(f"{api.url}/health")
        self.assertEqual("Health endpoint returns 200", expected=200, actual=response.status_code)

    def teardown(self) -> None:
        pass
Attribute Type Description
environment.name str Environment name from the JSON
environment.hosts List[Host] All hosts in the environment
host.name str Host label
host.address str IP address or hostname
host.credential Credential | None SSH or login credential for the host
host.services List[Service] Services running on the host
service.name str Service label
service.port int | None Port number
service.url str | None Full URL
service.credential Credential | None Service-specific credential
credential.username str Username
credential.password str | None Password
credential.key_path str | None Path to a private key file

Configuration

The config file is read from the first location found: --config PATH (CLI flag) → ~/.vault88.conf/etc/vault88.conf. It uses INI format.

Console output

All terminal output is rendered through a console template. Configure it in the [CONSOLE] section of the config file.

Selecting a template

[CONSOLE]
template = default
Value Effect
default (or omitted) Use the built-in DefaultTemplate
mypackage.console.MyTemplate Load a custom template class by its full dotted Python path

If the custom class cannot be imported, vault88 logs a warning and falls back to DefaultTemplate.

DefaultTemplate options

Key Default Description
width auto-detected Output width in characters (falls back to 80 if terminal detection fails)
stage_color (none) ANSI color applied to stage header lines
step_color (none) ANSI color applied to the Step N-N: prefix
timestamp_format %H:%M:%S strftime format string for step timestamps
timestamp_position field Where timestamps appear: field (own line) or inline (after step number)

Available color names: black, red, green, yellow, blue, magenta, cyan, white, bright_black, bright_red, bright_green, bright_yellow, bright_blue, bright_magenta, bright_cyan, bright_white.

[CONSOLE]
width = 120
stage_color = cyan
step_color = bright_blue
timestamp_format = %Y-%m-%d %H:%M:%S
timestamp_position = inline

See docs/console-templates.md for the full template API and a custom template example.

Reporters

Each [REPORTER<n>] section loads one reporter:

[REPORTER1]
module = vault88.core.reporters.junit_reporter
class = JUnitReporter
enabled = true
suite_name = My Project Tests

[REPORTER2]
module = vault88.core.reporters.log_archive_reporter
class = LogArchiveReporter
enabled = true
output_dir = ./logs

License

MIT License

Copyright (c) 2025 Brad Murdoch

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

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

vault88-0.3.3.tar.gz (39.2 kB view details)

Uploaded Source

Built Distribution

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

vault88-0.3.3-py3-none-any.whl (34.2 kB view details)

Uploaded Python 3

File details

Details for the file vault88-0.3.3.tar.gz.

File metadata

  • Download URL: vault88-0.3.3.tar.gz
  • Upload date:
  • Size: 39.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"26.04","id":"resolute","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for vault88-0.3.3.tar.gz
Algorithm Hash digest
SHA256 97585a1fbbc9e649c8c0f5c238ce9d45bdb38605003e456c1c7b05e99ea0b42c
MD5 3268b6ac958b8edbd65585177e2535d9
BLAKE2b-256 bcdef7d5919535eefd1117dfeea2a0c539533b6d7a7017c4afd3f039e30c5130

See more details on using hashes here.

File details

Details for the file vault88-0.3.3-py3-none-any.whl.

File metadata

  • Download URL: vault88-0.3.3-py3-none-any.whl
  • Upload date:
  • Size: 34.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"26.04","id":"resolute","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for vault88-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e56326f380ce33dc353c8e76b0126a9aa128431e540205f0704963f3b7506e26
MD5 e7f560ec47720264e26e921200dd9ce5
BLAKE2b-256 622a452d1a6c9cbff43d974292392ec6a7228f89fc3ff007a7a65adc37f0e31c

See more details on using hashes here.

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