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
}
115 116 117 118 119 120 121
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
L
liuyq-617 已提交
122
    git reset --hard HEAD~10 
123 124 125 126
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
        bat '''
L
liuyq-617 已提交
127
        cd C:\\workspace\\TDinternal\\community
128 129 130 131 132
        git checkout master
        '''
        }
      else if(env.CHANGE_TARGET == '2.0'){
        bat '''
L
liuyq-617 已提交
133
        cd C:\\workspace\\TDinternal\\community
134 135 136 137 138
        git checkout 2.0
        '''
      } 
      else{
        bat '''
L
liuyq-617 已提交
139
        cd C:\\workspace\\TDinternal\\community
140 141 142 143 144 145
        git checkout develop
        '''
      }
    }
    bat'''
    cd C:\\workspace\\TDinternal\\community
L
liuyq-617 已提交
146
    git pull 
L
liuyq-617 已提交
147
    git fetch origin +refs/pull/%CHANGE_ID%/merge
148 149 150 151 152 153 154 155
    git checkout -qf FETCH_HEAD
    git clean -dfx
    cd C:\\workspace\\TDinternal
    git reset --hard HEAD~10
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
        bat '''
L
liuyq-617 已提交
156
        cd C:\\workspace\\TDinternal
157 158 159 160 161
        git checkout master
        '''
        }
      else if(env.CHANGE_TARGET == '2.0'){
        bat '''
L
liuyq-617 已提交
162
        cd C:\\workspace\\TDinternal
163 164 165 166 167
        git checkout 2.0
        '''
      } 
      else{
        bat '''
L
liuyq-617 已提交
168
        cd C:\\workspace\\TDinternal
169 170 171 172 173 174
        git checkout develop
        '''
      } 
    }
    bat '''
    cd C:\\workspace\\TDinternal
L
liuyq-617 已提交
175
    git pull 
L
liuyq-617 已提交
176

177 178 179 180 181 182 183 184
    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 
L
liuyq-617 已提交
185
    xcopy /e/y/i/f C:\\workspace\\TDinternal\\debug\\build\\lib\\taos.dll C:\\Windows\\System32
186 187
    cd C:\\workspace\\TDinternal\\community\\src\\connector\\python
    python -m pip install .
L
liuyq-617 已提交
188
    
