-
Notifications
You must be signed in to change notification settings - Fork 19
158 lines (150 loc) · 5.52 KB
/
dockerbuild.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
name: Build & push images for 'reefer ML demo'
on:
push:
branches:
- master
paths-ignore:
- 'docs/**'
- 'consumer/'
- 'data_schema/'
- 'docker/'
- 'ml/'
- 'scripts/'
- '*/chart/**'
jobs:
validate-docker-secrets:
runs-on: ubuntu-latest
steps:
- name: Validate docker registry secrets are defined
id: validate-docker-secrets
run: |
echo "Validating docker registry secrets are defined on the repository"
FAIL=false
validate_secret(){
FIELD=$1
VALUE=$2
if [ -z "${VALUE}" ]; then
echo "The secret ${FIELD} needs to be set on this repository."
FAIL=true
else
echo "The secret ${FIELD} is set on this repository."
fi
}
validate_secret DOCKER_USERNAME ${DOCKER_USERNAME}
validate_secret DOCKER_PASSWORD ${DOCKER_PASSWORD}
validate_secret DOCKER_REPOSITORY ${DOCKER_REPOSITORY}
validate_secret DOCKER_REGISTRY ${DOCKER_REGISTRY}
validate_secret DOCKER_IMAGE_SIMULATOR ${DOCKER_IMAGE_SIMULATOR}
validate_secret DOCKER_IMAGE_SCORING ${DOCKER_IMAGE_SCORING}
validate_secret GITOPS_EMAIL ${GITOPS_EMAIL}
validate_secret GITOPS_TOKEN ${GITOPS_TOKEN}
validate_secret GITOPS_ORG ${GITOPS_ORG}
if [ "${FAIL}" = "true" ]; then
exit 1
fi
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
DOCKER_REPOSITORY: ${{ secrets.DOCKER_REPOSITORY }}
DOCKER_REGISTRY: ${{ secrets.DOCKER_REGISTRY }}
DOCKER_IMAGE_SIMULATOR: ${{ secrets.DOCKER_IMAGE_SIMULATOR }}
DOCKER_IMAGE_SCORING: ${{ secrets.DOCKER_IMAGE_SCORING }}
GITOPS_EMAIL: ${{ secrets.GITOPS_EMAIL }}
GITOPS_TOKEN: ${{ secrets.GITOPS_TOKEN }}
GITOPS_ORG: ${{ secrets.GITOPS_ORG }}
build-docker-images:
needs:
validate-docker-secrets
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- name: Bump version and push tag
id: bump-version-action
uses: ibm-cloud-architecture/github-tag-action@master
env:
DEFAULT_BUMP: patch
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Install Appsody CLI
id: install-appsody-cli
uses: ibm-cloud-architecture/appsody-install-action@master
- name: Build the simulator docker image
id: build-simulator-image
run: |
echo "Build and push the docker image"
IMAGE_NAME="${DOCKER_REG}/${DOCKER_R}/${DOCKER_I}"
docker login -u ${DOCKER_U} -p ${DOCKER_P} ${DOCKER_REG}
cd ${WORKDIR}
appsody build --tag ${IMAGE_NAME}:${IMAGE_TAG} --push
docker tag ${IMAGE_NAME}:${IMAGE_TAG} ${IMAGE_NAME}:latest
docker push ${IMAGE_NAME}
env:
DOCKER_U: ${{ secrets.DOCKER_USERNAME }}
DOCKER_P: ${{ secrets.DOCKER_PASSWORD }}
DOCKER_R: ${{ secrets.DOCKER_REPOSITORY }}
DOCKER_REG: ${{ secrets.DOCKER_REGISTRY }}
DOCKER_I: ${{ secrets.DOCKER_IMAGE_SIMULATOR }}
WORKDIR: simulator
IMAGE_TAG: ${{ steps.bump-version-action.outputs.new_tag }}
- name: Save simulator app-deploy.yaml
uses: actions/upload-artifact@v2
with:
name: simulator-app-deploy.yaml
path: simulator/app-deploy.yaml
- name: Build the scoring-mp docker image
id: build-scoring-image
run: |
echo "Build and push the docker image"
IMAGE_NAME="${DOCKER_REG}/${DOCKER_R}/${DOCKER_I}"
docker login -u ${DOCKER_U} -p ${DOCKER_P} ${DOCKER_REG}
cd ${WORKDIR}
appsody build --tag ${IMAGE_NAME}:${IMAGE_TAG} --push
docker tag ${IMAGE_NAME}:${IMAGE_TAG} ${IMAGE_NAME}:latest
docker push ${IMAGE_NAME}
env:
DOCKER_U: ${{ secrets.DOCKER_USERNAME }}
DOCKER_P: ${{ secrets.DOCKER_PASSWORD }}
DOCKER_R: ${{ secrets.DOCKER_REPOSITORY }}
DOCKER_REG: ${{ secrets.DOCKER_REGISTRY }}
DOCKER_I: ${{ secrets.DOCKER_IMAGE_SCORING }}
WORKDIR: scoring-mp
IMAGE_TAG: ${{ steps.bump-version-action.outputs.new_tag }}
- name: Save scoring-mp app-deploy.yaml
uses: actions/upload-artifact@v2
with:
name: scoringmp-app-deploy.yaml
path: scoring-mp/app-deploy.yaml
update-gitops:
needs:
build-docker-images
runs-on: ubuntu-latest
steps:
- name: Configure git client
id: configure-git
uses: ibm-cloud-architecture/git-config-action@master
with:
user-email: ${{ secrets.GITOPS_EMAIL }}
gitops-token: ${{ secrets.GITOPS_TOKEN }}
- name: Retrieve simulator app-deploy.yaml
uses: actions/download-artifact@v2
with:
name: simulator-app-deploy.yaml
path: reefersimulator
- name: Update simulator app-deploy.yaml in GitOps repo
id: update-ordercommand-gitops
uses: ibm-cloud-architecture/appsody-gitops-update-action@master
with:
service-name: reefersimulator
github-org: ${{ secrets.GITOPS_ORG }}
gitops-repo-name: refarch-kc-gitops
- name: Retrieve scoringmp app-deploy.yaml
uses: actions/download-artifact@v2
with:
name: scoringmp-app-deploy.yaml
path: scoringmp
- name: Update scoringmp app-deploy.yaml in GitOps repo
id: update-scoringmp-gitops
uses: ibm-cloud-architecture/appsody-gitops-update-action@master
with:
service-name: scoringmp
github-org: ${{ secrets.GITOPS_ORG }}
gitops-repo-name: refarch-kc-gitops