Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
A
alfa
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
OZG-Cloud
app
alfa
Commits
aca845b1
Commit
aca845b1
authored
2 years ago
by
OZGCloud
Browse files
Options
Downloads
Patches
Plain Diff
ozg-2502 trigger test rollout
parent
1542dfe3
No related branches found
No related tags found
No related merge requests found
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
Jenkinsfile
+70
-35
70 additions, 35 deletions
Jenkinsfile
with
70 additions
and
35 deletions
Jenkinsfile
+
70
−
35
View file @
aca845b1
...
...
@@ -125,22 +125,6 @@ pipeline {
}
}
}
stage
(
'Init k8s'
)
{
steps
{
script
{
FAILED_STAGE
=
env
.
STAGE_NAME
E2E_FAILED
=
""
}
container
(
"k8s"
)
{
configFileProvider
([
configFile
(
fileId:
'jenkins-kuby-kubeconfig'
,
variable:
'KUBE_CONFIG'
)])
{
sh
'mkdir ~/.kube'
sh
'cp ${KUBE_CONFIG} ~/.kube/config'
}
sh
'helm version'
}
}
}
stage
(
'Deploy Maven Artifacts to Nexus'
)
{
when
{
anyOf
{
...
...
@@ -190,14 +174,26 @@ pipeline {
}
}
}
stage
(
'Rollout (kiel-dev & ea-dev) | (kiel-test $ sl-test) Goofy'
)
{
stage
(
'Init k8s'
)
{
steps
{
script
{
FAILED_STAGE
=
env
.
STAGE_NAME
E2E_FAILED
=
""
}
container
(
"k8s"
)
{
configFileProvider
([
configFile
(
fileId:
'jenkins-kuby-kubeconfig'
,
variable:
'KUBE_CONFIG'
)])
{
sh
'mkdir ~/.kube'
sh
'cp ${KUBE_CONFIG} ~/.kube/config'
sh
'cat ~/.kube/config'
}
sh
'helm version'
}
}
}
stage
(
'Rollout Dev Goofy'
)
{
when
{
anyOf
{
branch
'master'
branch
'release'
}
}
steps
{
script
{
FAILED_STAGE
=
env
.
STAGE_NAME
...
...
@@ -205,12 +201,42 @@ pipeline {
container
(
"k8s"
){
script
{
if
(
env
.
BRANCH_NAME
==
'master'
)
{
sh
'kubectl rollout restart deployment/goofy -n sh-kiel-dev'
sh
'kubectl rollout status deployment/goofy -n sh-kiel-dev'
sh
"""
error=0
for NAMESPACE in \$(kubectl get namespaces -l ozg-environment=dev -o custom-columns=NAME:.metadata.name --no-headers); \
do \
if kubectl get deployment -n \$NAMESPACE | grep goofy; then \
kubectl rollout restart deployment/goofy -n \$NAMESPACE; \
if ! kubectl rollout status deployment/goofy -n \$NAMESPACE; then \
error=1; \
fi; \
fi; \
done
exit \$error
"""
}
}
}
}
stage
(
'Trigger Test rollout'
)
{
when
{
branch
'release'
}
steps
{
script
{
FAILED_STAGE
=
env
.
STAGE_NAME
withCredentials
([
usernamePassword
(
credentialsId:
'jenkins-gitea-access-token'
,
passwordVariable:
'TOKEN'
,
usernameVariable:
'USER'
)])
{
sh
'git clone https://${USER}:${TOKEN}@git.ozg-sh.de/mgm/rollout.git'
dir
(
'rollout'
)
{
sh
"sed -i 's/GOOFY_APP_VERSION\\=.*/GOOFY_APP_VERSION=${VERSION}/' versions/dev/versions.sh"
sh
'kubectl rollout restart deployment/goofy -n sh-ea-dev'
sh
'kubectl rollout status deployment/goofy -n sh-ea-dev'
sh
'git add versions/dev/versions.sh'
sh
'git config user.email "jenkins@ozg.de"'
sh
'git config user.name "jenkins"'
sh
"git commit -m 'jenkins rollout goofy ${VERSION}'"
sh
'git push https://${USER}:${TOKEN}@git.ozg-sh.de/mgm/rollout.git'
}
}
}
...
...
@@ -329,7 +355,7 @@ Void checkIfNamespaceExists(String namespace) {
def
namespaceList
=
sh
(
script:
'kubectl get namespaces'
,
returnStdout:
true
)
if
(
namespaceList
.
contains
(
namespace
))
{
error
(
"N
amespace
:
${namespace}
existiert bereits"
)
sh
"kubectl delete n
amespace ${namespace}
"
}
}
}
...
...
@@ -337,9 +363,7 @@ Void checkIfNamespaceExists(String namespace) {
Void
startPluto
(
String
namespace
,
String
values
,
String
bezeichner
)
{
container
(
"k8s"
)
{
dir
(
'goofy-client/apps/goofy-e2e/deployment-values/pluto'
)
{
withCredentials
([
usernamePassword
(
credentialsId:
'jenkins-nexus-login'
,
usernameVariable:
'USER'
,
passwordVariable:
'PASSWORD'
)])
{
sh
"helm upgrade --install --create-namespace pluto pluto -f ${values} --set kop.bezeichner=${bezeichner} --namespace ${namespace} --version 0.12.0-SNAPSHOT"
+
' --repo https://nexus.ozg-sh.de/repository/ozg-base-apps-snapshot --username ${USER} --password ${PASSWORD} --wait --wait-for-jobs'
}
sh
"helm upgrade --install --create-namespace pluto ozg-base-apps-snapshot/pluto -f ${values} --set kop.bezeichner=${bezeichner} --namespace ${namespace} --version ${getLatestChartVersion('pluto').trim()} --wait --wait-for-jobs"
}
sh
"kubectl rollout status statefulset/pluto-database -n ${namespace}"
...
...
@@ -349,9 +373,7 @@ Void startPluto(String namespace, String values, String bezeichner) {
Void
startGoofy
(
String
namespace
,
String
values
,
String
imageTag
,
String
bezeichner
)
{
container
(
"k8s"
)
{
dir
(
'goofy-client/apps/goofy-e2e/deployment-values/goofy'
)
{
withCredentials
([
usernamePassword
(
credentialsId:
'jenkins-nexus-login'
,
usernameVariable:
'USER'
,
passwordVariable:
'PASSWORD'
)])
{
sh
"helm upgrade --install --create-namespace goofy goofy -f ${values} --set image.tag=${imageTag} --set kop.bezeichner=${bezeichner} --namespace ${namespace} --version 0.14.0-SNAPSHOT"
+
' --repo https://nexus.ozg-sh.de/repository/ozg-base-apps-snapshot --username ${USER} --password ${PASSWORD} --wait --wait-for-jobs'
}
sh
"helm upgrade --install --create-namespace goofy ozg-base-apps-snapshot/goofy -f ${values} --set image.tag=${imageTag} --set kop.bezeichner=${bezeichner} --namespace ${namespace} --version ${getLatestChartVersion('goofy').trim()} --wait --wait-for-jobs"
}
createKeycloakGroups
(
namespace
)
...
...
@@ -360,6 +382,12 @@ Void startGoofy(String namespace, String values, String imageTag, String bezeich
}
}
String
getLatestChartVersion
(
String
chart
)
{
container
(
"k8s"
)
{
return
sh
(
script:
"helm search repo ozg-base-apps-snapshot --devel -l -o json | jq -r 'first(.[] | select((.name==\"ozg-base-apps-snapshot/${chart}\") and (.version|match(\"SNAPSHOT\$\"))) | .version)'"
,
returnStdout:
true
)
}
}
String
runTests
(
String
stageName
,
String
reportFolder
)
{
container
(
"cypress"
)
{
try
{
...
...
@@ -397,6 +425,12 @@ String generateBezeichner(String stage) {
def
branchName
=
makeUrlConform
(
env
.
BRANCH_NAME
)
def
stageName
=
makeUrlConform
(
stage
)
def
cutBranchNamePosition
=
30
-
(
branchName
.
length
()
+
stageName
.
length
()
+
8
)
if
(
cutBranchNamePosition
<
0
)
{
branchName
=
branchName
[
0
..
cutBranchNamePosition
]
}
return
"${branchName}${stageName}"
}
...
...
@@ -412,6 +446,7 @@ Void generateKeycloakUserYaml(String namespace) {
def
userJson
=
readJSON
file:
'goofy-client/apps/goofy-e2e/src/fixtures/user/'
+
user
newUserYaml
.
metadata
.
name
=
namespace
+
"-"
+
userJson
.
name
newUserYaml
.
metadata
.
namespace
=
namespace
newUserYaml
.
metadata
.
labels
.
realm
=
namespace
newUserYaml
.
spec
.
realmSelector
.
matchLabels
.
realm
=
namespace
newUserYaml
.
spec
.
user
.
username
=
userJson
.
name
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment