Jenkinsfile 15.7 KB
Newer Older
L
liuyq-617 已提交
1
import hudson.model.Result
L
liuyq-617 已提交
2
import hudson.model.*;
L
liuyq-617 已提交
3
import jenkins.model.CauseOfInterruption
4 5
properties([pipelineTriggers([githubPush()])])
node {
L
liuyq-617 已提交
6
    git url: 'https://github.com/taosdata/TDengine.git'
7 8
}

L
liuyq-617 已提交
9
def skipbuild=0
L
liuyq-617 已提交
10
def win_stop=0
L
liuyq-617 已提交
11

L
recover  
liuyq-617 已提交
12 13 14 15 16
def abortPreviousBuilds() {
  def currentJobName = env.JOB_NAME
  def currentBuildNumber = env.BUILD_NUMBER.toInteger()
  def jobs = Jenkins.instance.getItemByFullName(currentJobName)
  def builds = jobs.getBuilds()
17

L
recover  
liuyq-617 已提交
18 19 20 21
  for (build in builds) {
    if (!build.isBuilding()) {
      continue;
    }
L
liuyq-617 已提交
22

L
recover  
liuyq-617 已提交
23 24 25 26 27 28 29 30 31 32 33 34 35 36
    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)
}
37
def pre_test(){
L
liuyq-617 已提交
38
    sh'hostname'
L
liuyq-617 已提交
39 40 41
    sh '''
    sudo rmtaos || echo "taosd has not installed"
    '''
L
liuyq-617 已提交
42
    sh '''
L
fix  
liuyq-617 已提交
43 44
    killall -9 taosd ||echo "no taosd running"
    killall -9 gdb || echo "no gdb running"
L
liuyq-617 已提交
45
    killall -9 python3.8 || echo "no python program running"
46
    cd ${WKC}
L
fix  
liuyq-617 已提交
47 48 49 50
    git reset --hard HEAD~10 >/dev/null
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
L
fix  
liuyq-617 已提交
51 52 53 54
        sh '''
        cd ${WKC}
        git checkout master
        '''
L
fix  
liuyq-617 已提交
55
        }
56
      else if(env.CHANGE_TARGET == '2.0'){
L
fix  
liuyq-617 已提交
57 58
        sh '''
        cd ${WKC}
59
        git checkout 2.0
L
fix  
liuyq-617 已提交
60
        '''
L
fix  
liuyq-617 已提交
61
      } 
62 63 64 65 66 67
      else{
        sh '''
        cd ${WKC}
        git checkout develop
        '''
      }
L
fix  
liuyq-617 已提交
68 69
    }
    sh'''
L
fix  
liuyq-617 已提交
70
    cd ${WKC}
L
liuyq-617 已提交
71
    git pull >/dev/null
L
liuyq-617 已提交
72
    git fetch origin +refs/pull/${CHANGE_ID}/merge
73
    git checkout -qf FETCH_HEAD
L
liuyq-617 已提交
74
    git clean -dfx
75
    cd ${WK}
L
enhance  
liuyq-617 已提交
76
    git reset --hard HEAD~10
L
fix  
liuyq-617 已提交
77 78 79
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
L
fix  
liuyq-617 已提交
80
        sh '''
L
fix  
liuyq-617 已提交
81
        cd ${WK}
L
fix  
liuyq-617 已提交
82 83
        git checkout master
        '''
L
fix  
liuyq-617 已提交
84
        }
85 86 87 88 89 90 91
      else if(env.CHANGE_TARGET == '2.0'){
        sh '''
        cd ${WK}
        git checkout 2.0
        '''
      } 
      else{
L
fix  
liuyq-617 已提交
92
        sh '''
L
fix  
liuyq-617 已提交
93
        cd ${WK}
L
fix  
liuyq-617 已提交
94 95
        git checkout develop
        '''
L
fix  
liuyq-617 已提交
96 97 98
      } 
    }
    sh '''
99
    cd ${WK}
L
fix  
liuyq-617 已提交
100
    git pull >/dev/null 
L
fix  
liuyq-617 已提交
101

102 103
    export TZ=Asia/Harbin
    date
L
liuyq-617 已提交
104
    git clean -dfx
105 106 107 108 109 110
    mkdir debug
    cd debug
    cmake .. > /dev/null
    make > /dev/null
    make install > /dev/null
    cd ${WKC}/tests
L
liuyq-617 已提交
111
    pip3 install ${WKC}/src/connector/python/
L
liuyq-617 已提交
112
    '''
