Skip to main content

health checks module

Project description

certificate

Bravo! You have received a Medical Diploma in "volts" from
the Orbital Convergence University International Air and Water
Embassy of the Tangerine Planet ๐ŸŠ.

You are now officially certified to include "volts" in your
practice.


๐Ÿ volts


CircleCI


๐Ÿฅง description

This module can monitor the health status of a python3 .py biome.


โ›ฒ licensing

GNU General Public License v3.0 - GNU Project - Free Software Foundation (FSF)

The complete license is included in the module
in the "./__license/options" directory.


โ›‘๏ธ install

This utilizes:
https://pypi.org/project/xonsh

[xonsh] pip install volts

โš•๏ธ internal status monitor of the module

To monitor the internal status of the "volts" module:

[xonsh] volts internal-status

These checks are run with pypi "body_scan";
"volts" is built from a fork of "body_scan".

The "body_scan" checks are written with "unittest".


๐Ÿ“– documentation

[xonsh] volts help 

This opens a server process that can be opened in a browser.


๐ŸŒŒ Tutorial

The structure

๐Ÿ“ performance
	๐Ÿ“œ status_1.py

The checks

# status_1.py

def check_1 ():
	print ("check 1")
	
def check_2 ():
	print ("check 2")
	
def check_3 ():
	raise Exception ("not 110%")

checks = {
	"check 1": check_1,
	"check 2": check_2,
	"check 3": check_3
}

The procedure

From the performance directory,

[xonsh] volts status

The report

This is the report that is (hopefully) written to the terminal.

paths: [
	{
		"path": "status_1.py",
		"empty": false,
		"parsed": true,
		"stats": {
			"passes": 2,
			"alarms": 1
		},
		"checks": [
			{
				"check": "check 1",
				"passed": true,
				"elapsed": [
					4.054199962411076e-05,
					"seconds"
				]
			},
			{
				"check": "check 2",
				"passed": true,
				"elapsed": [
					1.72930003827787e-05,
					"seconds"
				]
			},
			{
				"check": "check 3",
				"passed": false,
				"exception": "Exception('not 110%')",
				"exception trace": [
					"Traceback (most recent call last):",
					"  File \"/volts/processes/scan/process/keg/check.py\", line 68, in start",
					"    checks [ check ] ()",
					"  File \"<string>\", line 13, in check_3",
					"Exception: not 110%"
				]
			}
		]
	}
]
alarms: [
	{
		"path": "status_1.py",
		"checks": [
			{
				"check": "check 3",
				"passed": false,
				"exception": "Exception('not 110%')",
				"exception trace": [
					"Traceback (most recent call last):",
					"  File \"/volts/processes/scan/process/keg/check.py\", line 68, in start",
					"    checks [ check ] ()",
					"  File \"<string>\", line 13, in check_3",
					"Exception: not 110%"
				]
			}
		]
	}
]
stats: {
	"alarms": 0,
	"empty": 0,
	"checks": {
		"passes": 2,
		"alarms": 1
	}
}

Notes

  • Checks are started simultaneously, unless --simultaneous no

    • [xonsh] volts status --simultaneous no
  • The fractory glob pattern is "**/status_*.py", but can be changed with --glob-string

    • [xonsh] volts status --glob-string "**/performance_*.py"

Advanced Tutorial

It's recommended to run volts in a .py script.

An example of this can be found in the "_book/advanced tutorial"
section of the documentation.


๐Ÿ“ก Contacts

Bryan@Status600.com

๐ŸŒ‘ ๐ŸŒ˜ ๐ŸŒ— ๐ŸŒ– ๐ŸŒ• ๐ŸŒ” ๐ŸŒ“ ๐ŸŒ’ ๐ŸŒ‘

๐ŸŒ‘ ๐ŸŒ’ ๐ŸŒ“ ๐ŸŒ” ๐ŸŒ• ๐ŸŒ– ๐ŸŒ— ๐ŸŒ˜ ๐ŸŒ‘

๐ŸŒ‘ ๐ŸŒ˜ ๐ŸŒ— ๐ŸŒ– ๐ŸŒ• ๐ŸŒ” ๐ŸŒ“ ๐ŸŒ’ ๐ŸŒ‘

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

volts-1.1.1.tar.gz (139.3 kB view details)

Uploaded Source

Built Distribution

volts-1.1.1-py3-none-any.whl (258.5 kB view details)

Uploaded Python 3

File details

Details for the file volts-1.1.1.tar.gz.

File metadata

  • Download URL: volts-1.1.1.tar.gz
  • Upload date:
  • Size: 139.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.10.12 Linux/6.5.0-27-generic

File hashes

Hashes for volts-1.1.1.tar.gz
Algorithm Hash digest
SHA256 3e8ca805b6a1239543c353fca2262da5e9624ef4dc27863a3aea4d367b229273
MD5 2f2092dde3265ef0d76e172ce4190d74
BLAKE2b-256 7283e8d2aca0845118f5bf338a542fa39533ba1a77dc4b533407f43343bd9d77

See more details on using hashes here.

File details

Details for the file volts-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: volts-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 258.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.10.12 Linux/6.5.0-27-generic

File hashes

Hashes for volts-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6c6654c9e7b9fd0be5a5682e0bf11e076cd213d2d020c5fc3106af9eb40296aa
MD5 59b7578dba6c4653da7c2c50c445d5af
BLAKE2b-256 3e25700b165f02f7ab149cb719cf119f3f08d84e89c1d25391beb9cbeb0d6c4f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page