Adding policy manager and a1 sdnc vth
[it/otf.git] / a1-policy-manager-vth / Jenkinsfile
diff --git a/a1-policy-manager-vth/Jenkinsfile b/a1-policy-manager-vth/Jenkinsfile
new file mode 100644 (file)
index 0000000..3244ca2
--- /dev/null
@@ -0,0 +1,158 @@
+#!/usr/bin/env groovy\r
+\r
+/*  Copyright (c) 2019 AT&T Intellectual Property.                             #\r
+#                                                                              #\r
+#   Licensed under the Apache License, Version 2.0 (the "License");            #\r
+#   you may not use this file except in compliance with the License.           #\r
+#   You may obtain a copy of the License at                                    #\r
+#                                                                              #\r
+#       http://www.apache.org/licenses/LICENSE-2.0                             #\r
+#                                                                              #\r
+#   Unless required by applicable law or agreed to in writing, software        #\r
+#   distributed under the License is distributed on an "AS IS" BASIS,          #\r
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #\r
+#   See the License for the specific language governing permissions and        #\r
+#   limitations under the License.                                             #\r
+##############################################################################*/\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: "m13591_otf_dev"],\r
+    [$class: 'hudson.model.StringParameterDefinition', name: 'KUBE_CONFIG', defaultValue: "kubeConfig-dev"],\r
+    [$class: 'hudson.model.StringParameterDefinition', name: 'TILLER_NAMESPACE', defaultValue: "com-att-ecomp-otf-dev"]\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="a1-policy-manager-vth";\r
+      VERSION="0.0.1-SNAPSHOT";\r
+      NAMESPACE="com.att.ecomp.otf" //TODO change back to org-otf-oran when done testing\r
+        DOCKER_REGISTRY="dockercentral.it.att.com:5100"\r
+\r
+        if( ENV.equalsIgnoreCase("dev") ){\r
+          IMAGE_NAME=DOCKER_REGISTRY + "/" + NAMESPACE + ".dev" + "/" + 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
+              dir("./a1-policy-manager-vth"){\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
+\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.14.3-linux-amd64.tar.gz\r
+                  tar -xf helm-v2.14.3-linux-amd64.tar.gz\r
+                  rm helm-v2.14.3-linux-amd64.tar.gz\r
+                  """\r
+              }\r
+\r
+            withCredentials([file(credentialsId: KUBE_CONFIG, variable: 'KUBECONFIG')]) {\r
+\r
+              dir('a1-policy-manager-vth/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([usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {\r
+\r
+                      sh """\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
+\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
+\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
+\r
+                        """\r
+                    }\r
+                }\r
+\r
+              }\r
+            }\r
+          }\r
+\r
+        }\r
+    }\r