From 62370a8fe5909a0a4a93339991564cd351afed26 Mon Sep 17 00:00:00 2001
From: wangzilun <964606955@qq.com>
Date: Wed, 09 Mar 2022 11:48:20 +0800
Subject: [PATCH] ttt14

---
 Jenkinsfile |  131 ++++++++++++++++++++++++++++++-------------
 1 files changed, 90 insertions(+), 41 deletions(-)

diff --git a/Jenkinsfile b/Jenkinsfile
index 49ec891..09a5aba 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -10,60 +10,87 @@
         }
     options {
         //给日志加上时间错, 需安装 Timestamper 插件
+        //mvn test surefire-report:report
         timestamps()
         ansiColor('xterm')
+        //丢弃旧的构建前两个为发布包保留天数(比此早的发布包将被删除,但构建的日志、操作历史、报告等将被保留)和构建个数
+        buildDiscarder logRotator(artifactDaysToKeepStr: '', artifactNumToKeepStr: '', daysToKeepStr: '7', numToKeepStr: '10')
 
     }
     stages {
         stage('source') {
             steps {
-                checkout([$class: 'GitSCM'
-                , branches: [[name: "${GIT_BRANCH}"]]
-                , doGenerateSubmoduleConfigurations: false
-                , extensions: []
-                , submoduleCfg: []
-                , userRemoteConfigs: [[credentialsId: "${GIT_CREDENTIALS_ID}", url: "${url}"]]
-                ])
+                script{
+                    def changeLogSets = checkout([$class: 'GitSCM'
+                                    , branches: [[name: "${GIT_BRANCH}"]]
+                                    , doGenerateSubmoduleConfigurations: false
+                                    , extensions: []
+                                    , submoduleCfg: []
+                                    , userRemoteConfigs: [[credentialsId: "${GIT_CREDENTIALS_ID}", url: "${url}"]]
+                                    ])
+                     println "changeLogSets ${changeLogSets}"
+                     GIT_COMMIT = changeLogSets.get("GIT_COMMIT")
+                     GIT_PREVIOUS_COMMIT = changeLogSets['GIT_PREVIOUS_COMMIT']
+                     env.GIT_COMMIT_AUTHOR = sh (script: 'git log -1 --oneline --pretty=%an ${GIT_COMMIT}', returnStdout: true).trim()
+                     env.GIT_COMMIT_MSG = sh (script: 'git log --oneline --pretty=%s ${GIT_PREVIOUS_COMMIT}...${GIT_COMMIT}| sed = |sed "N;s/\\n/./"', returnStdout: true).trim()
 
+                }
             }
         }
-        stage('test') {
+        //stage('testMaven') {
+            //steps {
+
+                //sh 'mvn clean test -U'
+                //junit allowEmptyResults: true, keepLongStdio: true, skipPublishingChecks: true, testResults: 'target/surefire-reports/*.xml'
+
+            //}
+        //}
+
+        //将项目打成war并归档,将配置文件目录存入stash
+        stage('package') {
             steps {
-
-                sh '''
-                    #定义颜色的变量
-                    RED_COLOR='\\E[1;31m'   #红
-                    GREEN_COLOR='\\E[1;32m' #绿
-                    YELOW_COLOR='\\E[1;33m' #黄
-                    BLUE_COLOR='\\E[1;34m'  #蓝
-                    PINK='\\E[1;35m'        #粉红
-                    RES='\\E[0m'
-
-                    #需要使用echo -e
-                    echo -e  "\${RED_COLOR}======red color======\${RES}"
-                    echo -e  "\${YELOW_COLOR}======yelow color======\${RES}"
-                    echo -e  "\${BLUE_COLOR}======green color======\${RES}"
-                    echo -e  "\${GREEN_COLOR}======green color======\${RES}"
-                    echo -e  "\${PINK}======pink color======\${RES}"
-                    echo "#######################################"
-                    #直接把echo -e放到变量里面,使用的时候直接输出变量即可
-                    SETCOLOR_SUCCESS="echo -en \\\\033[1;32m"
-                    SETCOLOR_FAILURE="echo -en \\\\033[1;31m"
-                    SETCOLOR_WARNING="echo -en \\\\033[1;33m"
-                    SETCOLOR_NORMAL="echo -en \\\\033[0;39m"
-                    echo ----成功了!-----  &&  \$SETCOLOR_SUCCESS
-                    echo ----失败了!-----  &&  \$SETCOLOR_FAILURE
-                    echo ----需注意!-----  &&  \$SETCOLOR_WARNING
-                    echo ----正常的!-----  &&  \$SETCOLOR_NORMAL
-
-                    echo "BRANCH ${GIT_BRANCH}"
-                    printenv
-                   '''
-                test("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+                sh '''#!/bin/sh
+                    ####maven编译部署#####
+                    ##mvn clean package -U
+                    ##处理结果包
+                    versionFile=\$(find . -iname "${project_name}.java")
+                    str="-"
+                    old_version_all=\$(cat \$versionFile | sed -nr \'s/^[^0-9]*"([^"]+)".*;/\\1/p\')
+                    echo "old_version_all \$old_version_all"
+                    echo "project_name \$project_name"
+                    dir_name=\${project_name}"-"\$old_version_all
+                    echo "dir_name \$dir_name"
+                    ##cd target
+                    ##mkdir \$dir_name
+                    ##cp *.war \$dir_name
+                    ##zip -r "\$dir_name.zip" \$dir_name
+                    exit 1
+                '''
             }
         }
-        stage('version add') {
+
+        stage('master version add') {
             when {
+                not {
+                    allOf {
+                       changeset "**/${project_name}.java"
+                    }
+                }
+                branch 'master'
+            }
+            steps {
+                //http(s)的git链接使用帐号密码,ssh使用 keyFileVariable: 'SSH_KEY'
+                echo "todo version add"
+                versionAddCom("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+                }
+        }
+
+        stage('version add develop') {
+            when {
+                //版本号自动添加逻辑需同时符合下列触发条件:
+                //1. 不能在master分支触发
+                //2. 有任意浏览器页面资源文件修改
+                //3. 不包含[项目名.java]文件的修改
                 allOf {
                     anyOf {
                         changeset "**/*.js"
@@ -76,16 +103,38 @@
                     not {
                         changeset "**/${project_name}.java"
                     }
+                    branch 'develop'
                 }
             }
             steps {
-                versionAdd("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+                versionAddCom("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
             }
         }
+
         stage('deploy') {
+            when { branch 'master' }
             steps {
                 sh 'echo test'
             }
         }
     }
+
+    post {
+        unsuccessful {
+            script{
+                String msg = '''
+                        当前构建失败<br>
+                        ---------------------<br>
+                        提交人:${GIT_COMMIT_AUTHOR}<br>
+                        提交信息:<br>
+                        ${GIT_COMMIT_MSG}<br>
+                        ---------------------<br>
+                        构建内网链接:${BUILD_URL}console
+                    '''
+                msg = msg.replaceAll("\n","")
+                def number = "964606955"
+                sendMessage(true,number,msg);
+            }
+        }
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.1