adding vth code as well as aaf and cert config
[it/otf.git] / otf-ssh-test-head / Jenkinsfile
diff --git a/otf-ssh-test-head/Jenkinsfile b/otf-ssh-test-head/Jenkinsfile
new file mode 100644 (file)
index 0000000..c19179c
--- /dev/null
@@ -0,0 +1,157 @@
+#!/usr/bin/env groovy\r
+\r
+\r
+properties([[$class: 'ParametersDefinitionProperty', parameterDefinitions: [\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'PHASE', defaultValue: "BUILD"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'ENV', defaultValue: "dev"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'MECHID', defaultValue: "id_otf_dev"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'KUBE_CONFIG', defaultValue: "kubeConfig-dev"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'TILLER_NAMESPACE', defaultValue: "org-oran-otf"]\r
+]]])\r
+\r
+\r
+echo "Build branch: ${env.BRANCH_NAME}"\r
+\r
+node("docker"){\r
+       stage 'Checkout'\r
+       checkout scm\r
+       PHASES=PHASE.tokenize( '_' );\r
+       echo "PHASES : " + PHASES\r
+\r
+\r
+       ARTIFACT_ID="otf-ssh-test-head";\r
+       VERSION="Blitzcrank.1.1";\r
+       NAMESPACE="org-oran-otf"\r
+       DOCKER_REGISTRY="registry.hub.docker.io"\r
+\r
+  if( ENV.equalsIgnoreCase("dev") ){\r
+    IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + "/" + ARTIFACT_ID +  ":" + VERSION\r
+\r
+  }\r
+  if( ENV.equalsIgnoreCase("prod") || ENV.equalsIgnoreCase("prod-dr")){\r
+    IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".prod" + "/" + ARTIFACT_ID +  ":" + VERSION\r
+\r
+  }\r
+\r
+  if( ENV.equalsIgnoreCase("st") ){\r
+    IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".st" + "/" + ARTIFACT_ID +  ":" + VERSION\r
+\r
+  }\r
+\r
+       echo "Artifact: " + IMAGE_NAME\r
+\r
+       withEnv(["PATH=${env.PATH}:${env.WORKSPACE}/linux-amd64", "HELM_HOME=${env.WORKSPACE}"]) {\r
+\r
+               echo "PATH=${env.PATH}"\r
+               echo "HELM_HOME=${env.HELM_HOME}"\r
+\r
+               if (PHASES.contains("BUILD")){\r
+\r
+                       stage 'Publish Artifact'\r
+\r
+                               withCredentials([usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {\r
+\r
+                               echo "Artifact: " + IMAGE_NAME\r
+\r
+                               sh """\r
+                                       docker login $DOCKER_REGISTRY --username $USERNAME --password $PASSWORD\r
+                                       docker build -t $IMAGE_NAME .\r
+                                       docker push $IMAGE_NAME\r
+                               """\r
+                               }\r
+\r
+               }\r
+\r
+               if (PHASES.contains("DEPLOY") || PHASES.contains("UNDEPLOY")) {\r
+\r
+                       stage 'Init Helm'\r
+\r
+                       //check if helm exists if not install\r
+                       if(fileExists('linux-amd64/helm')){\r
+                               sh """\r
+                                       echo "helm is already installed"\r
+                               """\r
+                       }\r
+                       else{\r
+                       //download helm\r
+                               sh """\r
+                                       echo "installing helm"\r
+                                       wget  https://storage.googleapis.com/kubernetes-helm/helm-v2.8.2-linux-amd64.tar.gz\r
+                                       tar -xf helm-v2.8.2-linux-amd64.tar.gz\r
+                                       rm helm-v2.8.2-linux-amd64.tar.gz\r
+                               """\r
+                       }\r
+\r
+                       withCredentials([file(credentialsId: KUBE_CONFIG, variable: 'KUBECONFIG')]) {\r
+\r
+                               dir('helm'){\r
+                               //check if charts are valid, and then perform dry run, if successful then upgrade/install charts\r
+\r
+                                       if (PHASES.contains("UNDEPLOY") ) {\r
+                                               stage 'Undeploy'\r
+\r
+                                               sh """\r
+                                                       helm delete --tiller-namespace=$TILLER_NAMESPACE --purge $ARTIFACT_ID\r
+                                               """\r
+                                       }\r
+\r
+                               //NOTE Double quotes are used below to access groovy variables like artifact_id and tiller_namespace\r
+                       if (PHASES.contains("DEPLOY") ){\r
+                               stage 'Deploy'\r
+                                                       withCredentials([\r
+                                                               usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD'),\r
+                                                               file(credentialsId: 'id_PRIVATE_KEY', variable: 'VAR_id_PRIVATE_KEY'),\r
+                                                               string(credentialsId: 'id_otf_key_passphrase', variable: 'VAR_id_otf_key_passphrase')\r
+                                                       ]) {\r
+\r
+                                                               sh """\r
+                                                                       \r
+                                                                       cp $VAR_id_PRIVATE_KEY $ARTIFACT_ID\r
+                                               FILE_id_PRIVATE_KEY=`basename $VAR_id_PRIVATE_KEY`\r
+\r
+                                                                       echo "Validate Yaml"\r
+                                                                       helm lint $ARTIFACT_ID\r
+\r
+                                                                       echo "View Helm Templates"\r
+                                                                       helm template $ARTIFACT_ID --set appName=$ARTIFACT_ID \\r
+                                                                       --set appName=$ARTIFACT_ID \\r
+                                                                       --set version=$VERSION  \\r
+                                                                       --set env=$ENV \\r
+                                                                       --set image=$IMAGE_NAME \\r
+                                                                       --set namespace=$TILLER_NAMESPACE \\r
+                                           --set Secret.id_private_key=\$FILE_id_PRIVATE_KEY \\r
+                                    --set Secret.id_private_key_passphrase=$VAR_id_otf_key_passphrase \\r
+\r
+\r
+\r
+                                                                       echo "Perform Dry Run Of Install"\r
+                                                                       helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install --dry-run $ARTIFACT_ID $ARTIFACT_ID \\r
+                                                                       --set appName=$ARTIFACT_ID \\r
+                                                                       --set version=$VERSION  \\r
+                                                                       --set env=$ENV \\r
+                                                                       --set image=$IMAGE_NAME \\r
+                                                                       --set namespace=$TILLER_NAMESPACE \\r
+                                           --set Secret.id_private_key=\$FILE_id_PRIVATE_KEY \\r
+                                    --set Secret.id_private_key_passphrase=$VAR_id_otf_key_passphrase \\r
+\r
+\r
+                                                                       echo "Helm Install/Upgrade"\r
+                                                               helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install $ARTIFACT_ID $ARTIFACT_ID \\r
+                                                                       --set appName=$ARTIFACT_ID \\r
+                                                                       --set version=$VERSION  \\r
+                                                                       --set env=$ENV \\r
+                                                                       --set image=$IMAGE_NAME \\r
+                                                                       --set namespace=$TILLER_NAMESPACE \\r
+                                           --set Secret.id_private_key=\$FILE_id_PRIVATE_KEY \\r
+                                    --set Secret.id_private_key_passphrase=$VAR_id_otf_key_passphrase \\r
+\r
+                                                               """\r
+                                                       }\r
+                       }\r
+\r
+                               }\r
+                       }\r
+       }\r
+\r
+       }\r
+}\r