Skip to main content

Shared workflows across CI/CD pipelines

Project description

CircleCI

Noos Invoke

Software development kit for sharing workflows across CI/CD pipelines.

Such a project aims to enforce parity and reproducability between local development and CI/CD workflows in remote containers (e.g. executable versions, command line calls, environment variables...) - developped with inv[oke].

Installation

Install the package from the PyPi repository:

```bash
$ pip install noos-inv
```

To enable shell completion, execute the following command (e.g. zsh),

```bash
$ noosinv --print-completion-script=zsh
```

And copy/paste its stdout into your shell config.

```bash
# NOOSINV completion script

_complete_noosinv() {
    collection_arg=''
    if [[ "${words}" =~ "(-c|--collection) [^ ]+" ]]; then
        collection_arg=$MATCH
    fi
    reply=( $(noosinv ${=collection_arg} --complete -- ${words}) )
}

compctl -K _complete_noosinv + -f noosinv
```

Finally, still in your shell config, enable automatic sub shell loading:

```bash
# ENV variable sub shell loading with command "source .env"

set -a
```

Usage as a command line tool

The noos-inv package installs a CLI binary, for managing common CI/CD tasks.

From the terminal,

```bash
$ noosinv

Usage: noosinv [--core-opts] <subcommand> [--subcommand-opts] ...

Subcommands:

docker.build       Build Docker image locally.
docker.buildx      Build and push x-platform Docker image to a remote registry.
docker.configure   Create and configure buildx builder for multi-platform.
docker.login       Login to Docker remote registry (AWS ECR or Dockerhub).
docker.pull        Pull Docker image from a remote registry.
docker.push        Push Docker image to a remote registry.
git.config         Setup git credentials with a Github token.
helm.install       Provision local Helm client (Chart Museum Plugin).
helm.lint          Check compliance of Helm charts / values.
helm.login         Login to Helm remote registry (AWS ECR or Chart Museum).
helm.push          Push Helm chart to a remote registry (AWS ECR or Chart Museum).
helm.test          Test local deployment in Minikube.
local.dotenv       Create local dotenv file.
local.ports        Forward ports for defined Kubernetes pods.
python.clean       Clean project from temp files / dirs.
python.coverage    Run coverage test report.
python.format      Auto-format source code.
python.lint        Run python linters.
python.package     Build project wheel distribution.
python.release     Publish wheel distribution to PyPi.
python.test        Run pytest with optional grouped tests.
terraform.run      Run a plan in Terraform cloud.
terraform.update   Update variable in Terraform cloud.
```

Source your environnement variables first for a seamless experience. (use command local.dotenv to create it from the provided template)

```bash
$ source .env
```

Special note on K8S port-forwards

Add the NOOSINV_LOCAL_CONFIG OS variable to your shell config, as the path to a local configuration file:

```json
{
    "podForwards": {
        "pod_1": {
            "podNamespace": "default",
            "podPrefix": "service-1-",
            "podPort": 80,
            "localPort": 8000
        },
        "pod_2": {
            "podNamespace": "test",
            "podPrefix": "service-2-",
            "podPort": 8080,
            "localPort": 8000,
            "localAddress": "0.0.0.0"
        }
    }
}
```

To start port forwarding a specific K8S cluster pod:

```bash
$ noosinv local.ports -p pod_1
```

To kill all previous port forward processes:

```bash
$ noosinv local.ports -u
```

Or previously opened port forward:

```bash
$ noosinv local.ports -p pod_1 -u
```

Development

Make sure poetry has been installed and pre-configured,

This project is shipped with a Makefile, which is ready to do basic common tasks.

```bash
$ make

help                           Display this auto-generated help message
update                         Lock and install build dependencies
clean                          Clean project from temp files / dirs
format                         Run auto-formatting linters
install                        Install build dependencies from lock file
lint                           Run python linters
test                           Run pytest with all tests
package                        Build project wheel distribution
release                        Publish wheel distribution to PyPi
```

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

noos_inv-0.2.10.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

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

noos_inv-0.2.10-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file noos_inv-0.2.10.tar.gz.

File metadata

  • Download URL: noos_inv-0.2.10.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.12.8 Linux/6.8.0-1031-aws

File hashes

Hashes for noos_inv-0.2.10.tar.gz
Algorithm Hash digest
SHA256 4d9b0f230b24b0865a666aeacfa96b2a0aa2d44ea6f0b4dc08340fbcb76d72a2
MD5 78a1c9ab5242396cc663ab52bea800cc
BLAKE2b-256 24f87efd92bbb84b558a9e9d28a6b03a3935bc44bbe19353a58f79d77a4be39a

See more details on using hashes here.

File details

Details for the file noos_inv-0.2.10-py3-none-any.whl.

File metadata

  • Download URL: noos_inv-0.2.10-py3-none-any.whl
  • Upload date:
  • Size: 14.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.12.8 Linux/6.8.0-1031-aws

File hashes

Hashes for noos_inv-0.2.10-py3-none-any.whl
Algorithm Hash digest
SHA256 2ba887fdfa8d607688ba5a206bacf2f73f16a1862731a8fb3ef3408f46ae9ddb
MD5 481bab3cc8f660fe9860c7287cc59455
BLAKE2b-256 d1d4acf6b42a79c869fd63089c6b061abd55f5ec91acec33736bd53791c3fcc9

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