chore: Simplify the CI configuration. #8
1 changed files with 79 additions and 200 deletions
277
.drone.yml
277
.drone.yml
|
@ -26,7 +26,6 @@ steps:
|
||||||
|
|
||||||
- name: restore build cache
|
- name: restore build cache
|
||||||
image: meltwater/drone-cache
|
image: meltwater/drone-cache
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
AWS_ACCESS_KEY_ID:
|
AWS_ACCESS_KEY_ID:
|
||||||
from_secret: ACCESS_KEY_ID
|
from_secret: ACCESS_KEY_ID
|
||||||
|
@ -73,7 +72,6 @@ steps:
|
||||||
|
|
||||||
- name: store ASDF cache
|
- name: store ASDF cache
|
||||||
image: meltwater/drone-cache
|
image: meltwater/drone-cache
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
AWS_ACCESS_KEY_ID:
|
AWS_ACCESS_KEY_ID:
|
||||||
from_secret: ACCESS_KEY_ID
|
from_secret: ACCESS_KEY_ID
|
||||||
|
@ -97,7 +95,6 @@ steps:
|
||||||
|
|
||||||
- name: store build cache
|
- name: store build cache
|
||||||
image: meltwater/drone-cache
|
image: meltwater/drone-cache
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
AWS_ACCESS_KEY_ID:
|
AWS_ACCESS_KEY_ID:
|
||||||
from_secret: ACCESS_KEY_ID
|
from_secret: ACCESS_KEY_ID
|
||||||
|
@ -123,65 +120,8 @@ steps:
|
||||||
- .mix
|
- .mix
|
||||||
- .rebar3
|
- .rebar3
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
kind: pipeline
|
|
||||||
type: docker
|
|
||||||
name: test
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- build
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: restore ASDF cache
|
|
||||||
image: meltwater/drone-cache
|
|
||||||
pull: "always"
|
|
||||||
environment:
|
|
||||||
AWS_ACCESS_KEY_ID:
|
|
||||||
from_secret: ACCESS_KEY_ID
|
|
||||||
AWS_SECRET_ACCESS_KEY:
|
|
||||||
from_secret: SECRET_ACCESS_KEY
|
|
||||||
AWS_PLUGIN_PATH_STYLE: true
|
|
||||||
settings:
|
|
||||||
restore: true
|
|
||||||
endpoint:
|
|
||||||
from_secret: S3_ENDPOINT
|
|
||||||
bucket:
|
|
||||||
from_secret: CACHE_BUCKET
|
|
||||||
region: us-east-1
|
|
||||||
path-style: true
|
|
||||||
cache_key: 'asdf-{{ os }}-{{ arch }}-{{ checksum ".tool-versions" }}'
|
|
||||||
mount:
|
|
||||||
- .asdf
|
|
||||||
|
|
||||||
- name: restore build cache
|
|
||||||
image: meltwater/drone-cache
|
|
||||||
pull: "always"
|
|
||||||
environment:
|
|
||||||
AWS_ACCESS_KEY_ID:
|
|
||||||
from_secret: ACCESS_KEY_ID
|
|
||||||
AWS_SECRET_ACCESS_KEY:
|
|
||||||
from_secret: SECRET_ACCESS_KEY
|
|
||||||
AWS_PLUGIN_PATH_STYLE: true
|
|
||||||
settings:
|
|
||||||
restore: true
|
|
||||||
endpoint:
|
|
||||||
from_secret: S3_ENDPOINT
|
|
||||||
bucket:
|
|
||||||
from_secret: CACHE_BUCKET
|
|
||||||
region: us-east-1
|
|
||||||
path-style: true
|
|
||||||
cache_key: 'elixir-{{ checksum "mix.lock" }}-{{ checksum ".tool-versions" }}'
|
|
||||||
mount:
|
|
||||||
- deps
|
|
||||||
- _build
|
|
||||||
- .hex
|
|
||||||
- .mix
|
|
||||||
- .rebar3
|
|
||||||
|
|
||||||
- name: mix compile
|
- name: mix compile
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -189,14 +129,12 @@ steps:
|
||||||
REBAR_BASE_DIR: /drone/src/.rebar3
|
REBAR_BASE_DIR: /drone/src/.rebar3
|
||||||
ASDF_DATA_DIR: /drone/src/.asdf
|
ASDF_DATA_DIR: /drone/src/.asdf
|
||||||
depends_on:
|
depends_on:
|
||||||
- restore ASDF cache
|
- install dependencies
|
||||||
- restore build cache
|
|
||||||
commands:
|
commands:
|
||||||
- asdf mix compile --warnings-as-errors
|
- asdf mix compile --warnings-as-errors
|
||||||
|
|
||||||
- name: mix test
|
- name: mix test
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -210,7 +148,6 @@ steps:
|
||||||
|
|
||||||
- name: mix credo
|
- name: mix credo
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -222,9 +159,21 @@ steps:
|
||||||
commands:
|
commands:
|
||||||
- asdf mix credo --strict
|
- asdf mix credo --strict
|
||||||
|
|
||||||
|
- name: mix dialyzer
|
||||||
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
|
environment:
|
||||||
|
MIX_ENV: test
|
||||||
|
HEX_HOME: /drone/src/.hex
|
||||||
|
MIX_HOME: /drone/src/.mix
|
||||||
|
REBAR_BASE_DIR: /drone/src/.rebar3
|
||||||
|
ASDF_DATA_DIR: /drone/src/.asdf
|
||||||
|
depends_on:
|
||||||
|
- mix compile
|
||||||
|
commands:
|
||||||
|
- asdf mix dialyzer
|
||||||
|
|
||||||
- name: mix hex.audit
|
- name: mix hex.audit
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -238,7 +187,6 @@ steps:
|
||||||
|
|
||||||
- name: mix format
|
- name: mix format
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -252,7 +200,6 @@ steps:
|
||||||
|
|
||||||
- name: mix deps.unlock
|
- name: mix deps.unlock
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -266,7 +213,6 @@ steps:
|
||||||
|
|
||||||
- name: mix doctor
|
- name: mix doctor
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -280,7 +226,6 @@ steps:
|
||||||
|
|
||||||
- name: mix git_ops.check_message
|
- name: mix git_ops.check_message
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -293,73 +238,23 @@ steps:
|
||||||
- git log -1 --format=%s > .last_commit_message
|
- git log -1 --format=%s > .last_commit_message
|
||||||
- asdf mix git_ops.check_message .last_commit_message
|
- asdf mix git_ops.check_message .last_commit_message
|
||||||
|
|
||||||
---
|
- name: mix git_ops.release
|
||||||
kind: pipeline
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
type: docker
|
when:
|
||||||
name: git ops
|
|
||||||
|
|
||||||
trigger:
|
|
||||||
branch:
|
branch:
|
||||||
- main
|
- main
|
||||||
event:
|
event:
|
||||||
- push
|
exclude:
|
||||||
|
- pull_request
|
||||||
depends_on:
|
|
||||||
- test
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: restore ASDF cache
|
|
||||||
image: meltwater/drone-cache
|
|
||||||
pull: "always"
|
|
||||||
environment:
|
|
||||||
AWS_ACCESS_KEY_ID:
|
|
||||||
from_secret: ACCESS_KEY_ID
|
|
||||||
AWS_SECRET_ACCESS_KEY:
|
|
||||||
from_secret: SECRET_ACCESS_KEY
|
|
||||||
AWS_PLUGIN_PATH_STYLE: true
|
|
||||||
settings:
|
|
||||||
restore: true
|
|
||||||
endpoint:
|
|
||||||
from_secret: S3_ENDPOINT
|
|
||||||
bucket:
|
|
||||||
from_secret: CACHE_BUCKET
|
|
||||||
region: us-east-1
|
|
||||||
path-style: true
|
|
||||||
cache_key: 'asdf-{{ os }}-{{ arch }}-{{ checksum ".tool-versions" }}'
|
|
||||||
mount:
|
|
||||||
- .asdf
|
|
||||||
|
|
||||||
- name: restore build cache
|
|
||||||
image: meltwater/drone-cache
|
|
||||||
pull: "always"
|
|
||||||
environment:
|
|
||||||
AWS_ACCESS_KEY_ID:
|
|
||||||
from_secret: ACCESS_KEY_ID
|
|
||||||
AWS_SECRET_ACCESS_KEY:
|
|
||||||
from_secret: SECRET_ACCESS_KEY
|
|
||||||
AWS_PLUGIN_PATH_STYLE: true
|
|
||||||
settings:
|
|
||||||
restore: true
|
|
||||||
endpoint:
|
|
||||||
from_secret: S3_ENDPOINT
|
|
||||||
bucket:
|
|
||||||
from_secret: CACHE_BUCKET
|
|
||||||
region: us-east-1
|
|
||||||
path-style: true
|
|
||||||
cache_key: 'elixir-{{ checksum "mix.lock" }}-{{ checksum ".tool-versions" }}'
|
|
||||||
mount:
|
|
||||||
- deps
|
|
||||||
- _build
|
|
||||||
- .hex
|
|
||||||
- .mix
|
|
||||||
- .rebar3
|
|
||||||
|
|
||||||
- name: mix git_ops.release
|
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
|
||||||
pull: "always"
|
|
||||||
depends_on:
|
depends_on:
|
||||||
- restore ASDF cache
|
- mix test
|
||||||
- restore build cache
|
- mix credo
|
||||||
|
- mix dialyzer
|
||||||
|
- mix hex.audit
|
||||||
|
- mix format
|
||||||
|
- mix deps.unlock
|
||||||
|
- mix doctor
|
||||||
|
- mix git_ops.check_message
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -384,73 +279,23 @@ steps:
|
||||||
- git push $${GIT_URL} "HEAD:${DRONE_COMMIT_REF}" "refs/tags/v$${NEW_APP_VERSION}"
|
- git push $${GIT_URL} "HEAD:${DRONE_COMMIT_REF}" "refs/tags/v$${NEW_APP_VERSION}"
|
||||||
- fi
|
- fi
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
kind: pipeline
|
|
||||||
type: docker
|
|
||||||
name: release
|
|
||||||
|
|
||||||
trigger:
|
|
||||||
ref:
|
|
||||||
include:
|
|
||||||
- refs/tags/v**
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- test
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: restore ASDF cache
|
|
||||||
image: meltwater/drone-cache
|
|
||||||
pull: "always"
|
|
||||||
environment:
|
|
||||||
AWS_ACCESS_KEY_ID:
|
|
||||||
from_secret: ACCESS_KEY_ID
|
|
||||||
AWS_SECRET_ACCESS_KEY:
|
|
||||||
from_secret: SECRET_ACCESS_KEY
|
|
||||||
AWS_PLUGIN_PATH_STYLE: true
|
|
||||||
settings:
|
|
||||||
restore: true
|
|
||||||
endpoint:
|
|
||||||
from_secret: S3_ENDPOINT
|
|
||||||
bucket:
|
|
||||||
from_secret: CACHE_BUCKET
|
|
||||||
region: us-east-1
|
|
||||||
path-style: true
|
|
||||||
cache_key: 'asdf-{{ os }}-{{ arch }}-{{ checksum ".tool-versions" }}'
|
|
||||||
mount:
|
|
||||||
- .asdf
|
|
||||||
|
|
||||||
- name: restore build cache
|
|
||||||
image: meltwater/drone-cache
|
|
||||||
pull: "always"
|
|
||||||
environment:
|
|
||||||
AWS_ACCESS_KEY_ID:
|
|
||||||
from_secret: ACCESS_KEY_ID
|
|
||||||
AWS_SECRET_ACCESS_KEY:
|
|
||||||
from_secret: SECRET_ACCESS_KEY
|
|
||||||
AWS_PLUGIN_PATH_STYLE: true
|
|
||||||
settings:
|
|
||||||
restore: true
|
|
||||||
endpoint:
|
|
||||||
from_secret: S3_ENDPOINT
|
|
||||||
bucket:
|
|
||||||
from_secret: CACHE_BUCKET
|
|
||||||
region: us-east-1
|
|
||||||
path-style: true
|
|
||||||
cache_key: 'elixir-{{ checksum "mix.lock" }}-{{ checksum ".tool-versions" }}'
|
|
||||||
mount:
|
|
||||||
- deps
|
|
||||||
- _build
|
|
||||||
- .hex
|
|
||||||
- .mix
|
|
||||||
- .rebar3
|
|
||||||
|
|
||||||
- name: build artifacts
|
- name: build artifacts
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
when:
|
||||||
|
event:
|
||||||
|
- tag
|
||||||
|
refs:
|
||||||
|
include:
|
||||||
|
- refs/tags/v*
|
||||||
depends_on:
|
depends_on:
|
||||||
- restore ASDF cache
|
- mix test
|
||||||
- restore build cache
|
- mix credo
|
||||||
|
- mix dialyzer
|
||||||
|
- mix hex.audit
|
||||||
|
- mix format
|
||||||
|
- mix deps.unlock
|
||||||
|
- mix doctor
|
||||||
|
- mix git_ops.check_message
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
@ -472,6 +317,12 @@ steps:
|
||||||
|
|
||||||
- name: gitea release
|
- name: gitea release
|
||||||
image: plugins/gitea-release
|
image: plugins/gitea-release
|
||||||
|
when:
|
||||||
|
event:
|
||||||
|
- tag
|
||||||
|
refs:
|
||||||
|
include:
|
||||||
|
- refs/tags/v*
|
||||||
depends_on:
|
depends_on:
|
||||||
- build artifacts
|
- build artifacts
|
||||||
settings:
|
settings:
|
||||||
|
@ -483,12 +334,40 @@ steps:
|
||||||
title: tag_subject
|
title: tag_subject
|
||||||
note: tag_body
|
note: tag_body
|
||||||
|
|
||||||
|
- name: docs release
|
||||||
|
when:
|
||||||
|
event:
|
||||||
|
- tag
|
||||||
|
refs:
|
||||||
|
include:
|
||||||
|
- refs/tags/v*
|
||||||
|
image: minio/mc
|
||||||
|
environment:
|
||||||
|
S3_ENDPOINT:
|
||||||
|
from_secret: S3_ENDPOINT
|
||||||
|
ACCESS_KEY:
|
||||||
|
from_secret: ACCESS_KEY_ID
|
||||||
|
SECRET_KEY:
|
||||||
|
from_secret: SECRET_ACCESS_KEY
|
||||||
|
depends_on:
|
||||||
|
- build artifacts
|
||||||
|
commands:
|
||||||
|
- mc alias set store $${S3_ENDPOINT} $${ACCESS_KEY} $${SECRET_KEY}
|
||||||
|
- mc mb -p store/docs.harton.nz
|
||||||
|
- mc anonymous set download store/docs.harton.nz
|
||||||
|
- mc mirror --overwrite doc/ store/docs.harton.nz/$${DRONE_REPO}/$${DRONE_TAG}
|
||||||
|
- mc mirror --overwrite doc/ store/docs.harton.nz/$${DRONE_REPO}
|
||||||
|
|
||||||
- name: hex release
|
- name: hex release
|
||||||
image: code.harton.nz/james/asdf_container:latest
|
image: code.harton.nz/james/asdf_container:latest
|
||||||
pull: "always"
|
when:
|
||||||
|
event:
|
||||||
|
- tag
|
||||||
|
refs:
|
||||||
|
include:
|
||||||
|
- refs/tags/v*
|
||||||
depends_on:
|
depends_on:
|
||||||
- restore ASDF cache
|
- build artifacts
|
||||||
- restore build cache
|
|
||||||
environment:
|
environment:
|
||||||
MIX_ENV: test
|
MIX_ENV: test
|
||||||
HEX_HOME: /drone/src/.hex
|
HEX_HOME: /drone/src/.hex
|
||||||
|
|
Loading…
Reference in a new issue