From d0cf8aab000211e027f49b43afdefd6c44f0a465 Mon Sep 17 00:00:00 2001
From: wangzilun <964606955@qq.com>
Date: Mon, 21 Feb 2022 16:08:16 +0800
Subject: [PATCH] 测试

---
 Jenkinsfile |   54 +++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 47 insertions(+), 7 deletions(-)

diff --git a/Jenkinsfile b/Jenkinsfile
index 1f13819..323b555 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -10,8 +10,11 @@
         }
     options {
         //给日志加上时间错, 需安装 Timestamper 插件
+        //mvn test surefire-report:report
         timestamps()
         ansiColor('xterm')
+        //丢弃旧的构建前两个为发布包保留天数(比此早的发布包将被删除,但构建的日志、操作历史、报告等将被保留)和构建个数
+        buildDiscarder logRotator(artifactDaysToKeepStr: '', artifactNumToKeepStr: '', daysToKeepStr: '7', numToKeepStr: '10')
 
     }
     stages {
@@ -27,18 +30,54 @@
 
             }
         }
-        stage('test') {
+        stage('testMaven') {
             steps {
-                sh '''
-                     echo "BRANCH ${GIT_BRANCH}"
-                     printenv
-                   '''
-                test("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+
+                sh 'mvn clean test -U'
+                junit allowEmptyResults: true, keepLongStdio: true, skipPublishingChecks: true, testResults: 'target/surefire-reports/*.xml'
+
+            }
+        }
+        stage('testFunction') {
+            steps {
+                sh 'echo test'
+            }
+        }
+
+        //将项目打成war并归档,将配置文件目录存入stash
+        stage('package') {
+            steps {
+                sh '''#!/bin/sh
+                    ####maven编译部署#####
+                    ##mvn clean package -U
+                    ##处理结果包
+                    old_version_all=\$(find . -iname "\${project_name}.java"| xargs sed -nr 's/^[^0-9]*\\"(([0-9]+\\.)*[0-9]+.*-[0-9]+)\\".*;/\\1/p\')
+                    if [ "\$old_version_all" =~ "-" ];then
+                        echo "包含"
+                    else
+                        echo "不包含"
+                    fi
+                    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
+                '''
             }
         }
         stage('version add') {
             when {
+                //版本号自动添加逻辑需同时符合下列触发条件:
+                //1. 不能在master分支触发
+                //2. 有任意浏览器页面资源文件修改
+                //3. 不包含[项目名.java]文件的修改
                 allOf {
+                    not {
+                        branch 'master'
+                    }
                     anyOf {
                         changeset "**/*.js"
                         changeset "**/*.css"
@@ -53,10 +92,11 @@
                 }
             }
             steps {
-                versionAdd("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+                versionAddTest("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
             }
         }
         stage('deploy') {
+            when { branch 'master' }
             steps {
                 sh 'echo test'
             }

--
Gitblit v1.9.1