Skip to main content

Future Agile CICD tooling template

Project description

agileetc

Example python 3.9+ project where we can develop best practices and provide teams with a useful template with the following features:

  • Poetry packaged python project with example CLI entry point.
  • Linux and Windows compatible project.
  • Example read/write YML files.
  • Example Unit Tests.
  • Example flake8 linter configuration.
  • Example line operation via click API allowing project to be run from command line of from CICD pipelines.
  • Example use of Fabric API to execute external commands.
  • Example use of Texttable for pretty table output.
  • Example GoCD pipeline.
  • Example GitHub actions.
  • Python package publishing to PiPy.
  • Docker image publishing to docker hub.
  • Example usage of python package.
  • Example usage of docker image.

Prerequisites

This project uses poetry is a tool for dependency management and packaging in Python. It allows you to declare the libraries your project depends on, it will manage (install/update) them for you.

Use the installer rather than pip installing-with-the-official-installer.

poetry self add poetry-bumpversion
poetry -V
Poetry (version 1.2.0)

Getting Started

poetry update
poetry install

Run

poetry run agileetc

Lint

poetry run flake8

Test

poetry run pytest

Publish

  • By default we are using PYPI packages.
  • Create yourself an access token for PYPI and then follow the instructions.
export PYPI_USERNAME=__token__ 
export PYPI_PASSWORD=<Your API Token>
poetry publish --build --username $PYPI_USERNAME --password $PYPI_PASSWORD

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

Releasing

We are using poetry-bumpversion to manage release versions.

poetry version patch

Dependency

Once the release has been created it is now available for you to use in other python projects via:

pip install agileetc

And also for poetry projects via:

poetry add aigleetc

Continuous Integration

The objects of each of the example CI pipelines here are to:

  • Lint the python code.
  • Run Unit Tests
  • Build package.
  • Release package, bumping the version.
  • Publishing in new package version.

GitHub Actions

The example GitHub actions CI for this project is located in file .github/workflows/python-ci.yml and is available from the GitHub dashboard. This CI is setup to run via a local runner which should be configured.

Jenkins

GoCD

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

License

This project is licensed under the Apache License, Version 2.0 - see the LICENSE file for details

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

agileetc-0.0.11.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

agileetc-0.0.11-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

File details

Details for the file agileetc-0.0.11.tar.gz.

File metadata

  • Download URL: agileetc-0.0.11.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.0 CPython/3.9.2 Linux/5.18.0-14parrot1-amd64

File hashes

Hashes for agileetc-0.0.11.tar.gz
Algorithm Hash digest
SHA256 dd15556a33571707d73563a443602ddae349e7be73a038cda251b1b3805a8790
MD5 8c5442ccb3bf0816b98ec68ae6f21e66
BLAKE2b-256 e79954b5fd3ee0b97e39a21fc2f7935f07094faf388b73352152a3ac3ac33b2a

See more details on using hashes here.

File details

Details for the file agileetc-0.0.11-py3-none-any.whl.

File metadata

  • Download URL: agileetc-0.0.11-py3-none-any.whl
  • Upload date:
  • Size: 5.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.0 CPython/3.9.2 Linux/5.18.0-14parrot1-amd64

File hashes

Hashes for agileetc-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 1a633287067a8ad89de0c5fb57c5c7cc91dfb4e693f9e922654b0ead39cb6c57
MD5 28f93f61e4b3a526aa31c4eef0e7e3c7
BLAKE2b-256 40de13c7cd4e6a50e5530a56f30fec8f2fbf2616758f49852aacd8f643fd43bf

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