113 114
    return 1
}
L
liuyq-617 已提交
115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175
def pre_test_win(){
    bat '''
    cd C:\\
    rd /s /Q C:\\TDengine
    cd C:\\workspace\\TDinternal
    rd /s /Q C:\\workspace\\TDinternal\\debug
    cd C:\\workspace\\TDinternal\\community
    git reset --hard HEAD~10 
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
        bat '''
        cd C:\\workspace\\TDinternal\\community
        git checkout master
        '''
        }
      else if(env.CHANGE_TARGET == '2.0'){
        bat '''
        cd C:\\workspace\\TDinternal\\community
        git checkout 2.0
        '''
      } 
      else{
        bat '''
        cd C:\\workspace\\TDinternal\\community
        git checkout develop
        '''
      }
    }
    bat'''
    cd C:\\workspace\\TDinternal\\community
    git pull 
    git fetch origin +refs/pull/%CHANGE_ID%/merge
    git checkout -qf FETCH_HEAD
    git clean -dfx
    cd C:\\workspace\\TDinternal
    git reset --hard HEAD~10
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
        bat '''
        cd C:\\workspace\\TDinternal
        git checkout master
        '''
        }
      else if(env.CHANGE_TARGET == '2.0'){
        bat '''
        cd C:\\workspace\\TDinternal
        git checkout 2.0
        '''
      } 
      else{
        bat '''
        cd C:\\workspace\\TDinternal
        git checkout develop
        '''
      } 
    }
    bat '''
    cd C:\\workspace\\TDinternal
    git pull 
L
liuyq-617 已提交
176

L
liuyq-617 已提交
177 178 179 180 181 182 183 184 185 186 187 188 189 190 191
    date
    git clean -dfx
    mkdir debug
    cd debug
    call "C:\\Program Files (x86)\\Microsoft Visual Studio 14.0\\VC\\vcvarsall.bat" amd64
    cmake ../ -G "NMake Makefiles" 
    nmake
    nmake install 
    xcopy /e/y/i/f C:\\workspace\\TDinternal\\debug\\build\\lib\\taos.dll C:\\Windows\\System32
    cd C:\\workspace\\TDinternal\\community\\src\\connector\\python
    python -m pip install .
    
    '''
    return 1
}
Y
Yiqing Liu 已提交
192
pipeline {
L
liuyq-617 已提交
193 194 195 196 197
  agent none
  environment{
      WK = '/var/lib/jenkins/workspace/TDinternal'
      WKC= '/var/lib/jenkins/workspace/TDinternal/community'
  }
Y
Yiqing Liu 已提交
198
  stages {
L
change  
liuyq-617 已提交
199
      stage('pre_build'){
200
          agent{label 'master'}
L
liuyq-617 已提交
201 202 203
          when {
              changeRequest()
          }
204
          steps {
L
change  
liuyq-617 已提交
205 206 207 208
            script{
              abort_previous()
              abortPreviousBuilds()
            }
L
liuyq-617 已提交
209
          sh'''
210
          rm -rf ${WORKSPACE}.tes
L
fix  
liuyq-617 已提交
211 212
          cp -r ${WORKSPACE} ${WORKSPACE}.tes
          cd ${WORKSPACE}.tes
L
test  
liuyq-617 已提交
213
          git fetch
214 215 216 217 218 219 220
          '''
          script {
            if (env.CHANGE_TARGET == 'master') {
              sh '''
              git checkout master
              '''
              }
L
test  
liuyq-617 已提交
221 222 223 224 225 226
            else if(env.CHANGE_TARGET == '2.0'){
              sh '''
              git checkout 2.0
              '''
            } 
            else{
227 228 229 230 231 232
              sh '''
              git checkout develop
              '''
            } 
          }
          sh'''
L
liuyq-617 已提交
233
          git fetch origin +refs/pull/${CHANGE_ID}/merge
234
          git checkout -qf FETCH_HEAD
L
fix  
liuyq-617 已提交
235
          '''     
236

L
liuyq-617 已提交
237 238 239 240
          script{  
            skipbuild='2'     
            skipbuild=sh(script: "git log -2 --pretty=%B | fgrep -ie '[skip ci]' -e '[ci skip]' && echo 1 || echo 2", returnStdout:true)
            println skipbuild
241
          }
L
fix  
liuyq-617 已提交
242
          sh'''
L
liuyq-617 已提交
243
          rm -rf ${WORKSPACE}.tes
L
fix  
liuyq-617 已提交
244
          '''
245 246
          }
      }
L
change  
liuyq-617 已提交
247
      stage('Parallel test stage') {
L
liuyq-617 已提交
248 249
        //only build pr
        when {
L
liuyq-617 已提交
250
          allOf{
L
liuyq-617 已提交
251
              changeRequest()
L
liuyq-617 已提交
252 253
               expression{
                return skipbuild.trim() == '2'
254
              }
L
liuyq-617 已提交
255
            }
L
liuyq-617 已提交
256
          }
Y
Yiqing Liu 已提交
257
      parallel {
L
liuyq-617 已提交
258
        stage('python_1_s1') {
L
liuyq-617 已提交
259
          agent{label " slave1 || slave11 "}
L
liuyq-617 已提交
260
          steps {
L
liuyq-617 已提交
261
            
262
            pre_test()
L
liuyq-617 已提交
263
            timeout(time: 55, unit: 'MINUTES'){
L
liuyq-617 已提交
264
              sh '''
L
liuyq-617 已提交
265
              date
L
liuyq-617 已提交
266 267 268 269 270
              cd ${WKC}/tests
              ./test-all.sh p1
              date'''
            }
            
L
liuyq-617 已提交
271 272
          }
        }
L
liuyq-617 已提交
273
        stage('python_2_s5') {
L
liuyq-617 已提交
274
          agent{label " slave5 || slave15 "}
L
liuyq-617 已提交
275 276 277
          steps {
            
            pre_test()
L
liuyq-617 已提交
278
            timeout(time: 55, unit: 'MINUTES'){
279 280 281 282 283
                sh '''
                date
                cd ${WKC}/tests
                ./test-all.sh p2
                date'''
L
liuyq-617 已提交
284 285 286 287
            }
          }
        }
        stage('python_3_s6') {
L
liuyq-617 已提交
288
          agent{label " slave6 || slave16 "}
L
liuyq-617 已提交
289
          steps {     
L
liuyq-617 已提交
290
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
291 292 293 294 295 296 297
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh p3
              date'''
            }
L
liuyq-617 已提交
298 299
          }
        }
L
liuyq-617 已提交
300
        stage('test_b1_s2') {
L
liuyq-617 已提交
301
          agent{label " slave2 || slave12 "}
L
liuyq-617 已提交
302
          steps {     
L
liuyq-617 已提交
303
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
304
              pre_test()
L
liuyq-617 已提交
305 306 307 308 309 310 311 312 313 314 315 316
              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
              '''
              sh '''
L
liuyq-617 已提交
317 318 319
              cd ${WKC}/tests/examples/C#/taosdemo
              mcs -out:taosdemo *.cs > /dev/null 2>&1
              ./taosdemo -c /etc/taos -y
L
liuyq-617 已提交
320 321 322 323 324
              '''
              sh '''
                cd ${WKC}/tests/gotest
                bash batchtest.sh
              '''
L
liuyq-617 已提交
325 326 327 328 329
              sh '''
              cd ${WKC}/tests
              ./test-all.sh b1fq
              date'''
            }
Y
Yiqing Liu 已提交
330 331
          }
        }
L
liuyq-617 已提交
332
        stage('test_crash_gen_s3') {
L
liuyq-617 已提交
333
          agent{label " slave3 || slave13 "}
334
          
Y
Yiqing Liu 已提交
335
          steps {
336
            pre_test()
L
liuyq-617 已提交
337 338 339 340 341
            timeout(time: 60, unit: 'MINUTES'){
              sh '''
              cd ${WKC}/tests/pytest
              ./crash_gen.sh -a -p -t 4 -s 2000
              '''
342 343
            }
            timeout(time: 60, unit: 'MINUTES'){
P
Ping Xiao 已提交
344 345 346 347 348 349
              // sh '''
              // cd ${WKC}/tests/pytest
              // rm -rf /var/lib/taos/*
              // rm -rf /var/log/taos/*
              // ./handle_crash_gen_val_log.sh
              // '''
350 351 352 353 354 355
              sh '''
              cd ${WKC}/tests/pytest
              rm -rf /var/lib/taos/*
              rm -rf /var/log/taos/*
              ./handle_taosd_val_log.sh
              '''
L
liuyq-617 已提交
356
            }
L
liuyq-617 已提交
357
            timeout(time: 55, unit: 'MINUTES'){
358 359 360 361 362 363
                sh '''
                date
                cd ${WKC}/tests
                ./test-all.sh b2fq
                date
                '''
L
test  
liuyq-617 已提交
364
            }                     
Y
Yiqing Liu 已提交
365 366
          }
        }
L
liuyq-617 已提交
367
        stage('test_valgrind_s4') {
L
liuyq-617 已提交
368
          agent{label " slave4 || slave14 "}
L
liuyq-617 已提交
369

Y
Yiqing Liu 已提交
370
          steps {
371 372 373 374 375 376 377
            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
                '''
L
liuyq-617 已提交
378
            }     
L
liuyq-617 已提交
379
            timeout(time: 55, unit: 'MINUTES'){      
L
liuyq-617 已提交
380 381 382 383 384
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b3fq
              date'''
P
change  
Ping Xiao 已提交
385 386 387 388 389
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh full example
              date'''
L
liuyq-617 已提交
390
            }
Y
Yiqing Liu 已提交
391 392
          }
        }
L
liuyq-617 已提交
393
        stage('test_b4_s7') {
L
liuyq-617 已提交
394
          agent{label " slave7 || slave17 "}
L
liuyq-617 已提交
395
          steps {     
L
liuyq-617 已提交
396
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
397 398 399 400 401
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b4fq
L
fix  
liuyq-617 已提交
402
              cd ${WKC}/tests
L
liuyq-617 已提交
403
              ./test-all.sh p4
404 405
              cd ${WKC}/tests
              ./test-all.sh full jdbc
P
Ping Xiao 已提交
406 407
              cd ${WKC}/tests
              ./test-all.sh full unit
L
liuyq-617 已提交
408 409 410 411 412
              date'''
            }
          }
        }
        stage('test_b5_s8') {
L
liuyq-617 已提交
413
          agent{label " slave8 || slave18 "}
L
liuyq-617 已提交
414
          steps {     
L
liuyq-617 已提交
415
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
416 417 418 419 420 421 422 423 424 425
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b5fq
              date'''
            }
          }
        }
        stage('test_b6_s9') {
L
liuyq-617 已提交
426
          agent{label " slave9 || slave19 "}
L
liuyq-617 已提交
427
          steps {     
L
liuyq-617 已提交
428
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
429 430 431 432 433 434 435 436 437 438
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b6fq
              date'''
            }
          }
        }
        stage('test_b7_s10') {
L
liuyq-617 已提交
439
          agent{label " slave10 || slave20 "}
L
liuyq-617 已提交
440
          steps {     
L
liuyq-617 已提交
441
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
442 443 444 445 446
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b7fq
P
change  
Ping Xiao 已提交
447
              date'''              
L
liuyq-617 已提交
448 449
            }
          }
L
liuyq-617 已提交
450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480
        } 
        
        stage('build'){
          agent{label " wintest "}
          steps {
            pre_test()
            script{             
                while(win_stop == 0){
                  sleep(1)
                  }
              }
            }
        }
        stage('test'){
          agent{label "win"}
          steps{
            
            catchError(buildResult: 'FAILURE', stageResult: 'FAILURE') {
                pre_test_win()
                bat'''
                cd C:\\workspace\\TDinternal\\community\\tests\\pytest
                .\\test-all.bat Wintest
                '''
            }     
            script{
              win_stop=1
            }
          }
        }
          
               
Y
Yiqing Liu 已提交
481 482
    }
  }
L
liuyq-617 已提交
483
  }
L
liuyq-617 已提交
484
  post {  
485 486
        success {
            emailext (
487 488
                subject: "PR-result: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]' SUCCESS",
                body: """<!DOCTYPE html>
489 490 491 492 493 494 495 496 497 498 499 500 501 502 503
                <html>
                <head>
                <meta charset="UTF-8">
                </head>
                <body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4" offset="0">
                    <table width="95%" cellpadding="0" cellspacing="0" style="font-size: 16pt; font-family: Tahoma, Arial, Helvetica, sans-serif">
                        <tr>
                            <td><br />
                                <b><font color="#0B610B"><font size="6">构建信息</font></font></b>
                                <hr size="2" width="100%" align="center" /></td>
                        </tr>
                        <tr>
                            <td>
                                <ul>
                                <div style="font-size:18px">
504
                                    <li>构建名称>>分支:${env.BRANCH_NAME}</li>
505 506
                                    <li>构建结果:<span style="color:green"> Successful </span></li>
                                    <li>构建编号:${BUILD_NUMBER}</li>
507
                                    <li>触发用户:${env.CHANGE_AUTHOR}</li>
L
fix  
liuyq-617 已提交
508
                                    <li>提交信息:${env.CHANGE_TITLE}</li>
509 510
                                    <li>构建地址:<a href=${BUILD_URL}>${BUILD_URL}</a></li>
                                    <li>构建日志:<a href=${BUILD_URL}console>${BUILD_URL}console</a></li>
511
                                    
512 513 514 515 516 517
                                </div>
                                </ul>
                            </td>
                        </tr>
                    </table></font>
                </body>
518
                </html>""",
L
liuyq-617 已提交
519
                to: "${env.CHANGE_AUTHOR_EMAIL}",
520 521 522 523 524
                from: "support@taosdata.com"
            )
        }
        failure {
            emailext (
525 526
                subject: "PR-result: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]' FAIL",
                body: """<!DOCTYPE html>
527 528 529 530 531 532 533 534 535 536 537 538 539 540 541
                <html>
                <head>
                <meta charset="UTF-8">
                </head>
                <body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4" offset="0">
                    <table width="95%" cellpadding="0" cellspacing="0" style="font-size: 16pt; font-family: Tahoma, Arial, Helvetica, sans-serif">
                        <tr>
                            <td><br />
                                <b><font color="#0B610B"><font size="6">构建信息</font></font></b>
                                <hr size="2" width="100%" align="center" /></td>
                        </tr>
                        <tr>
                            <td>
                                <ul>
                                <div style="font-size:18px">
542
                                    <li>构建名称>>分支:${env.BRANCH_NAME}</li>
L
liuyq-617 已提交
543
                                    <li>构建结果:<span style="color:red"> Failure </span></li>
544
                                    <li>构建编号:${BUILD_NUMBER}</li>
545
                                    <li>触发用户:${env.CHANGE_AUTHOR}</li>
L
fix  
liuyq-617 已提交
546
                                    <li>提交信息:${env.CHANGE_TITLE}</li>
547 548
                                    <li>构建地址:<a href=${BUILD_URL}>${BUILD_URL}</a></li>
                                    <li>构建日志:<a href=${BUILD_URL}console>${BUILD_URL}console</a></li>
549
                                    
550 551 552 553 554 555
                                </div>
                                </ul>
                            </td>
                        </tr>
                    </table></font>
                </body>
556
                </html>""",
L
liuyq-617 已提交
557
                to: "${env.CHANGE_AUTHOR_EMAIL}",
558 559 560
                from: "support@taosdata.com"
            )
        }
L
liuyq-617 已提交
561
    } 
L
liuyq-617 已提交
562
}