added svcapi ui and camunda code
[it/otf.git] / otf-camunda / Jenkinsfile
diff --git a/otf-camunda/Jenkinsfile b/otf-camunda/Jenkinsfile
new file mode 100644 (file)
index 0000000..1548993
--- /dev/null
@@ -0,0 +1,197 @@
+#!/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: "username"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'KUBE_CONFIG', defaultValue: "kubeConfig-dev"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'OTF_MONGO_DB', defaultValue: "otf_mongo_dev_db"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'OTF_CAMUNDA_DB', defaultValue: "otf_camunda_dev_db"],\r
+        [$class: 'hudson.model.StringParameterDefinition', name: 'TILLER_NAMESPACE', defaultValue: "org.oran.otf"]\r
+\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
+    pom = readMavenPom file: 'pom.xml'\r
+    ARTIFACT_ID = pom.artifactId;\r
+    VERSION = pom.version;\r
+    LABEL_VERSION = pom.version.replaceAll("\\.", "-");\r
+    echo "LabelVerion: " + LABEL_VERSION\r
+    NAMESPACE = pom.groupId\r
+    echo "Tiller Namespace: " + TILLER_NAMESPACE\r
+    DOCKER_REGISTRY = pom.properties['docker.registry']\r
+\r
+       if( ENV.equalsIgnoreCase("dev") ){\r
+           IMAGE_NAME = pom.properties['docker.registry'] + "/" + NAMESPACE  + "/" + ARTIFACT_ID + ":" + VERSION\r
+       }\r
+       if( ENV.equalsIgnoreCase("prod") || ENV.equalsIgnoreCase("prod-dr") ){\r
+           IMAGE_NAME = pom.properties['docker.registry'] + "/" + NAMESPACE + ".prod" + "/" + ARTIFACT_ID + ":" + VERSION\r
+       }\r
+\r
+    if( ENV.equalsIgnoreCase("st") ){\r
+        IMAGE_NAME = pom.properties['docker.registry'] + "/" + NAMESPACE + ".st" + "/" + ARTIFACT_ID + ":" + VERSION\r
+    }\r
+    echo "Artifact: " + IMAGE_NAME\r
+\r
+\r
+       if( ENV.equalsIgnoreCase("dev") ){\r
+               ROUTER_CONFIG="mysqlRouterConfig-dev.ini"\r
+       }\r
+    if( ENV.equalsIgnoreCase("st") ){\r
+        ROUTER_CONFIG="mysqlRouterConfig-st.ini"\r
+    }\r
+       if( ENV.equalsIgnoreCase("prod") || ENV.equalsIgnoreCase("prod-dr")){\r
+               ROUTER_CONFIG="mysqlRouterConfig-prod.ini"\r
+       }\r
+\r
+    withEnv(["PATH=${env.PATH}:${tool 'mvn352'}/bin:${tool 'jdk180'}/bin:${env.WORKSPACE}/linux-amd64", "JAVA_HOME=${tool 'jdk180'}", "MAVEN_HOME=${tool 'mvn352'}", "HELM_HOME=${env.WORKSPACE}"]) {\r
+\r
+        echo "JAVA_HOME=${env.JAVA_HOME}"\r
+        echo "MAVEN_HOME=${env.MAVEN_HOME}"\r
+        echo "PATH=${env.PATH}"\r
+        echo "HELM_HOME=${env.HELM_HOME}"\r
+\r
+        wrap([$class: 'ConfigFileBuildWrapper', managedFiles: [\r
+                [fileId: 'maven-settings.xml', variable: 'MAVEN_SETTINGS'],\r
+                [fileId: 'maven-settings-security.xml', variable: 'MAVEN_SETTINGS_SECURITY']\r
+        ]]) {\r
+\r
+\r
+            if (PHASES.contains("BUILD")) {\r
+                stage 'Compile'\r
+                sh 'mvn -s $MAVEN_SETTINGS -Dsettings.security=$MAVEN_SETTINGS_SECURITY clean compile'\r
+\r
+                stage 'Unit Test'\r
+                sh 'mvn -s $MAVEN_SETTINGS -Dsettings.security=$MAVEN_SETTINGS_SECURITY test'\r
+\r
+                stage 'Package'\r
+                sh 'mvn -s $MAVEN_SETTINGS -Dsettings.security=$MAVEN_SETTINGS_SECURITY package'\r
+                //sh 'mvn -DskipTests -Dmaven.test.skip=true -s $MAVEN_SETTINGS package'\r
+\r
+                stage 'Verify'\r
+                sh 'mvn -s $MAVEN_SETTINGS -Dsettings.security=$MAVEN_SETTINGS_SECURITY verify'\r
+\r
+                stage 'Publish Artifact'\r
+\r
+                withCredentials([usernamePassword(credentialsId: MECHID, usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {\r
+\r
+                    echo "Artifact: " + DOCKER_REGISTRY\r
+\r
+                    sh """\r
+                                               docker login $DOCKER_REGISTRY --username $USERNAME --password $PASSWORD\r
+                                               docker build -t $IMAGE_NAME -f target/Dockerfile target\r
+                                               docker push $IMAGE_NAME\r
+                                       """\r
+                }\r
+\r
+            }\r
+            if (PHASES.contains("DEPLOY") || PHASES.contains("UNDEPLOY") || PHASES.contains("UNDEPLOYFORCE")) {\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
+                } 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
+                        if (PHASES.contains("UNDEPLOYFORCE")) {\r
+                            stage 'Undeploy Force'\r
+\r
+                            sh """\r
+                                \r
+                                                       helm delete --tiller-namespace=$TILLER_NAMESPACE --purge $ARTIFACT_ID &\r
+                                chmod 755 forceDelete.sh\r
+                                ./forceDelete.sh $ARTIFACT_ID\r
+                                               """\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: OTF_MONGO_DB, usernameVariable: 'USERNAME_MONGO', passwordVariable: 'PASSWORD_MONGO'),\r
+                                       usernamePassword(credentialsId: OTF_CAMUNDA_DB, usernameVariable: 'USERNAME_CAMUNDA', passwordVariable: 'PASSWORD_CAMUNDA')\r
+                               ]) {\r
+\r
+                                sh """                                                                         \r
+                                                                               \r
+                                                                               echo "Validate Yaml"\r
+                                                                               helm lint $ARTIFACT_ID\r
+\r
+                                                                               echo "View Helm Templates"\r
+                                                                               helm template $ARTIFACT_ID \\r
+                                                                                       --set appName=$ARTIFACT_ID \\r
+                                                                                       --set version=$VERSION  \\r
+                                                                                       --set image=$IMAGE_NAME \\r
+                                                                                       --set namespace=$TILLER_NAMESPACE \\r
+                                                                                       --set env=$ENV \\r
+                                                                                       --set otf.mongo.username=$USERNAME_MONGO \\r
+                                                                                       --set otf.mongo.password=$PASSWORD_MONGO \\r
+                                                                                       --set otf.camunda.db.username=$USERNAME_CAMUNDA \\r
+                                                                                       --set otf.camunda.db.password=$PASSWORD_CAMUNDA \\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 version=$VERSION  \\r
+                                                                                       --set image=$IMAGE_NAME \\r
+                                                                                       --set namespace=$TILLER_NAMESPACE \\r
+                                                                                       --set env=$ENV \\r
+                                                                                       --set otf.mongo.username=$USERNAME_MONGO \\r
+                                                                                       --set otf.mongo.password=$PASSWORD_MONGO \\r
+                                                                                       --set otf.camunda.db.username=$USERNAME_CAMUNDA \\r
+                                                                                       --set otf.camunda.db.password=$PASSWORD_CAMUNDA \\r
+       \r
+                                                                                       \r
+                                                                               echo "Helm Install/Upgrade"\r
+                                                                       helm upgrade --tiller-namespace=$TILLER_NAMESPACE --install $ARTIFACT_ID $ARTIFACT_ID \\r
+                                                                                       --set version=$VERSION  \\r
+                                                                                       --set image=$IMAGE_NAME \\r
+                                                                                       --set namespace=$TILLER_NAMESPACE \\r
+                                                                                       --set env=$ENV \\r
+                                                                                       --set otf.mongo.username=$USERNAME_MONGO \\r
+                                                                                       --set otf.mongo.password=$PASSWORD_MONGO \\r
+                                                                                       --set otf.camunda.db.username=$USERNAME_CAMUNDA \\r
+                                                                                       --set otf.camunda.db.password=$PASSWORD_CAMUNDA \\r
+\r
+                                                                       """\r
+                            }\r
+                        }\r
+\r
+                    }\r
+                }\r
+            }\r
+        }\r
+    }\r
+}
\ No newline at end of file