From 533ba4f898e9bd2906d521aa937ecdd55f918b3a Mon Sep 17 00:00:00 2001
From: wangzilun <964606955@qq.com>
Date: Tue, 08 Mar 2022 18:14:34 +0800
Subject: [PATCH] 补充15
---
Jenkinsfile | 80 ++++++++++++++++++++++++++-------------
1 files changed, 53 insertions(+), 27 deletions(-)
diff --git a/Jenkinsfile b/Jenkinsfile
index c65cea3..903a4ab 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -20,29 +20,31 @@
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['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('testMaven') {
- steps {
+ //stage('testMaven') {
+ //steps {
- sh 'mvn clean test -U'
- junit allowEmptyResults: true, keepLongStdio: true, skipPublishingChecks: true, testResults: 'target/surefire-reports/*.xml'
+ //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') {
@@ -51,12 +53,9 @@
####maven编译部署#####
##mvn clean package -U
##处理结果包
- old_version=\$(find . -iname "\${project_name}.java"| xargs sed -nr 's/^[^0-9]*(([0-9]+\\.)*[0-9]+).*;/\\1/p\')
- if [ "\$old_version_all" =~ "-" ];then
- echo "包含"
- else
- echo "不包含"
- fi
+ 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
@@ -65,6 +64,7 @@
##mkdir \$dir_name
##cp *.war \$dir_name
##zip -r "\$dir_name.zip" \$dir_name
+ exit 1
'''
}
}
@@ -81,11 +81,11 @@
steps {
//http(s)的git链接使用帐号密码,ssh使用 keyFileVariable: 'SSH_KEY'
echo "todo version add"
- versionAddDevelop("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+ versionAddCom("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
}
}
- stage('version add master') {
+ stage('version add develop') {
when {
//版本号自动添加逻辑需同时符合下列触发条件:
//1. 不能在master分支触发
@@ -107,7 +107,7 @@
}
}
steps {
- versionAddDevelop("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
+ versionAddCom("${project_name}","${GIT_CREDENTIALS_ID}","${url}","${GIT_BRANCH}")
}
}
@@ -118,4 +118,30 @@
}
}
}
+
+ post {
+ unsuccessful {
+ script{
+ sh '''
+ msg="当前构建失败,\n提交人:${env.GIT_COMMIT_AUTHOR}\n提交信息:\n${env.GIT_COMMIT_MSG}\n 构建内网链接:${BUILD_URL}"
+ echo "$msg"
+ sendqq(){
+ rm -f tmp_in
+ mknod tmp_in p
+ exec 8<> tmp_in
+
+ telnet zllr.top 9588 <&8 &
+ sleep 5
+ echo "send -t qq -fn $1 $2 >> tmp_in"
+ echo "send -t qq -fn $1 $2" >> tmp_in
+ sleep 1
+ echo "exit" >> tmp_in
+ }
+
+ sendqq "964606955" "${msg}"
+ '''
+
+ }
+ }
+ }
}
\ No newline at end of file
--
Gitblit v1.9.1