62 lines
1.5 KiB
YAML
62 lines
1.5 KiB
YAML
image: docker:latest
|
|
services:
|
|
- docker:dind
|
|
|
|
stages:
|
|
- build
|
|
- test
|
|
- deploy
|
|
|
|
# Disable the Gradle daemon for Continuous Integration servers as correctness
|
|
# is usually a priority over speed in CI environments. Using a fresh
|
|
# runtime for each build is more reliable since the runtime is completely
|
|
# isolated from any previous builds.
|
|
variables:
|
|
GRADLE_OPTS: "-Dorg.gradle.daemon=false"
|
|
# Use TLS https://docs.gitlab.com/ee/ci/docker/using_docker_build.html#tls-enabled
|
|
DOCKER_HOST: tcp://docker:2376
|
|
DOCKER_TLS_CERTDIR: "/certs"
|
|
CONTAINER_LATEST_IMAGE: $CI_REGISTRY_IMAGE:latest
|
|
|
|
before_script:
|
|
- export GRADLE_USER_HOME=`pwd`/.gradle
|
|
|
|
build:
|
|
image: gradle:jdk15
|
|
stage: build
|
|
script: gradle --build-cache assemble
|
|
cache:
|
|
key: "$CI_COMMIT_REF_NAME"
|
|
policy: push
|
|
paths:
|
|
- build
|
|
- .gradle
|
|
|
|
|
|
test:
|
|
image: gradle:jdk15
|
|
stage: test
|
|
script: gradle check
|
|
cache:
|
|
key: "$CI_COMMIT_REF_NAME"
|
|
policy: pull
|
|
paths:
|
|
- build/libs/*.jar
|
|
- .gradle
|
|
|
|
|
|
package:
|
|
stage: deploy
|
|
image: $CI_REGISTRY/group/project/docker:19.03.12
|
|
services:
|
|
- name: $CI_REGISTRY/group/project/docker:19.03.12-dind
|
|
alias: docker
|
|
variables:
|
|
IMAGE_LATEST_TAG: $CI_REGISTRY_IMAGE:latest
|
|
IMAGE_COMMIT_REF_TAG: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
|
|
script:
|
|
- docker login -u $CI_REGISTRY_IMAGE -p $CI_BUILD_TOKEN $CI_REGISTRY
|
|
- docker build -t $IMAGE_LATEST_TAG -t $IMAGE_COMMIT_REF_TAG .
|
|
- docker push $IMAGE_LATEST_TAG $IMAGE_COMMIT_REF_TAG
|
|
only:
|
|
- master |