-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path.gitlab-ci.yml
144 lines (137 loc) · 3.98 KB
/
.gitlab-ci.yml
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
stages:
- build-image
- cloud-deploy
variables:
LANG: "en_US.UTF-8"
LC_ALL: "en_US.UTF-8"
GIT_DEPTH: 0
GIT_SUBMODULE_STRATEGY: normal
# Use TLS https://docs.gitlab.com/ee/ci/docker/using_docker_build.html#tls-enabled
DOCKER_HOST: tcp://docker:2376
DOCKER_TLS_CERTDIR: "/certs"
# These are usually specified by the entrypoint, however the
# Kubernetes executor doesn't run entrypoints
# https://gitlab.com/gitlab-org/gitlab-runner/-/issues/4125
DOCKER_TLS_VERIFY: 1
DOCKER_CERT_PATH: "$DOCKER_TLS_CERTDIR/client"
DOCKER_DRIVER: overlay2
build-and-push: &build-and-push
image:
name: gcr.io/kaniko-project/executor:debug
entrypoint: [""]
tags:
- self-docker
stage: build-image
needs: []
script:
- mkdir -p /kaniko/.docker
- echo "{\"auths\":{\"${CI_REGISTRY}\":{\"auth\":\"$(printf "%s:%s" "${CI_REGISTRY_USER}" "${CI_REGISTRY_PASSWORD}" | base64 | tr -d '\n')\"}}}" > /kaniko/.docker/config.json
- chmod +x ./tools/shell-script/package.sh
- sh ./tools/shell-script/package.sh
rules:
- when: never
retry:
max: 2
when:
- stuck_or_timeout_failure
- runner_system_failure
build-and-push:staging:
<<: *build-and-push
stage: build-image
needs: []
variables:
PROJECT_NAME: yggdrasil-core-engine
rules:
- if: '$CI_COMMIT_BRANCH == "develop"'
retry:
max: 2
when:
- stuck_or_timeout_failure
- runner_system_failure
build-and-push-discord-client:staging:
<<: *build-and-push
stage: build-image
needs: []
variables:
PROJECT_NAME: yggdrasil-discord-client
rules:
- if: '$CI_COMMIT_BRANCH == "develop"'
retry:
max: 2
when:
- stuck_or_timeout_failure
- runner_system_failure
cloud-deploy: &cloud-deploy
image: alpine:3.14
stage: cloud-deploy
tags:
- self-docker
before_script:
- apk update && apk add --no-cache curl nodejs npm
- curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl
- chmod +x ./kubectl && mv ./kubectl /usr/local/bin/kubectl
- mkdir -p $HOME/.kube
- echo -n $KUBE_CONFIG | base64 -d > $HOME/.kube/config
- kubectl config view
script:
- echo $NODE_ENV
- echo $KUBE_NAME_SPACE
- echo $PROJECT_NAME
- kubectl delete jobs --all -n $KUBE_NAME_SPACE
- kubectl delete cronjobs --all -n $KUBE_NAME_SPACE
- chmod +x ./tools/shell-script/build-cdk8s.sh
- sh ./tools/shell-script/build-cdk8s.sh
- kubectl create secret docker-registry gitlab-registry --docker-server="$CI_REGISTRY" --docker-username="$CI_DEPLOY_USER" --docker-password="$CI_DEPLOY_PASSWORD" --docker-email="$GITLAB_USER_EMAIL" -n $KUBE_NAME_SPACE -o yaml --dry-run=client | kubectl apply -f -
- kubectl apply -f ./tools/cdk8s/${PROJECT_NAME}/dist/*.yaml -n $KUBE_NAME_SPACE
rules:
- when: never
artifacts:
name: "${PROJECT_NAME}-$CI_JOB_NAME-$CI_COMMIT_REF_NAME"
paths:
- ./tools/cdk8s/${PROJECT_NAME}/dist/*
expire_in: 3 days
retry:
max: 2
when:
- stuck_or_timeout_failure
- runner_system_failure
cloud-deploy:staging:
<<: *cloud-deploy
stage: cloud-deploy
needs: [
'build-and-push:staging'
]
variables:
NODE_ENV: staging
KUBE_NAME_SPACE: yggdrasil-core-engine-staging
PROJECT_NAME: yggdrasil-core-engine
rules:
- if: '$CI_COMMIT_BRANCH == "develop"'
environment:
name: staging
action: prepare
retry:
max: 2
when:
- stuck_or_timeout_failure
- runner_system_failure
cloud-deploy-discord-client:staging:
<<: *cloud-deploy
stage: cloud-deploy
needs: [
'build-and-push-discord-client:staging'
]
variables:
NODE_ENV: staging
KUBE_NAME_SPACE: yggdrasil-discord-client-staging
PROJECT_NAME: yggdrasil-discord-client
rules:
- if: '$CI_COMMIT_BRANCH == "develop"'
environment:
name: staging
action: prepare
retry:
max: 2
when:
- stuck_or_timeout_failure
- runner_system_failure