mirror of
https://github.com/thegeeklab/docker-autotag.git
synced 2024-11-05 00:40:40 +00:00
556 lines
9.4 KiB
YAML
556 lines
9.4 KiB
YAML
---
|
|
kind: pipeline
|
|
name: lint
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: flake8
|
|
image: python:3.9
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- flake8 ./dockerautotag
|
|
environment:
|
|
PY_COLORS: 1
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
---
|
|
kind: pipeline
|
|
name: test
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: python35-pytest
|
|
image: python:3.5
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- docker-autotag --help
|
|
- docker-autotag --version
|
|
environment:
|
|
PY_COLORS: 1
|
|
depends_on:
|
|
- clone
|
|
|
|
- name: python36-pytest
|
|
image: python:3.6
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- docker-autotag --help
|
|
- docker-autotag --version
|
|
environment:
|
|
PY_COLORS: 1
|
|
depends_on:
|
|
- clone
|
|
|
|
- name: python37-pytest
|
|
image: python:3.7
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- docker-autotag --help
|
|
- docker-autotag --version
|
|
environment:
|
|
PY_COLORS: 1
|
|
depends_on:
|
|
- clone
|
|
|
|
- name: python38-pytest
|
|
image: python:3.8
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- docker-autotag --help
|
|
- docker-autotag --version
|
|
environment:
|
|
PY_COLORS: 1
|
|
depends_on:
|
|
- clone
|
|
|
|
- name: python39-pytest
|
|
image: python:3.9
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- docker-autotag --help
|
|
- docker-autotag --version
|
|
environment:
|
|
PY_COLORS: 1
|
|
depends_on:
|
|
- clone
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- lint
|
|
|
|
---
|
|
kind: pipeline
|
|
name: security
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: bandit
|
|
image: python:3.9
|
|
commands:
|
|
- pip install -r dev-requirements.txt -qq
|
|
- pip install -qq .
|
|
- bandit -r ./dockerautotag -x ./dockerautotag/tests
|
|
environment:
|
|
PY_COLORS: 1
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- test
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-package
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: build
|
|
image: python:3.9
|
|
commands:
|
|
- python setup.py sdist bdist_wheel
|
|
|
|
- name: checksum
|
|
image: alpine
|
|
commands:
|
|
- cd dist/ && sha256sum * > ../sha256sum.txt
|
|
|
|
- name: publish-github
|
|
image: plugins/github-release
|
|
settings:
|
|
api_key:
|
|
from_secret: github_token
|
|
files:
|
|
- dist/*
|
|
- sha256sum.txt
|
|
note: CHANGELOG.md
|
|
overwrite: true
|
|
title: ${DRONE_TAG}
|
|
when:
|
|
ref:
|
|
- refs/tags/**
|
|
|
|
- name: publish-pypi
|
|
image: plugins/pypi
|
|
settings:
|
|
password:
|
|
from_secret: pypi_password
|
|
repository: https://upload.pypi.org/legacy/
|
|
skip_build: true
|
|
username:
|
|
from_secret: pypi_username
|
|
when:
|
|
ref:
|
|
- refs/tags/**
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- security
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-container-amd64
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: build
|
|
image: python:3.9
|
|
commands:
|
|
- python setup.py bdist_wheel
|
|
|
|
- name: dryrun
|
|
image: plugins/docker:19
|
|
settings:
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
dry_run: true
|
|
password:
|
|
from_secret: docker_password
|
|
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
ref:
|
|
- refs/pull/**
|
|
depends_on:
|
|
- build
|
|
|
|
- name: publish-dockerhub
|
|
image: plugins/docker:19
|
|
settings:
|
|
auto_tag: true
|
|
auto_tag_suffix: amd64
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
password:
|
|
from_secret: docker_password
|
|
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
depends_on:
|
|
- dryrun
|
|
|
|
- name: publish-quay
|
|
image: plugins/docker:19
|
|
settings:
|
|
auto_tag: true
|
|
auto_tag_suffix: amd64
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
password:
|
|
from_secret: quay_password
|
|
registry: quay.io
|
|
repo: quay.io/thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: quay_username
|
|
when:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
depends_on:
|
|
- dryrun
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- security
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-container-arm64
|
|
|
|
platform:
|
|
os: linux
|
|
arch: arm64
|
|
|
|
steps:
|
|
- name: build
|
|
image: python:3.9
|
|
commands:
|
|
- python setup.py bdist_wheel
|
|
|
|
- name: dryrun
|
|
image: plugins/docker:19
|
|
settings:
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
dry_run: true
|
|
password:
|
|
from_secret: docker_password
|
|
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
ref:
|
|
- refs/pull/**
|
|
depends_on:
|
|
- build
|
|
|
|
- name: publish-dockerhub
|
|
image: plugins/docker:19
|
|
settings:
|
|
auto_tag: true
|
|
auto_tag_suffix: arm64
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
password:
|
|
from_secret: docker_password
|
|
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
depends_on:
|
|
- dryrun
|
|
|
|
- name: publish-quay
|
|
image: plugins/docker:19
|
|
settings:
|
|
auto_tag: true
|
|
auto_tag_suffix: arm64
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
password:
|
|
from_secret: quay_password
|
|
registry: quay.io
|
|
repo: quay.io/thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: quay_username
|
|
when:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
depends_on:
|
|
- dryrun
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- security
|
|
|
|
---
|
|
kind: pipeline
|
|
name: build-container-arm
|
|
|
|
platform:
|
|
os: linux
|
|
arch: arm
|
|
|
|
steps:
|
|
- name: build
|
|
image: python:3.9
|
|
commands:
|
|
- python setup.py bdist_wheel
|
|
|
|
- name: dryrun
|
|
image: plugins/docker:19
|
|
settings:
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
dry_run: true
|
|
password:
|
|
from_secret: docker_password
|
|
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
ref:
|
|
- refs/pull/**
|
|
depends_on:
|
|
- build
|
|
|
|
- name: publish-dockerhub
|
|
image: plugins/docker:19
|
|
settings:
|
|
auto_tag: true
|
|
auto_tag_suffix: arm
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
password:
|
|
from_secret: docker_password
|
|
repo: thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
depends_on:
|
|
- dryrun
|
|
|
|
- name: publish-quay
|
|
image: plugins/docker:19
|
|
settings:
|
|
auto_tag: true
|
|
auto_tag_suffix: arm
|
|
config:
|
|
from_secret: docker_config
|
|
dockerfile: docker/Dockerfile
|
|
password:
|
|
from_secret: quay_password
|
|
registry: quay.io
|
|
repo: quay.io/thegeeklab/${DRONE_REPO_NAME}
|
|
username:
|
|
from_secret: quay_username
|
|
when:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
depends_on:
|
|
- dryrun
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
- refs/pull/**
|
|
|
|
depends_on:
|
|
- security
|
|
|
|
---
|
|
kind: pipeline
|
|
name: notifications
|
|
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
|
|
steps:
|
|
- name: manifest-dockerhub
|
|
image: plugins/manifest
|
|
settings:
|
|
auto_tag: true
|
|
ignore_missing: true
|
|
password:
|
|
from_secret: docker_password
|
|
spec: docker/manifest.tmpl
|
|
username:
|
|
from_secret: docker_username
|
|
when:
|
|
status:
|
|
- success
|
|
|
|
- name: manifest-quay
|
|
image: plugins/manifest
|
|
settings:
|
|
auto_tag: true
|
|
ignore_missing: true
|
|
password:
|
|
from_secret: quay_password
|
|
spec: docker/manifest-quay.tmpl
|
|
username:
|
|
from_secret: quay_username
|
|
when:
|
|
status:
|
|
- success
|
|
|
|
- name: pushrm-dockerhub
|
|
pull: always
|
|
image: chko/docker-pushrm:1
|
|
environment:
|
|
DOCKER_PASS:
|
|
from_secret: docker_password
|
|
DOCKER_USER:
|
|
from_secret: docker_username
|
|
PUSHRM_FILE: README.md
|
|
PUSHRM_SHORT: Create docker tags from a given version string
|
|
PUSHRM_TARGET: thegeeklab/${DRONE_REPO_NAME}
|
|
when:
|
|
status:
|
|
- success
|
|
|
|
- name: pushrm-quay
|
|
pull: always
|
|
image: chko/docker-pushrm:1
|
|
environment:
|
|
APIKEY__QUAY_IO:
|
|
from_secret: quay_token
|
|
PUSHRM_FILE: README.md
|
|
PUSHRM_TARGET: quay.io/thegeeklab/${DRONE_REPO_NAME}
|
|
when:
|
|
status:
|
|
- success
|
|
|
|
- name: matrix
|
|
image: plugins/matrix
|
|
settings:
|
|
homeserver:
|
|
from_secret: matrix_homeserver
|
|
password:
|
|
from_secret: matrix_password
|
|
roomid:
|
|
from_secret: matrix_roomid
|
|
template: "Status: **{{ build.status }}**<br/> Build: [{{ repo.Owner }}/{{ repo.Name }}]({{ build.link }}) ({{ build.branch }}) by {{ build.author }}<br/> Message: {{ build.message }}"
|
|
username:
|
|
from_secret: matrix_username
|
|
when:
|
|
status:
|
|
- success
|
|
- failure
|
|
|
|
image_pull_secrets:
|
|
- docker_config
|
|
|
|
trigger:
|
|
ref:
|
|
- refs/heads/master
|
|
- refs/tags/**
|
|
status:
|
|
- success
|
|
- failure
|
|
|
|
depends_on:
|
|
- build-package
|
|
- build-container-amd64
|
|
- build-container-arm64
|
|
- build-container-arm
|
|
|
|
---
|
|
kind: signature
|
|
hmac: d9b5c4f8f10284f81bea1041a8e2d5ea17ac134c16f4cd7a5a77c3bddb5ae17d
|
|
|
|
...
|