mirror of
https://github.com/thegeeklab/docker-autotag.git
synced 2024-11-05 08:50:40 +00:00
358 lines
8.1 KiB
Plaintext
358 lines
8.1 KiB
Plaintext
local PythonVersion(pyversion='3.7') = {
|
|
name: 'python' + std.strReplace(pyversion, '.', '') + '-pytest',
|
|
image: 'python:' + pyversion,
|
|
environment: {
|
|
PY_COLORS: 1,
|
|
},
|
|
commands: [
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry config experimental.new-installer false',
|
|
'poetry install',
|
|
'poetry version',
|
|
'poetry run docker-autotag --help',
|
|
],
|
|
depends_on: [
|
|
'fetch',
|
|
],
|
|
};
|
|
|
|
local PipelineLint = {
|
|
kind: 'pipeline',
|
|
name: 'lint',
|
|
platform: {
|
|
os: 'linux',
|
|
arch: 'amd64',
|
|
},
|
|
steps: [
|
|
{
|
|
name: 'yapf',
|
|
image: 'python:3.11',
|
|
environment: {
|
|
PY_COLORS: 1,
|
|
},
|
|
commands: [
|
|
'git fetch -tq',
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry config experimental.new-installer false',
|
|
'poetry install',
|
|
'poetry run yapf -dr ./dockerautotag',
|
|
],
|
|
},
|
|
{
|
|
name: 'flake8',
|
|
image: 'python:3.11',
|
|
environment: {
|
|
PY_COLORS: 1,
|
|
},
|
|
commands: [
|
|
'git fetch -tq',
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry config experimental.new-installer false',
|
|
'poetry install',
|
|
'poetry run flake8 ./dockerautotag',
|
|
],
|
|
},
|
|
],
|
|
trigger: {
|
|
ref: ['refs/heads/main', 'refs/tags/**', 'refs/pull/**'],
|
|
},
|
|
};
|
|
|
|
local PipelineTest = {
|
|
kind: 'pipeline',
|
|
name: 'test',
|
|
platform: {
|
|
os: 'linux',
|
|
arch: 'amd64',
|
|
},
|
|
steps: [
|
|
{
|
|
name: 'fetch',
|
|
image: 'python:3.11',
|
|
commands: [
|
|
'git fetch -tq',
|
|
],
|
|
},
|
|
PythonVersion(pyversion='3.7'),
|
|
PythonVersion(pyversion='3.8'),
|
|
PythonVersion(pyversion='3.9'),
|
|
PythonVersion(pyversion='3.10'),
|
|
PythonVersion(pyversion='3.11'),
|
|
],
|
|
depends_on: [
|
|
'lint',
|
|
],
|
|
trigger: {
|
|
ref: ['refs/heads/main', 'refs/tags/**', 'refs/pull/**'],
|
|
},
|
|
};
|
|
|
|
local PipelineSecurity = {
|
|
kind: 'pipeline',
|
|
name: 'security',
|
|
platform: {
|
|
os: 'linux',
|
|
arch: 'amd64',
|
|
},
|
|
steps: [
|
|
{
|
|
name: 'bandit',
|
|
image: 'python:3.11',
|
|
environment: {
|
|
PY_COLORS: 1,
|
|
},
|
|
commands: [
|
|
'git fetch -tq',
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry config experimental.new-installer false',
|
|
'poetry install',
|
|
'poetry run bandit -r ./dockerautotag -x ./dockerautotag/test',
|
|
],
|
|
},
|
|
],
|
|
depends_on: [
|
|
'test',
|
|
],
|
|
trigger: {
|
|
ref: ['refs/heads/main', 'refs/tags/**', 'refs/pull/**'],
|
|
},
|
|
};
|
|
|
|
local PipelineBuildPackage = {
|
|
kind: 'pipeline',
|
|
name: 'build-package',
|
|
platform: {
|
|
os: 'linux',
|
|
arch: 'amd64',
|
|
},
|
|
steps: [
|
|
{
|
|
name: 'build',
|
|
image: 'python:3.11',
|
|
commands: [
|
|
'git fetch -tq',
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry build',
|
|
],
|
|
},
|
|
{
|
|
name: 'checksum',
|
|
image: 'alpine',
|
|
commands: [
|
|
'cd dist/ && sha256sum * > ../sha256sum.txt',
|
|
],
|
|
},
|
|
{
|
|
name: 'changelog-generate',
|
|
image: 'thegeeklab/git-chglog',
|
|
commands: [
|
|
'git fetch -tq',
|
|
'git-chglog --no-color --no-emoji -o CHANGELOG.md ${DRONE_TAG:---next-tag unreleased unreleased}',
|
|
],
|
|
},
|
|
{
|
|
name: 'changelog-format',
|
|
image: 'thegeeklab/alpine-tools',
|
|
commands: [
|
|
'prettier CHANGELOG.md',
|
|
'prettier -w CHANGELOG.md',
|
|
],
|
|
},
|
|
{
|
|
name: 'publish-github',
|
|
image: 'plugins/github-release',
|
|
settings: {
|
|
overwrite: true,
|
|
api_key: { from_secret: 'github_token' },
|
|
files: ['dist/*', 'sha256sum.txt'],
|
|
title: '${DRONE_TAG}',
|
|
note: 'CHANGELOG.md',
|
|
},
|
|
when: {
|
|
ref: ['refs/tags/**'],
|
|
},
|
|
},
|
|
{
|
|
name: 'publish-pypi',
|
|
image: 'python:3.11',
|
|
commands: [
|
|
'git fetch -tq',
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry publish -n',
|
|
],
|
|
environment: {
|
|
POETRY_HTTP_BASIC_PYPI_USERNAME: { from_secret: 'pypi_username' },
|
|
POETRY_HTTP_BASIC_PYPI_PASSWORD: { from_secret: 'pypi_password' },
|
|
},
|
|
when: {
|
|
ref: ['refs/tags/**'],
|
|
},
|
|
},
|
|
],
|
|
depends_on: [
|
|
'security',
|
|
],
|
|
trigger: {
|
|
ref: ['refs/heads/main', 'refs/tags/**', 'refs/pull/**'],
|
|
},
|
|
};
|
|
|
|
local PipelineBuildContainer = {
|
|
kind: 'pipeline',
|
|
name: 'build-container',
|
|
platform: {
|
|
os: 'linux',
|
|
arch: 'amd64',
|
|
},
|
|
steps: [
|
|
{
|
|
name: 'build',
|
|
image: 'python:3.11',
|
|
commands: [
|
|
'git fetch -tq',
|
|
'pip install poetry poetry-dynamic-versioning -qq',
|
|
'poetry build',
|
|
],
|
|
},
|
|
{
|
|
name: 'dryrun',
|
|
image: 'thegeeklab/drone-docker-buildx:20',
|
|
settings: {
|
|
dry_run: true,
|
|
dockerfile: 'Dockerfile.multiarch',
|
|
repo: 'thegeeklab/${DRONE_REPO_NAME}',
|
|
platforms: [
|
|
'linux/amd64',
|
|
'linux/arm64',
|
|
],
|
|
provenance: false,
|
|
},
|
|
depends_on: ['build'],
|
|
when: {
|
|
ref: ['refs/pull/**'],
|
|
},
|
|
},
|
|
{
|
|
name: 'publish-dockerhub',
|
|
image: 'thegeeklab/drone-docker-buildx:20',
|
|
settings: {
|
|
auto_tag: true,
|
|
dockerfile: 'Dockerfile.multiarch',
|
|
repo: 'thegeeklab/${DRONE_REPO_NAME}',
|
|
username: { from_secret: 'docker_username' },
|
|
password: { from_secret: 'docker_password' },
|
|
platforms: [
|
|
'linux/amd64',
|
|
'linux/arm64',
|
|
],
|
|
provenance: false,
|
|
},
|
|
when: {
|
|
ref: ['refs/heads/main', 'refs/tags/**'],
|
|
},
|
|
depends_on: ['dryrun'],
|
|
},
|
|
{
|
|
name: 'publish-quay',
|
|
image: 'thegeeklab/drone-docker-buildx:20',
|
|
settings: {
|
|
auto_tag: true,
|
|
dockerfile: 'Dockerfile.multiarch',
|
|
registry: 'quay.io',
|
|
repo: 'quay.io/thegeeklab/${DRONE_REPO_NAME}',
|
|
username: { from_secret: 'quay_username' },
|
|
password: { from_secret: 'quay_password' },
|
|
platforms: [
|
|
'linux/amd64',
|
|
'linux/arm64',
|
|
],
|
|
provenance: false,
|
|
},
|
|
when: {
|
|
ref: ['refs/heads/main', 'refs/tags/**'],
|
|
},
|
|
depends_on: ['dryrun'],
|
|
},
|
|
],
|
|
depends_on: [
|
|
'security',
|
|
],
|
|
trigger: {
|
|
ref: ['refs/heads/main', 'refs/tags/**', 'refs/pull/**'],
|
|
},
|
|
};
|
|
|
|
local PipelineNotifications = {
|
|
kind: 'pipeline',
|
|
name: 'notifications',
|
|
platform: {
|
|
os: 'linux',
|
|
arch: 'amd64',
|
|
},
|
|
steps: [
|
|
{
|
|
name: 'pushrm-dockerhub',
|
|
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',
|
|
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: 'thegeeklab/drone-matrix',
|
|
settings: {
|
|
homeserver: { from_secret: 'matrix_homeserver' },
|
|
roomid: { from_secret: 'matrix_roomid' },
|
|
template: 'Status: **{{ .Build.Status }}**<br/> Build: [{{ .Repo.Owner }}/{{ .Repo.Name }}]({{ .Build.Link }}){{ if .Build.Branch }} ({{ .Build.Branch }}){{ end }} by {{ .Commit.Author }}<br/> Message: {{ .Commit.Message.Title }}',
|
|
username: { from_secret: 'matrix_username' },
|
|
password: { from_secret: 'matrix_password' },
|
|
},
|
|
when: {
|
|
status: ['success', 'failure'],
|
|
},
|
|
},
|
|
],
|
|
depends_on: [
|
|
'build-package',
|
|
'build-container',
|
|
],
|
|
trigger: {
|
|
ref: ['refs/heads/main', 'refs/tags/**'],
|
|
status: ['success', 'failure'],
|
|
},
|
|
};
|
|
|
|
[
|
|
PipelineLint,
|
|
PipelineTest,
|
|
PipelineSecurity,
|
|
PipelineBuildPackage,
|
|
PipelineBuildContainer,
|
|
PipelineNotifications,
|
|
]
|