Skip to main content

Simple monorepo build tool

Project description

drkns is a simple build tool aimed at easing the continuous integration of monorepos through the use of caching.

Build Status

Build is driven through YAML files, that can have dependencies over other YAML files.

  • Steps are built after the dependencies.
  • A failure at a step prevents the execution of the next one.
  • The result of each execution step is cached, if a directory is left unchanged no execution will be triggered again.
  • State can be persisted in Amazon S3 to have a shared memory between volatile build instances

Sample master drkns.yml

drkns.yml

dependencies:
  sub1: subProject1/drkns.yml

Sample dependency drkns.yml

subProject1/drkns.yml

checkSteps:
  buildImages: |
       docker build -q -t ...

  startContainers: "docker run --network host --name test -d backServer-test"

YAML reference

  • directory: Current directory by default, only used to compute the hash associated with this build file
  • dependencies: named external drkns yml to load, their steps becomes callables through drkns dependencyName.stepName
  • checkSteps: ordered and named commands. Commands are either a string, or have two keys: command (string) and background (bool default false)
  • buildSteps: same as checkSteps, but those are executed only if checkSteps and dependencies' checkSteps got processed without errors.
  • cleanUpSteps: same as checkSteps, but those are executed no matter the execution of the previous ones.

CLI interface

The command line interface offers the following commands:

# Checks that the configuration makes sense (no output is a good sign
drkns check

# List all steps
drkns list

# Restore previous execution information from S3
# Assuming an environment variable DRKNS_S3_PATH exists under the form 
# "s3://buck3t/d1r" 
drkns sync in

# also available for something like
# drkns sync in s3://buck3t/d1r

# Runs all steps
drkns run 

# Runs identified task
drkns run sub1.buildImages

# Runs all steps but returns 0 no matter what happens 
drkns run --force-success

# Return the last `drkns run` to get the execution status 
drkns run

# Willing to have only the step statuses and not the failed output 
drkns run --summary

# Clean persisted data older than a week old when there is more than a few
# (to not overload the cache after too many builds)
drkns clean

# Persist previous execution information from S3, see assumptions for sync in
# Beware this erase extra files 
drkns sync out

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

drkns-1.2.1.tar.gz (13.1 kB view details)

Uploaded Source

Built Distribution

drkns-1.2.1-py3-none-any.whl (18.4 kB view details)

Uploaded Python 3

File details

Details for the file drkns-1.2.1.tar.gz.

File metadata

  • Download URL: drkns-1.2.1.tar.gz
  • Upload date:
  • Size: 13.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/51.0.0 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.8.2

File hashes

Hashes for drkns-1.2.1.tar.gz
Algorithm Hash digest
SHA256 23adf98dc0362cf3747a33329a63471d569bd9d62622f08f520a9d8d09bb567d
MD5 b2bc326834c48c9f851706646d06e670
BLAKE2b-256 1d3b9391b85012611677d94083421e78c89a517a76a75c448950a3bf4682e97e

See more details on using hashes here.

File details

Details for the file drkns-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: drkns-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 18.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/51.0.0 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.8.2

File hashes

Hashes for drkns-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3116cf345fe3f05021ef88973f5e9b961a80851ded61b894a094c4c32b9b56aa
MD5 11e532c93fa1e3e389843d0b47cfc788
BLAKE2b-256 4a4ddf6888b3f2c830407d2e5d475591bc06f73a25f3b5a2f8c3fc9a452b95ae

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