Skip to main content

Genesis CI Tools.

Project description

Genesis CI Tools

Helpful tools for Continuous Integration (CI) of Genesis projects. The tools are based on CLI utilities that simplify interacting with the Genesis installation. The main command is genesis-ci. It allows to create nodes, configs and other entities in the Genesis installations. For example, the genesis-ci nodes list command will list all nodes in the Genesis installation. genesis-ci --help will show all available commands.

📦 Installation

Install required packages:

Ubuntu:

sudo apt-get install libev-dev

Fedora:

sudo dnf install libev-devel

Initialize virtual environment with the package:

python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
pip install -e .

🚀 Usage

After installation the genesis-ci command will be available in the terminal. For example, genesis-ci nodes list will list all nodes in the Genesis installation. Below you can find most useful commands:

Create nodes with specified parameters:

genesis-ci -e http://127.0.0.1:11010 -u test -p test nodes add \
    --project-id 00000000-0000-0000-0000-000000000000 \
    --image "http://10.20.0.1:8080/genesis-base.raw" \
    --cores 4 \
    --ram 8192 \
    --root-disk 20 \
    --name "my-node"

List nodes:

genesis-ci -e http://127.0.0.1:11010 -u test -p test nodes list

List configs:

genesis-ci -e http://127.0.0.1:11010 -u test -p test configs list

Delete node:

genesis-ci -e http://127.0.0.1:11010 -u test -p test nodes delete 00000000-0000-0000-0000-000000000001

Configs from environment variables

One of the useful feature that need more explanation is the ability to create configs for nodes from environment variables. For this purpose we have genesis-ci configs add-from-env command. There are two formats of configurations that can be used to delivered to the node:

  • As environment variables
  • As plain text

In the environment variable all values should be placed in single file by path --env-path. To detect such variables the --env-prefix prefix will be used. The default value for this variable is GCT_ENV_. For example, if we have the variable GCT_ENV_FOO=bar it will be add to the config as FOO=bar on the node.

export GCT_ENV_FOO=bar

genesis-ci -e http://127.0.0.1:11010 -u test -p test configs add-from-env \
    --project-id <project-uuid> \
    <node-uuid>

# ... On the node ...

cat /var/lib/genesis/app.env

FOO=bar

Where /var/lib/genesis/app.env is default path. There are two supported formats for the env file: env and json, use option --env-format to set the format.

In the plain text we need to specify at least two variables for path and content.

export GCT_CFG_TEXT_FOO='My content!'
export GCT_CFG_PATH_FOO=/home/my-user/config.txt

genesis-ci -e http://127.0.0.1:11010 -u test -p test configs add-from-env \
    --project-id <project-uuid> \
    <node-uuid>

# ... On the node ...

cat /home/my-user/config.txt

My content!

--cfg-prefix set the prefix for config variables. The default value is GCT_CFG_. Also the content can be decoded from base64. Use --base64 flag to enable it.

💡 Contributing

Contributing to the project is highly appreciated! However, some rules should be followed for successful inclusion of new changes in the project:

  • All changes should be done in a separate branch.
  • Changes should include not only new functionality or bug fixes, but also tests for the new code.
  • After the changes are completed and tested, a Pull Request should be created with a clear description of the new functionality. And add one of the project maintainers as a reviewer.
  • Changes can be merged only after receiving an approve from one of the project maintainers.

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

genesis_ci_tools-0.0.3.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

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

genesis_ci_tools-0.0.3-py3-none-any.whl (16.5 kB view details)

Uploaded Python 3

File details

Details for the file genesis_ci_tools-0.0.3.tar.gz.

File metadata

  • Download URL: genesis_ci_tools-0.0.3.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for genesis_ci_tools-0.0.3.tar.gz
Algorithm Hash digest
SHA256 f22b7ff5de97256cc4a4dfa8f45e5bfb671d8bb75c8d0c30ac9bf997375be1f4
MD5 df8662e7df177824c74d094b9e6bf458
BLAKE2b-256 08a646306bbb5d9682689a681dac3a69ecd4bedceca17e392a8566e653d51a0d

See more details on using hashes here.

Provenance

The following attestation bundles were made for genesis_ci_tools-0.0.3.tar.gz:

Publisher: publish-to-pypi.yml on infraguys/genesis_ci_tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file genesis_ci_tools-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for genesis_ci_tools-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 c3b34472ef8b45a29a1dd22ca9fcf8dd0f01904fd7097766dc5484aacd01bef2
MD5 8675f937b42b64240a6fe4a87521c532
BLAKE2b-256 4eac26f287bbba9a63c5150cc6cf06c087c514c1b13e3ec396adaf5569806f9e

See more details on using hashes here.

Provenance

The following attestation bundles were made for genesis_ci_tools-0.0.3-py3-none-any.whl:

Publisher: publish-to-pypi.yml on infraguys/genesis_ci_tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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