Skip to main content

Matrix builder for docker

Project description

tumbo

Docker matrix build generator

variables:
    my_var:
        - a
        - b
        - c
    some_other:
        - 0.1.0
        - 0.1.2

context: ./build
recipe: './Dockerfile.j2'
tag: "my-tag:{{ my_var }}-{{ some_other }}"

parallel: no
# no
# yes : uses all threads available
# n : number of threads to use
# default: yes

push: yes
run: yes
registry:
    username: my_user
    password: my_pass
    host: my_host

📘 Config Reference

Variables

The variables to build the matrix. Simply specify an array for each variable. They will be available in the template.

variables:
    my_var:
        - a
        - b
        - c
    some_other:
        - 0.1.0
        - 0.1.2

Recipe

The template to compile the dockerfile. Can be a template itself if you don't want to write everything in the same file.

Simple
recipe: './Dockerfile.j2'
Template
variables:
    my_var:
        - a
        - b

recipe: './{{ my_var }}.j2'

Assuming my_var hast the values a and b it will render to ./a.j2 and ./b.j2 accordingly.

Context (Optional)

Default: directory of the config file.

Specify the directory where the templates and the dockerfiles will be built. Supports both absolute and relative paths.

context: ./build

Tag (Optional)

Default: Creates a tag that includes all variables. In most cases it will not be necessary to specify, but can be usefull if your are pushing images. Supports templating of course.

Important: The tag should be unique across the matrix, otherwise you will overwrite other tags. So always include all the variables you specified inside the image name

variables:
    var1:
        - a
        - b
    var2:
        - a
        - b
    var3:
        - a
        - b

tag: 'my-image-name:{{ var3 }}-{{ var1 }}-{{ var2 }}'

Parallel (Optional)

Default: yes

Whether the builds/push/runs should run in parallel or after each other.

no

Parallel off.

parallel: no
yes

Uses all the threads available on the machine.

parallel: yes
number

Uses how many thread you specify

parallel: 2

run (Optional)

Default: no

Wether to run the docker image after building. Can be usefull if running automated tests.

run: yes

push (Optional)

Default: no

Wether to push the docker image after building. Can be used to push images to the docker registry (or your own). See below on how to login.

run: yes

registry (Optional)

Default: Empty

Credentials for docker login. Used to push images and to specify a custom registry if necessary.

registry:
    username: my_user
    password: my_pass
    host: my_host

Project details


Release history Release notifications | RSS feed

This version

0.7

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tumbo-0.7.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

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

tumbo-0.7-py3-none-any.whl (18.0 kB view details)

Uploaded Python 3

File details

Details for the file tumbo-0.7.tar.gz.

File metadata

  • Download URL: tumbo-0.7.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.7.5

File hashes

Hashes for tumbo-0.7.tar.gz
Algorithm Hash digest
SHA256 19b926904f3941e28595c0bc699d62884d68b99fffa70359a7b43a3184877192
MD5 e9d386ac3a38baf6e89592eb30f0e5c2
BLAKE2b-256 ffb8fcf0f1dbc1d15e9ef21a4c19d2a0c1fc362b55ef9d179450f57346b02e94

See more details on using hashes here.

File details

Details for the file tumbo-0.7-py3-none-any.whl.

File metadata

  • Download URL: tumbo-0.7-py3-none-any.whl
  • Upload date:
  • Size: 18.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.7.5

File hashes

Hashes for tumbo-0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 c562f5818dc449a8e787935d10a1c68727ed5e53a7ab4de053e46c726e0f07bb
MD5 8ad0612d8881977ff21d83d0c29f25a6
BLAKE2b-256 1379573ef55dfd23448ea73b7c792387f3fbbefc906a9c17b9a5289b0afecbc8

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