import hudson.model.Result import hudson.model.*; import jenkins.model.CauseOfInterruption node { } def skipbuild=0 def win_stop=0 def abortPreviousBuilds() { def currentJobName = env.JOB_NAME def currentBuildNumber = env.BUILD_NUMBER.toInteger() def jobs = Jenkins.instance.getItemByFullName(currentJobName) def builds = jobs.getBuilds() for (build in builds) { if (!build.isBuilding()) { continue; } if (currentBuildNumber == build.getNumber().toInteger()) { continue; } build.doKill() //doTerm(),doKill(),doTerm() } } // abort previous build abortPreviousBuilds() def abort_previous(){ def buildNumber = env.BUILD_NUMBER as int if (buildNumber > 1) milestone(buildNumber - 1) milestone(buildNumber) } def pre_test(){ sh'hostname' sh ''' sudo rmtaos || echo "taosd has not installed" ''' sh ''' killall -9 taosd ||echo "no taosd running" killall -9 gdb || echo "no gdb running" killall -9 python3.8 || echo "no python program running" cd ${WKC} ''' script { if (env.CHANGE_TARGET == 'master') { sh ''' cd ${WKC} git checkout master ''' } else if(env.CHANGE_TARGET == '2.0'){ sh ''' cd ${WKC} git checkout 2.0 ''' } else if(env.CHANGE_TARGET == '3.0'){ sh ''' cd ${WKC} git checkout 3.0 ''' } else{ sh ''' cd ${WKC} git checkout develop ''' } } sh''' cd ${WKC} git pull >/dev/null git fetch origin +refs/pull/${CHANGE_ID}/merge git checkout -qf FETCH_HEAD export TZ=Asia/Harbin date rm -rf debug mkdir debug cd debug cmake .. > /dev/null make -j4> /dev/null ''' return 1 } pipeline { agent none options { skipDefaultCheckout() } environment{ WK = '/var/lib/jenkins/workspace/TDinternal' WKC= '/var/lib/jenkins/workspace/TDengine' } stages { stage('pre_build'){ agent{label 'slave3_0'} options { skipDefaultCheckout() } when { changeRequest() } steps { script{ abort_previous() abortPreviousBuilds() } pre_test() bash''' cd ${WKC}/tests ./test-all.sh p1 ''' } } // stage('Parallel test stage') { // skip defaultCheckout // options { skipDefaultCheckout() } // when { // allOf{ // changeRequest() // } // } // parallel { // stage('python_1_s1') { // agent{label " slave1 || slave11 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh p1 // // date''' // // } // } // } // stage('python_2_s5') { // agent{label " slave5 || slave15 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh p2 // // date''' // // } // } // } // stage('python_3_s6') { // agent{label " slave6 || slave16 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh p3 // // date''' // // } // } // } // stage('test_b1_s2') { // agent{label " slave2 || slave12 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // rm -rf /var/lib/taos/* // // rm -rf /var/log/taos/* // // nohup taosd >/dev/null & // // sleep 10 // // ''' // // sh ''' // // cd ${WKC}/tests/examples/nodejs // // npm install td2.0-connector > /dev/null 2>&1 // // node nodejsChecker.js host=localhost // // node test1970.js // // cd ${WKC}/tests/connectorTest/nodejsTest/nanosupport // // npm install td2.0-connector > /dev/null 2>&1 // // node nanosecondTest.js // // ''' // // sh ''' // // cd ${WKC}/tests/examples/C#/taosdemo // // mcs -out:taosdemo *.cs > /dev/null 2>&1 // // echo '' |./taosdemo -c /etc/taos // // cd ${WKC}/tests/connectorTest/C#Test/nanosupport // // mcs -out:nano *.cs > /dev/null 2>&1 // // echo '' |./nano // // ''' // // sh ''' // // cd ${WKC}/tests/gotest // // bash batchtest.sh // // ''' // // sh ''' // // cd ${WKC}/tests // // ./test-all.sh b1fq // // date''' // // } // } // } // stage('test_crash_gen_s3') { // agent{label " slave3 || slave13 "} // steps { // pre_test() // // timeout(time: 60, unit: 'MINUTES'){ // // sh ''' // // cd ${WKC}/tests/pytest // // ./crash_gen.sh -a -p -t 4 -s 2000 // // ''' // // } // // timeout(time: 60, unit: 'MINUTES'){ // // // sh ''' // // // cd ${WKC}/tests/pytest // // // rm -rf /var/lib/taos/* // // // rm -rf /var/log/taos/* // // // ./handle_crash_gen_val_log.sh // // // ''' // // sh ''' // // cd ${WKC}/tests/pytest // // rm -rf /var/lib/taos/* // // rm -rf /var/log/taos/* // // ./handle_taosd_val_log.sh // // ''' // // } // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh b2fq // // date // // ''' // // } // } // } // stage('test_valgrind_s4') { // agent{label " slave4 || slave14 "} // steps { // pre_test() // // catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') { // // sh ''' // // cd ${WKC}/tests/pytest // // ./valgrind-test.sh 2>&1 > mem-error-out.log // // ./handle_val_log.sh // // ''' // // } // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh b3fq // // date''' // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh full example // // date''' // // } // } // } // stage('test_b4_s7') { // agent{label " slave7 || slave17 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh b4fq // // cd ${WKC}/tests // // ./test-all.sh p4 // // cd ${WKC}/tests // // ./test-all.sh full jdbc // // cd ${WKC}/tests // // ./test-all.sh full unit // // date''' // // } // } // } // stage('test_b5_s8') { // agent{label " slave8 || slave18 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh b5fq // // date''' // // } // } // } // stage('test_b6_s9') { // agent{label " slave9 || slave19 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh b6fq // // date''' // // } // } // } // stage('test_b7_s10') { // agent{label " slave10 || slave20 "} // steps { // pre_test() // // timeout(time: 55, unit: 'MINUTES'){ // // sh ''' // // date // // cd ${WKC}/tests // // ./test-all.sh b7fq // // date''' // // } // } // } // } // } } post { success { emailext ( subject: "PR-result: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]' SUCCESS", body: """

构建信息
  • 构建名称>>分支:${env.BRANCH_NAME}
  • 构建结果: Successful
  • 构建编号:${BUILD_NUMBER}
  • 触发用户:${env.CHANGE_AUTHOR}
  • 提交信息:${env.CHANGE_TITLE}
  • 构建地址:${BUILD_URL}
  • 构建日志:${BUILD_URL}console
""", to: "${env.CHANGE_AUTHOR_EMAIL}", from: "support@taosdata.com" ) } failure { emailext ( subject: "PR-result: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]' FAIL", body: """

构建信息
  • 构建名称>>分支:${env.BRANCH_NAME}
  • 构建结果: Failure
  • 构建编号:${BUILD_NUMBER}
  • 触发用户:${env.CHANGE_AUTHOR}
  • 提交信息:${env.CHANGE_TITLE}
  • 构建地址:${BUILD_URL}
  • 构建日志:${BUILD_URL}console
""", to: "${env.CHANGE_AUTHOR_EMAIL}", from: "support@taosdata.com" ) } } }