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, PDF, 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.

To generate a starter config file in the current directory, run:

vault88 --init-config

This writes vault88.conf with width = 100, template = blueprint, and a disabled entry for every built-in reporter. Move the file to ~/.vault88.conf or pass it via --config vault88.conf to activate it.

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
blueprint Use the built-in BlueprintTemplate (box-framed stage headers, symbol-prefixed steps)
diagnostic Use the built-in DiagnosticTemplate (compiler/linter-style output with outcome-coloured bullets)
token Use the built-in TokenTemplate (keyword-coloured stage headers, right-aligned timestamps)
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.pdf_reporter
class = PdfReporter
enabled = true
output_dir = ./reports

[REPORTER3]
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.4.tar.gz (45.9 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.4-py3-none-any.whl (38.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: vault88-0.3.4.tar.gz
  • Upload date:
  • Size: 45.9 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.4.tar.gz
Algorithm Hash digest
SHA256 5a0d2fb069327d58abb7aecb8483630e2ebd42ccf59eed796b55540cd49f5aaa
MD5 67f2d2414013bfba0d47a0fabbfaaeeb
BLAKE2b-256 49ef62fd0b4dcaa83740af180a6ba751c71de7d3d1262e26c1410808ace86b18

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vault88-0.3.4-py3-none-any.whl
  • Upload date:
  • Size: 38.6 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a3dc13997fa987160445753c1d77ea6ae05f55524341c86c22fcef0aa3aa8ac8
MD5 f034246bbb9b910415becdb9cf12f8c3
BLAKE2b-256 d3a761df3df96ef43efe010081892fd3c3c2b30b81799699210c693d45c05804

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