189 190 191
    '''
    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
              sh '''
                rm -rf /var/lib/taos/*
                rm -rf /var/log/taos/*
L
update  
liuyq-617 已提交
308
                nohup taosd >/dev/null &
L
liuyq-617 已提交
309 310 311 312
                sleep 10
              '''
              sh '''
              cd ${WKC}/tests/examples/nodejs
L
update  
liuyq-617 已提交
313
              npm install td2.0-connector > /dev/null 2>&1
L
liuyq-617 已提交
314
              node nodejsChecker.js host=localhost
R
root 已提交
315
              node test1970.js
L
liuyq-617 已提交
316 317 318
              '''
              sh '''
                cd ${WKC}/tests/examples/C#/taosdemo
L
update  
liuyq-617 已提交
319
                mcs -out:taosdemo *.cs > /dev/null 2>&1
R
root 已提交
320
                echo '' |./taosdemo -c /etc/taos
L
liuyq-617 已提交
321 322 323 324 325
              '''
              sh '''
                cd ${WKC}/tests/gotest
                bash batchtest.sh
              '''
L
liuyq-617 已提交
326 327 328 329 330
              sh '''
              cd ${WKC}/tests
              ./test-all.sh b1fq
              date'''
            }
Y
Yiqing Liu 已提交
331 332
          }
        }
L
liuyq-617 已提交
333
        stage('test_crash_gen_s3') {
L
liuyq-617 已提交
334
          agent{label " slave3 || slave13 "}
335
          
Y
Yiqing Liu 已提交
336
          steps {
337
            pre_test()
338 339 340
            timeout(time: 60, unit: 'MINUTES'){
              sh '''
              cd ${WKC}/tests/pytest
L
liuyq-617 已提交
341
              ./crash_gen.sh -a -p -t 4 -s 2000
342 343 344
              '''
            }
            timeout(time: 60, unit: 'MINUTES'){
L
liuyq-617 已提交
345 346 347 348 349 350
              // sh '''
              // cd ${WKC}/tests/pytest
              // rm -rf /var/lib/taos/*
              // rm -rf /var/log/taos/*
              // ./handle_crash_gen_val_log.sh
              // '''
351 352 353 354 355 356
              sh '''
              cd ${WKC}/tests/pytest
              rm -rf /var/lib/taos/*
              rm -rf /var/log/taos/*
              ./handle_taosd_val_log.sh
              '''
L
liuyq-617 已提交
357
            }
L
liuyq-617 已提交
358
            timeout(time: 55, unit: 'MINUTES'){
359 360 361 362 363 364
                sh '''
                date
                cd ${WKC}/tests
                ./test-all.sh b2fq
                date
                '''
L
test  
liuyq-617 已提交
365
            }                     
Y
Yiqing Liu 已提交
366 367
          }
        }
L
liuyq-617 已提交
368
        stage('test_valgrind_s4') {
L
liuyq-617 已提交
369
          agent{label " slave4 || slave14 "}
L
liuyq-617 已提交
370

Y
Yiqing Liu 已提交
371
          steps {
372 373 374 375 376 377 378
            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 已提交
379
            }     
L
liuyq-617 已提交
380
            timeout(time: 55, unit: 'MINUTES'){      
L
liuyq-617 已提交
381 382 383 384 385
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b3fq
              date'''
P
change  
Ping Xiao 已提交
386 387 388 389 390
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh full example
              date'''
L
liuyq-617 已提交
391
            }
Y
Yiqing Liu 已提交
392 393
          }
        }
L
liuyq-617 已提交
394
        stage('test_b4_s7') {
L
liuyq-617 已提交
395
          agent{label " slave7 || slave17 "}
L
liuyq-617 已提交
396
          steps {     
L
liuyq-617 已提交
397
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
398 399 400 401 402
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b4fq
L
fix  
liuyq-617 已提交
403
              cd ${WKC}/tests
L
liuyq-617 已提交
404
              ./test-all.sh p4
405 406
              cd ${WKC}/tests
              ./test-all.sh full jdbc
P
Ping Xiao 已提交
407 408
              cd ${WKC}/tests
              ./test-all.sh full unit
L
liuyq-617 已提交
409 410 411 412 413
              date'''
            }
          }
        }
        stage('test_b5_s8') {
L
liuyq-617 已提交
414
          agent{label " slave8 || slave18 "}
L
liuyq-617 已提交
415
          steps {     
L
liuyq-617 已提交
416
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
417 418 419 420 421 422 423 424 425 426
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b5fq
              date'''
            }
          }
        }
        stage('test_b6_s9') {
L
liuyq-617 已提交
427
          agent{label " slave9 || slave19 "}
L
liuyq-617 已提交
428
          steps {     
L
liuyq-617 已提交
429
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
430 431 432 433 434 435 436 437 438 439
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b6fq
              date'''
            }
          }
        }
        stage('test_b7_s10') {
L
liuyq-617 已提交
440
          agent{label " slave10 || slave20 "}
L
liuyq-617 已提交
441
          steps {     
L
liuyq-617 已提交
442
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
443 444 445 446 447
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b7fq
P
change  
Ping Xiao 已提交
448
              date'''              
L
liuyq-617 已提交
449 450
            }
          }
451
        } 
L
liuyq-617 已提交
452 453
        
        stage('build'){
454 455 456
          agent{label " crashgen "}
          steps {
            pre_test()
L
liuyq-617 已提交
457 458 459 460 461 462
            script{             
                while(win_stop == 0){
                  sleep(1)
                  }
              }
            }
L
liuyq-617 已提交
463 464
        }
        stage('test'){
465 466 467
          agent{label "win"}
          steps{
            pre_test_win()
L
liuyq-617 已提交
468 469 470
            catchError(buildResult: 'FAILURE', stageResult: 'FAILURE') {
                bat'''
                cd C:\\workspace\\TDinternal\\community\\tests\\pytest
L
liuyq-617 已提交
471
                .\\test-all.bat Wintest
L
liuyq-617 已提交
472 473
                '''
            }     
L
liuyq-617 已提交
474 475 476
            script{
              win_stop=1
            }
477
          }
L
liuyq-617 已提交
478 479 480
        }
          
               
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
    } 
X
xiaolei li 已提交
562
}