53 lines
1.7 KiB
YAML
53 lines
1.7 KiB
YAML
# Template docker-push
|
|
|
|
# This template allows you to build and push your docker image to a Docker Hub account.
|
|
# The workflow allows running tests, code linting and security scans on feature branches (as well as master).
|
|
# The docker image will be validated and pushed to the docker registry after the code is merged to master.
|
|
|
|
# Prerequisites: $DOCKERHUB_USERNAME, $DOCKERHUB_PASSWORD setup as deployment variables
|
|
|
|
image: atlassian/default-image:2
|
|
|
|
pipelines:
|
|
default:
|
|
- parallel:
|
|
- step:
|
|
name: Build and Test
|
|
script:
|
|
- IMAGE_NAME=$BITBUCKET_REPO_SLUG
|
|
- docker build . --file Dockerfile --tag ${IMAGE_NAME}
|
|
services:
|
|
- docker
|
|
caches:
|
|
- docker
|
|
- step:
|
|
name: Lint the Dockerfile
|
|
image: hadolint/hadolint:latest-debian
|
|
script:
|
|
- hadolint Dockerfile
|
|
branches:
|
|
master:
|
|
- step:
|
|
name: Build and Test
|
|
script:
|
|
- IMAGE_NAME=$BITBUCKET_REPO_SLUG
|
|
- docker build . --file Dockerfile --tag ${IMAGE_NAME}
|
|
- docker save ${IMAGE_NAME} --output "${IMAGE_NAME}.tar"
|
|
services:
|
|
- docker
|
|
caches:
|
|
- docker
|
|
artifacts:
|
|
- "*.tar"
|
|
- step:
|
|
name: Deploy to Production
|
|
deployment: Production
|
|
script:
|
|
- echo ${DOCKERHUB_PASSWORD} | docker login --username "$DOCKERHUB_USERNAME" --password-stdin
|
|
- IMAGE_NAME=$BITBUCKET_REPO_SLUG
|
|
- IMAGE=${DOCKERHUB_NAMESPACE}/${IMAGE_NAME}
|
|
- docker tag "${IMAGE_NAME}" "${IMAGE}:latest"
|
|
- docker push "${IMAGE}:${VERSION}"
|
|
services:
|
|
- docker
|