adding vth code as well as aaf and cert config
[it/otf.git] / otf-ssh-test-head / Jenkinsfile
1 #!/usr/bin/env groovy\r
2 \r
3 \r
4 properties([[$class: 'ParametersDefinitionProperty', parameterDefinitions: [\r
5         [$class: 'hudson.model.StringParameterDefinition', name: 'PHASE', defaultValue: "BUILD"],\r
6         [$class: 'hudson.model.StringParameterDefinition', name: 'ENV', defaultValue: "dev"],\r
7         [$class: 'hudson.model.StringParameterDefinition', name: 'MECHID', defaultValue: "id_otf_dev"],\r
8         [$class: 'hudson.model.StringParameterDefinition', name: 'KUBE_CONFIG', defaultValue: "kubeConfig-dev"],\r
9         [$class: 'hudson.model.StringParameterDefinition', name: 'TILLER_NAMESPACE', defaultValue: "org-oran-otf"]\r
10 ]]])\r
11 \r
12 \r
13 echo "Build branch: ${env.BRANCH_NAME}"\r
14 \r
15 node("docker"){\r
16         stage 'Checkout'\r
17         checkout scm\r
18         PHASES=PHASE.tokenize( '_' );\r
19         echo "PHASES : " + PHASES\r
20 \r
21 \r
22         ARTIFACT_ID="otf-ssh-test-head";\r
23         VERSION="Blitzcrank.1.1";\r
24         NAMESPACE="org-oran-otf"\r
25         DOCKER_REGISTRY="registry.hub.docker.io"\r
26 \r
27   if( ENV.equalsIgnoreCase("dev") ){\r
28     IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + "/" + ARTIFACT_ID +  ":" + VERSION\r
29 \r
30   }\r
31   if( ENV.equalsIgnoreCase("prod") || ENV.equalsIgnoreCase("prod-dr")){\r
32     IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".prod" + "/" + ARTIFACT_ID +  ":" + VERSION\r
33 \r
34   }\r
35 \r
36   if( ENV.equalsIgnoreCase("st") ){\r
37     IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".st" + "/" + ARTIFACT_ID +  ":" + VERSION\r
38 \r
39   }\r
40 \r
41         echo "Artifact: " + IMAGE_NAME\r
42 \r
43         withEnv(["PATH=${env.PATH}:${env.WORKSPACE}/linux-amd64", "HELM_HOME=${env.WORKSPACE}"]) {\r
44 \r
45                 echo "PATH=${env.PATH}"\r
46                 echo "HELM_HOME=${env.HELM_HOME}"\r
47 \r
48                 if (PHASES.contains("BUILD")){\r
49 \r
50                         stage 'Publish Artifact'\r
51 \r
52                                 withCredentials([usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {\r
53 \r
54                                 echo "Artifact: " + IMAGE_NAME\r
55 \r
56                                 sh """\r
57                                         docker login $DOCKER_REGISTRY --username $USERNAME --password $PASSWORD\r
58                                         docker build -t $IMAGE_NAME .\r
59                                         docker push $IMAGE_NAME\r
60                                 """\r
61                                 }\r
62 \r
63                 }\r
64 \r
65                 if (PHASES.contains("DEPLOY") || PHASES.contains("UNDEPLOY")) {\r
66 \r
67                         stage 'Init Helm'\r
68 \r
69                         //check if helm exists if not install\r
70                         if(fileExists('linux-amd64/helm')){\r
71                                 sh """\r
72                                         echo "helm is already installed"\r
73                                 """\r
74                         }\r
75                         else{\r
76                         //download helm\r
77                                 sh """\r
78                                         echo "installing helm"\r
79                                         wget  https://storage.googleapis.com/kubernetes-helm/helm-v2.8.2-linux-amd64.tar.gz\r
80                                         tar -xf helm-v2.8.2-linux-amd64.tar.gz\r
81                                         rm helm-v2.8.2-linux-amd64.tar.gz\r
82                                 """\r
83                         }\r
84 \r
85                         withCredentials([file(credentialsId: KUBE_CONFIG, variable: 'KUBECONFIG')]) {\r
86 \r
87                                 dir('helm'){\r
88                                 //check if charts are valid, and then perform dry run, if successful then upgrade/install charts\r
89 \r
90                                         if (PHASES.contains("UNDEPLOY") ) {\r
91                                                 stage 'Undeploy'\r
92 \r
93                                                 sh """\r
94                                                         helm delete --tiller-namespace=$TILLER_NAMESPACE --purge $ARTIFACT_ID\r
95                                                 """\r
96                                         }\r
97 \r
98                                 //NOTE Double quotes are used below to access groovy variables like artifact_id and tiller_namespace\r
99                         if (PHASES.contains("DEPLOY") ){\r
100                                 stage 'Deploy'\r
101                                                         withCredentials([\r
102                                                                 usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD'),\r
103                                                                 file(credentialsId: 'id_PRIVATE_KEY', variable: 'VAR_id_PRIVATE_KEY'),\r
104                                                                 string(credentialsId: 'id_otf_key_passphrase', variable: 'VAR_id_otf_key_passphrase')\r
105                                                         ]) {\r
106 \r
107                                                                 sh """\r
108                                                                         \r
109                                                                         cp $VAR_id_PRIVATE_KEY $ARTIFACT_ID\r
110                                                 FILE_id_PRIVATE_KEY=`basename $VAR_id_PRIVATE_KEY`\r
111 \r
112                                                                         echo "Validate Yaml"\r
113                                                                         helm lint $ARTIFACT_ID\r
114 \r
115                                                                         echo "View Helm Templates"\r
116                                                                         helm template $ARTIFACT_ID --set appName=$ARTIFACT_ID \\r
117                                                                         --set appName=$ARTIFACT_ID \\r
118                                                                         --set version=$VERSION  \\r
119                                                                         --set env=$ENV \\r
120                                                                         --set image=$IMAGE_NAME \\r
121                                                                         --set namespace=$TILLER_NAMESPACE \\r
122                                             --set Secret.id_private_key=\$FILE_id_PRIVATE_KEY \\r
123                                     --set Secret.id_private_key_passphrase=$VAR_id_otf_key_passphrase \\r
124 \r
125 \r
126 \r
127                                                                         echo "Perform Dry Run Of Install"\r
128                                                                         helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install --dry-run $ARTIFACT_ID $ARTIFACT_ID \\r
129                                                                         --set appName=$ARTIFACT_ID \\r
130                                                                         --set version=$VERSION  \\r
131                                                                         --set env=$ENV \\r
132                                                                         --set image=$IMAGE_NAME \\r
133                                                                         --set namespace=$TILLER_NAMESPACE \\r
134                                             --set Secret.id_private_key=\$FILE_id_PRIVATE_KEY \\r
135                                     --set Secret.id_private_key_passphrase=$VAR_id_otf_key_passphrase \\r
136 \r
137 \r
138                                                                         echo "Helm Install/Upgrade"\r
139                                                                 helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install $ARTIFACT_ID $ARTIFACT_ID \\r
140                                                                         --set appName=$ARTIFACT_ID \\r
141                                                                         --set version=$VERSION  \\r
142                                                                         --set env=$ENV \\r
143                                                                         --set image=$IMAGE_NAME \\r
144                                                                         --set namespace=$TILLER_NAMESPACE \\r
145                                             --set Secret.id_private_key=\$FILE_id_PRIVATE_KEY \\r
146                                     --set Secret.id_private_key_passphrase=$VAR_id_otf_key_passphrase \\r
147 \r
148                                                                 """\r
149                                                         }\r
150                         }\r
151 \r
152                                 }\r
153                         }\r
154         }\r
155 \r
156         }\r
157 }\r