summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjp <jp+pleroma@supplntr.io>2020-01-14 12:32:36 -0500
committerjp <jp+pleroma@supplntr.io>2020-01-14 12:32:36 -0500
commitfe57e5139fb8396e2b929998850710d73de587ff (patch)
treef6399812d8fe776b0cad53ccbb3fb9f040cc9dbd
parent12b28c8925c2c55e0d7bb66ff3320532a1aade3b (diff)
Remove cache from docker jobs. Split devlop and stable branches into their own jobs
-rw-r--r--.gitlab-ci.yml43
1 files changed, 33 insertions, 10 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index b34c7e98d..ba6e41aef 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -6,10 +6,6 @@ variables: &global_variables
POSTGRES_PASSWORD: postgres
DB_HOST: postgres
MIX_ENV: test
- DOCKER_DRIVER: overlay2
- DOCKER_HOST: unix:///var/run/docker.sock
- DOCKER_IMAGE: $CI_REGISTRY_IMAGE:latest
- DOCKER_IMAGE_SHA: $CI_REGISTRY_IMAGE:$CI_COMMIT_SHORT_SHA
cache: &global_cache_policy
key: ${CI_COMMIT_REF_SLUG}
@@ -274,16 +270,43 @@ arm64-musl:
docker:
stage: docker
image: docker:latest
- tags:
- - dind
+ cache: {}
+ variables: &docker-variables
+ DOCKER_DRIVER: overlay2
+ DOCKER_HOST: unix:///var/run/docker.sock
+ IMAGE_TAG: $CI_REGISTRY_IMAGE:$CI_COMMIT_SHORT_SHA
+ IMAGE_TAG_SLUG: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
+ IMAGE_TAG_LATEST: $CI_REGISTRY_IMAGE:latest
+ IMAGE_TAG_LATEST_STABLE: $CI_REGISTRY_IMAGE:latest-stable
before_script: &before-docker
- docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
- export CI_JOB_TIMESTAMP=$(date --utc -Iseconds)
- export CI_VCS_REF=$CI_COMMIT_SHORT_SHA
script:
- - docker pull $DOCKER_IMAGE || true
- - docker build --cache-from $DOCKER_IMAGE --build-arg VCS_REF=$CI_VCS_REF --build-arg BUILD_DATE=$CI_JOB_TIMESTAMP -t $DOCKER_IMAGE_SHA -t $DOCKER_IMAGE .
- - docker push $DOCKER_IMAGE_SHA
- - docker push $DOCKER_IMAGE
+ - docker pull $IMAGE_TAG_SLUG || true
+ - docker build --cache-from $IMAGE_TAG_SLUG --build-arg VCS_REF=$CI_VCS_REF --build-arg BUILD_DATE=$CI_JOB_TIMESTAMP -t $IMAGE_TAG -t $IMAGE_TAG_SLUG -t $IMAGE_TAG_LATEST .
+ - docker push $IMAGE_TAG
+ - docker push $IMAGE_TAG_SLUG
+ - docker push $IMAGE_TAG_LATEST
+ tags:
+ - dind
only:
- develop
+ - features/docker-updates
+
+docker-stable:
+ stage: docker
+ image: docker:latest
+ cache: {}
+ variables: *docker-variables
+ before_script: *before-docker
+ script:
+ - docker pull $IMAGE_TAG_SLUG || true
+ - docker build --cache-from $IMAGE_TAG_SLUG --build-arg VCS_REF=$CI_VCS_REF --build-arg BUILD_DATE=$CI_JOB_TIMESTAMP -t $IMAGE_TAG -t $IMAGE_TAG_SLUG -t $IMAGE_TAG_LATEST_STABLE .
+ - docker push $IMAGE_TAG
+ - docker push $IMAGE_TAG_SLUG
+ - docker push $IMAGE_TAG_LATEST_STABLE
+ tags:
+ - dind
+ only:
+ - stable