Time and group logs for GitHub actions
Project description
gha-timer
Time and group logs for GitHub actions
Visit us at Fulcrum Genomics to learn more about how we can power your Bioinformatics with fetch-through-merge-base and beyond.
Motivation
This GitHub action and associated command-line tool enable log grouping and printing of the elapsed time
of that log group, with colored icons next to the elapsed based on the provided outcome (success, failure,
cancelled, or skipped).
Usage
jobs:
job:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: fulcrumgenomics/gha-timer@v1
- id: example
shell: bash
run: |
gha-timer start --name build
... do something
gha-timer elapsed --name build
Inputs
- uses: fulcrumgenomics/gha-timer@v1
with:
# The color of the success outcome
# Default: green
success-color: ''
# The icon to use for the success outcome
# Default: ✓
success-icon: ''
# The color of the failure outcome
# Default: red
failure-color: ''
# The icon to use for the failure outcome
# Default: ✕
failure-icon: ''
# The color of the cancelled outcome
# Default: yellow
cancelled-color: ''
# The icon to use for the cancelled outcome
# Default: ✕
cancelled-icon: ''
# The color of the skipped outcome
# Default: gray
skipped-color: ''
# The icon to use for the skipped outcome
# Default: ✕
skipped-icon: ''
# Skip emitting the banner
# Default: false
skip-banner: ''
Outputs
There are currently no outputs
Command Line Tool
Quickstart
Install command line tool:
pip install gha-timer
Start a timer:
$ gha-timer start
Get the elapsed time:
$ gha-timer elapsed --outcome success
✓ 10.8s
$ gha-timer elapsed --outcome failure
✕ 20.2s
$ gha-timer elapsed --outcome cancelled
✕ 33.6s
$ gha-timer elapsed --outcome skipped
✕ 37.3s
Stop the timer:
$ gha-timer stop
Use the --name option to add group log lines:
$ gha-timer start --name "Build the project"
::group::Build the project
$ gha-timer elapsed --outcome success --name "Build the project"
::endgroup::Build the project
✓ 19.2s
Specify a custom configuration file with --config (or just create a ~/.timerrc) to control the color and icon for
each outcome (steps.<step_id>.outcome: success, failure, cancelled, or skipped).
Below is the default configuration:
success:
color: green
icon: "✓"
failure:
color: red
icon: "✕"
cancelled:
color: yellow
icon: "✕"
skipped:
color: gray
icon: "✕"
Supported colors are: red, green, yellow, blue, cyan, bright_red, bright_green, white, gray,
and bg_grey.
Recommended Installation
Install the Python package and dependency management tool poetry using official documentation.
You must have Python 3.11 or greater available on your system path, which could be managed by mamba, pyenv, or another package manager.
Finally, install the dependencies of the project with:
poetry install
To check successful installation, run:
gha-timer --help
Installing into a Mamba Environment
Install the Python package and dependency management tool poetry and the environment manager mamba using official documentation.
Create and activate a virtual environment with Python 3.11 or greater:
mamba create -n gha_timer python=3.11
mamba activate gha_timer
Then, because Poetry will auto-detect an activated environment, install the project with:
poetry install
To check successful installation, run:
$ gha-timer start
$ gha-timer elapsed --outcome success
$ gha-timer stop
Development and Testing
See the contributing guide for more information.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gha_timer-1.1.0.tar.gz.
File metadata
- Download URL: gha_timer-1.1.0.tar.gz
- Upload date:
- Size: 10.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c8492ef8706b162d58804a476f2dcf662dedef1ce8dfe830831729bb5c3ab51a
|
|
| MD5 |
dad62eb5fa073a91846c6739367e166a
|
|
| BLAKE2b-256 |
0ceda3884785f6de3e43bb4c9f8e5a1ac0a447e4917617928f0e92754847d81c
|
Provenance
The following attestation bundles were made for gha_timer-1.1.0.tar.gz:
Publisher:
publish_gha_timer.yml on fulcrumgenomics/gha-timer
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gha_timer-1.1.0.tar.gz -
Subject digest:
c8492ef8706b162d58804a476f2dcf662dedef1ce8dfe830831729bb5c3ab51a - Sigstore transparency entry: 186193837
- Sigstore integration time:
-
Permalink:
fulcrumgenomics/gha-timer@6c2d3c71524c884b8b472fb888ff25fbc4d24e61 -
Branch / Tag:
refs/tags/v1.1.0 - Owner: https://github.com/fulcrumgenomics
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish_gha_timer.yml@6c2d3c71524c884b8b472fb888ff25fbc4d24e61 -
Trigger Event:
push
-
Statement type:
File details
Details for the file gha_timer-1.1.0-py3-none-any.whl.
File metadata
- Download URL: gha_timer-1.1.0-py3-none-any.whl
- Upload date:
- Size: 9.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8f809ef26fd1c9290692d41e4c05ff2eb83b476b281d3fa794f3c3e59faa3c91
|
|
| MD5 |
5cd2292395b0771a4fec3af0c701c64b
|
|
| BLAKE2b-256 |
d9c8272d6d1023a869a62c911ad1eaa5a57d3be426ff838e5a73a08d36d82aaf
|
Provenance
The following attestation bundles were made for gha_timer-1.1.0-py3-none-any.whl:
Publisher:
publish_gha_timer.yml on fulcrumgenomics/gha-timer
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gha_timer-1.1.0-py3-none-any.whl -
Subject digest:
8f809ef26fd1c9290692d41e4c05ff2eb83b476b281d3fa794f3c3e59faa3c91 - Sigstore transparency entry: 186193841
- Sigstore integration time:
-
Permalink:
fulcrumgenomics/gha-timer@6c2d3c71524c884b8b472fb888ff25fbc4d24e61 -
Branch / Tag:
refs/tags/v1.1.0 - Owner: https://github.com/fulcrumgenomics
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish_gha_timer.yml@6c2d3c71524c884b8b472fb888ff25fbc4d24e61 -
Trigger Event:
push
-
Statement type: