Skip to main content

Open Source Sanity Checking framework

Project description

Athena: Sanity Checking Framework

PythonVersion PyPi License

Athena is a versatile sanity checking framework designed to simplify the process of creating and running validation procedures, known as Sanity-Check. These checks can be executed in any software environments with Python interpreters, especially in DCC (Digital Content Creation) software, or in standalone across all operating systems.

Getting Started

To quickly get started with Athena, follow these steps:

Prerequisites

Ensure you have Python 3.8+ installed. Athena has no external dependencies.

Installing

You can install Athena using pip:

pip install athena-sanity

Or download the latest release here.

Usage Example

You can load a Blueprint and run all it's processes, or query one single process to run: When part of a Blueprint, a Process can have extra configuration to modify it's behavior or interaction with other processes within the blueprint.

from athena import atCore

register = atCore.AtSession().register
register.load_blueprint_from_python_import_path('athena.examples.blueprint.exampleBlueprint')
blueprint = register.blueprint_by_name('exampleBlueprint')
# processor = blueprint.processor_by_name('exampleProcess')  # To get a single `Processor` from the `Blueprint`.

for processor in blueprint.processors:
    result = processor.check()
    
    for container in result:
        print(container, container.status)
        for feedback in container:
            print('\t' + str(feedback))

Alternatively, you can skip the blueprint and just run a process with a default configuration or use your own by passing extra arguments to the Processor:

from athena import atCore

# The `Processor` takes full import path to the `Process` class. The same way you'd define it in the `Blueprint`.
processor = atCore.Processor('athena.examples.process.exampleProcess.AthenaExampleProcess')

result = processor.check()
for container in result:
    print(container, container.status)
    for feedback in container:
        print('\t' + str(feedback))

You can find examples on how to write a Process or Blueprint here

Running the Tests

Full support for unit test will come later.

Versioning

Athena follows the principles of Semantic Versioning (SemVer). Check the tags on this repository for available versions.

Authors

  • Gregory Pijat - Author - GitHub

See the list of contributors who participated in this project.

License

This project is licensed under the GPL-3.0 License - see the LICENSE file for details.

More

For an enhanced experience, check out the available UI on Gumroad. (Available soon)

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

athena_sanity-0.1.0b3.tar.gz (53.2 kB view details)

Uploaded Source

Built Distribution

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

athena_sanity-0.1.0b3-py3-none-any.whl (56.0 kB view details)

Uploaded Python 3

File details

Details for the file athena_sanity-0.1.0b3.tar.gz.

File metadata

  • Download URL: athena_sanity-0.1.0b3.tar.gz
  • Upload date:
  • Size: 53.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.7

File hashes

Hashes for athena_sanity-0.1.0b3.tar.gz
Algorithm Hash digest
SHA256 cc5b890a4ebf7342eb52a41a77c6661531a1fa9ac8716d2c5b4719e2d3d426b1
MD5 08254e6c83063d274fc760909856772e
BLAKE2b-256 3343f20340939d1dd923b39d3fdd3d765d6af69db793c599106eb38a8720f274

See more details on using hashes here.

File details

Details for the file athena_sanity-0.1.0b3-py3-none-any.whl.

File metadata

File hashes

Hashes for athena_sanity-0.1.0b3-py3-none-any.whl
Algorithm Hash digest
SHA256 6eaa414477ec7052fad7a3c735354d51aad54ac24ba8b12c0e5d0d0b60ea534e
MD5 41b8b6529947b26e7048bbe2390f72ae
BLAKE2b-256 0f30b1f6bbd75b3bbdcf5e688f8a880c1f19d10ea487c276400389a711ff6c1c

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