Jenkinsfile 16.6 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 6
node {
}

L
liuyq-617 已提交
7
def skipbuild=0
L
liuyq-617 已提交
8
def win_stop=0
L
liuyq-617 已提交
9

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

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

L
recover  
liuyq-617 已提交
21 22 23 24 25 26 27 28 29 30 31 32 33 34
    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)
}
35
def pre_test(){
L
liuyq-617 已提交
36
    sh'hostname'
L
liuyq-617 已提交
37 38 39
    sh '''
    sudo rmtaos || echo "taosd has not installed"
    '''
L
liuyq-617 已提交
40
    sh '''
L
fix  
liuyq-617 已提交
41 42
    killall -9 taosd ||echo "no taosd running"
    killall -9 gdb || echo "no gdb running"
L
liuyq-617 已提交
43
    killall -9 python3.8 || echo "no python program running"
44
    cd ${WKC}
L
fix  
liuyq-617 已提交
45 46 47 48
    git reset --hard HEAD~10 >/dev/null
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
L
fix  
liuyq-617 已提交
49 50 51 52
        sh '''
        cd ${WKC}
        git checkout master
        '''
L
fix  
liuyq-617 已提交
53
        }
54
      else if(env.CHANGE_TARGET == '2.0'){
L
fix  
liuyq-617 已提交
55 56
        sh '''
        cd ${WKC}
57
        git checkout 2.0
L
fix  
liuyq-617 已提交
58
        '''
L
fix  
liuyq-617 已提交
59
      } 
60 61 62 63 64 65
      else{
        sh '''
        cd ${WKC}
        git checkout develop
        '''
      }
L
fix  
liuyq-617 已提交
66 67
    }
    sh'''
L
fix  
liuyq-617 已提交
68
    cd ${WKC}
L
liuyq-617 已提交
69
    git pull >/dev/null
L
liuyq-617 已提交
70
    git fetch origin +refs/pull/${CHANGE_ID}/merge
71
    git checkout -qf FETCH_HEAD
L
liuyq-617 已提交
72
    git clean -dfx
73
    git submodule update --init --recursive
74
    cd ${WK}
L
enhance  
liuyq-617 已提交
75
    git reset --hard HEAD~10
L
fix  
liuyq-617 已提交
76 77 78
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
L
fix  
liuyq-617 已提交
79
        sh '''
L
fix  
liuyq-617 已提交
80
        cd ${WK}
L
fix  
liuyq-617 已提交
81 82
        git checkout master
        '''
L
fix  
liuyq-617 已提交
83
        }
84 85 86 87 88 89 90
      else if(env.CHANGE_TARGET == '2.0'){
        sh '''
        cd ${WK}
        git checkout 2.0
        '''
      } 
      else{
L
fix  
liuyq-617 已提交
91
        sh '''
L
fix  
liuyq-617 已提交
92
        cd ${WK}
L
fix  
liuyq-617 已提交
93 94
        git checkout develop
        '''
L
fix  
liuyq-617 已提交
95 96 97
      } 
    }
    sh '''
98
    cd ${WK}
L
fix  
liuyq-617 已提交
99
    git pull >/dev/null 
100
    
101 102
    export TZ=Asia/Harbin
    date
L
liuyq-617 已提交
103
    git clean -dfx
104 105 106 107 108 109
    mkdir debug
    cd debug
    cmake .. > /dev/null
    make > /dev/null
    make install > /dev/null
    cd ${WKC}/tests
L
liuyq-617 已提交
110
    pip3 install ${WKC}/src/connector/python/
L
liuyq-617 已提交
111
    '''
112 113
    return 1
}
114 115
def pre_test_win(){
    bat '''
L
update  
liuyq-617 已提交
116
    taskkill /f /t /im python.exe
117 118 119 120 121
    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
    git checkout -qf FETCH_HEAD
    git clean -dfx
150
    git submodule update --init --recursive
151 152 153 154 155 156
    cd C:\\workspace\\TDinternal
    git reset --hard HEAD~10
    '''
    script {
      if (env.CHANGE_TARGET == 'master') {
        bat '''
L
liuyq-617 已提交
157
        cd C:\\workspace\\TDinternal
158 159 160 161 162
        git checkout master
        '''
        }
      else if(env.CHANGE_TARGET == '2.0'){
        bat '''
L
liuyq-617 已提交
163
        cd C:\\workspace\\TDinternal
164 165 166 167 168
        git checkout 2.0
        '''
      } 
      else{
        bat '''
L
liuyq-617 已提交
169
        cd C:\\workspace\\TDinternal
170 171 172 173 174 175
        git checkout develop
        '''
      } 
    }
    bat '''
    cd C:\\workspace\\TDinternal
L
liuyq-617 已提交
176
    git pull 
L
liuyq-617 已提交
177

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

Y
Yiqing Liu 已提交
240 241 242 243 244 245 246 247 248
          // 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
          // }
          // sh'''
          // rm -rf ${WORKSPACE}.tes
          // '''
          // }       
249 250
          }
      }
L
change  
liuyq-617 已提交
251
      stage('Parallel test stage') {
L
liuyq-617 已提交
252
        //only build pr
Y
Yiqing Liu 已提交
253
        options { skipDefaultCheckout() } 
L
liuyq-617 已提交
254
        when {
L
liuyq-617 已提交
255
          allOf{
L
liuyq-617 已提交
256
              changeRequest()
257
              not{ expression { env.CHANGE_BRANCH =~ /docs\// }}
L
liuyq-617 已提交
258
            }
L
liuyq-617 已提交
259
          }
Y
Yiqing Liu 已提交
260
      parallel {
L
liuyq-617 已提交
261
        stage('python_1_s1') {
L
liuyq-617 已提交
262
          agent{label " slave1 || slave11 "}
L
liuyq-617 已提交
263
          steps {
264
            pre_test()
L
liuyq-617 已提交
265
            timeout(time: 55, unit: 'MINUTES'){
L
liuyq-617 已提交
266
              sh '''
L
liuyq-617 已提交
267
              date
L
liuyq-617 已提交
268 269 270 271 272
              cd ${WKC}/tests
              ./test-all.sh p1
              date'''
            }
            
L
liuyq-617 已提交
273 274
          }
        }
L
liuyq-617 已提交
275
        stage('python_2_s5') {
L
liuyq-617 已提交
276
          agent{label " slave5 || slave15 "}
L
liuyq-617 已提交
277 278 279
          steps {
            
            pre_test()
L
liuyq-617 已提交
280
            timeout(time: 55, unit: 'MINUTES'){
281 282 283 284 285
                sh '''
                date
                cd ${WKC}/tests
                ./test-all.sh p2
                date'''
L
liuyq-617 已提交
286 287 288 289
            }
          }
        }
        stage('python_3_s6') {
L
liuyq-617 已提交
290
          agent{label " slave6 || slave16 "}
L
liuyq-617 已提交
291
          steps {     
L
liuyq-617 已提交
292
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
293 294 295 296 297 298 299
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh p3
              date'''
            }
L
liuyq-617 已提交
300 301
          }
        }
L
liuyq-617 已提交
302
        stage('test_b1_s2') {
L
liuyq-617 已提交
303
          agent{label " slave2 || slave12 "}
L
liuyq-617 已提交
304
          steps {     
L
liuyq-617 已提交
305
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
306
              pre_test()
L
liuyq-617 已提交
307 308 309
              sh '''
                rm -rf /var/lib/taos/*
                rm -rf /var/log/taos/*
L
update  
liuyq-617 已提交
310
                nohup taosd >/dev/null &
L
liuyq-617 已提交
311 312 313 314
                sleep 10
              '''
              sh '''
              cd ${WKC}/tests/examples/nodejs
L
update  
liuyq-617 已提交
315
              npm install td2.0-connector > /dev/null 2>&1
L
liuyq-617 已提交
316
              node nodejsChecker.js host=localhost
R
root 已提交
317
              node test1970.js
318 319 320 321
	      cd ${WKC}/tests/connectorTest/nodejsTest/nanosupport
	      npm install td2.0-connector > /dev/null 2>&1
              node nanosecondTest.js

L
liuyq-617 已提交
322
              '''
323 324 325 326 327 328 329 330 331 332

              sh '''
              cd ${WKC}/src/connector/node-rest/
              npm install
              npm run build 
              npm run build:test
              npm run test

              '''

L
liuyq-617 已提交
333 334
              sh '''
                cd ${WKC}/tests/examples/C#/taosdemo
L
update  
liuyq-617 已提交
335
                mcs -out:taosdemo *.cs > /dev/null 2>&1
R
root 已提交
336
                echo '' |./taosdemo -c /etc/taos
337 338 339
                cd ${WKC}/tests/connectorTest/C#Test/nanosupport
                mcs -out:nano *.cs > /dev/null 2>&1
                echo '' |./nano
L
liuyq-617 已提交
340 341 342 343 344
              '''
              sh '''
                cd ${WKC}/tests/gotest
                bash batchtest.sh
              '''
L
liuyq-617 已提交
345 346 347 348 349
              sh '''
              cd ${WKC}/tests
              ./test-all.sh b1fq
              date'''
            }
Y
Yiqing Liu 已提交
350 351
          }
        }
L
liuyq-617 已提交
352
        stage('test_crash_gen_s3') {
L
liuyq-617 已提交
353
          agent{label " slave3 || slave13 "}
354
          
Y
Yiqing Liu 已提交
355
          steps {
356
            pre_test()
357 358 359
            timeout(time: 60, unit: 'MINUTES'){
              sh '''
              cd ${WKC}/tests/pytest
L
liuyq-617 已提交
360
              ./crash_gen.sh -a -p -t 4 -s 2000
361 362 363
              '''
            }
            timeout(time: 60, unit: 'MINUTES'){
P
Ping Xiao 已提交
364 365 366 367 368 369
              sh '''
              cd ${WKC}/tests/pytest
              rm -rf /var/lib/taos/*
              rm -rf /var/log/taos/*
              ./handle_crash_gen_val_log.sh
              '''
370 371 372 373 374 375
              sh '''
              cd ${WKC}/tests/pytest
              rm -rf /var/lib/taos/*
              rm -rf /var/log/taos/*
              ./handle_taosd_val_log.sh
              '''
L
liuyq-617 已提交
376
            }
L
liuyq-617 已提交
377
            timeout(time: 55, unit: 'MINUTES'){
378 379 380 381 382 383
                sh '''
                date
                cd ${WKC}/tests
                ./test-all.sh b2fq
                date
                '''
L
test  
liuyq-617 已提交
384
            }                     
Y
Yiqing Liu 已提交
385 386
          }
        }
L
liuyq-617 已提交
387
        stage('test_valgrind_s4') {
L
liuyq-617 已提交
388
          agent{label " slave4 || slave14 "}
L
liuyq-617 已提交
389

Y
Yiqing Liu 已提交
390
          steps {
391 392 393 394 395 396 397
            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 已提交
398
            }     
L
liuyq-617 已提交
399
            timeout(time: 55, unit: 'MINUTES'){      
L
liuyq-617 已提交
400 401 402 403 404
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b3fq
              date'''
P
change  
Ping Xiao 已提交
405 406 407 408 409
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh full example
              date'''
L
liuyq-617 已提交
410
            }
Y
Yiqing Liu 已提交
411 412
          }
        }
L
liuyq-617 已提交
413
        stage('test_b4_s7') {
L
liuyq-617 已提交
414
          agent{label " slave7 || slave17 "}
L
liuyq-617 已提交
415
          steps {     
L
liuyq-617 已提交
416
            timeout(time: 105, unit: 'MINUTES'){       
L
liuyq-617 已提交
417 418 419 420 421
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b4fq
L
fix  
liuyq-617 已提交
422
              cd ${WKC}/tests
L
liuyq-617 已提交
423
              ./test-all.sh p4
L
liuyq-617 已提交
424
              '''
L
liuyq-617 已提交
425 426
              // cd ${WKC}/tests
              // ./test-all.sh full jdbc
L
liuyq-617 已提交
427 428 429
              // cd ${WKC}/tests
              // ./test-all.sh full unit
              
L
liuyq-617 已提交
430 431 432 433
            }
          }
        }
        stage('test_b5_s8') {
L
liuyq-617 已提交
434
          agent{label " slave8 || slave18 "}
L
liuyq-617 已提交
435
          steps {     
L
liuyq-617 已提交
436
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
437 438 439 440 441 442 443 444 445 446
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b5fq
              date'''
            }
          }
        }
        stage('test_b6_s9') {
L
liuyq-617 已提交
447
          agent{label " slave9 || slave19 "}
L
liuyq-617 已提交
448
          steps {     
L
liuyq-617 已提交
449
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
450 451 452 453 454 455 456 457 458 459
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b6fq
              date'''
            }
          }
        }
        stage('test_b7_s10') {
L
liuyq-617 已提交
460
          agent{label " slave10 || slave20 "}
L
liuyq-617 已提交
461
          steps {     
L
liuyq-617 已提交
462
            timeout(time: 55, unit: 'MINUTES'){       
L
liuyq-617 已提交
463 464 465 466 467
              pre_test()
              sh '''
              date
              cd ${WKC}/tests
              ./test-all.sh b7fq
P
change  
Ping Xiao 已提交
468
              date'''              
L
liuyq-617 已提交
469 470
            }
          }
471
        } 
L
liuyq-617 已提交
472
        
L
liuyq-617 已提交
473 474 475 476 477 478 479 480 481 482 483 484 485 486
        stage('build'){
          agent{label " wintest "}
          steps {
            pre_test()
            script{             
                while(win_stop == 0){
                  sleep(1)
                  }
              }
            }
        }
        stage('test'){
          agent{label "win"}
          steps{
L
liuyq-617 已提交
487
            
L
liuyq-617 已提交
488 489 490 491 492 493 494 495 496 497 498 499 500 501
            catchError(buildResult: 'FAILURE', stageResult: 'FAILURE') {
                pre_test_win()
                timeout(time: 20, unit: 'MINUTES'){
                bat'''
                cd C:\\workspace\\TDinternal\\community\\tests\\pytest
                .\\test-all.bat wintest
                '''
                }
            }     
            script{
              win_stop=1
            }
          }
        }
L
liuyq-617 已提交
502 503
          
               
Y
Yiqing Liu 已提交
504 505
    }
  }
L
liuyq-617 已提交
506
  }
L
liuyq-617 已提交
507
  post {  
508 509
        success {
            emailext (
510 511
                subject: "PR-result: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]' SUCCESS",
                body: """<!DOCTYPE html>
512 513 514 515 516 517 518 519 520 521 522 523 524 525 526
                <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">
527
                                    <li>构建名称>>分支:${env.BRANCH_NAME}</li>
528 529
                                    <li>构建结果:<span style="color:green"> Successful </span></li>
                                    <li>构建编号:${BUILD_NUMBER}</li>
530
                                    <li>触发用户:${env.CHANGE_AUTHOR}</li>
L
fix  
liuyq-617 已提交
531
                                    <li>提交信息:${env.CHANGE_TITLE}</li>
532 533
                                    <li>构建地址:<a href=${BUILD_URL}>${BUILD_URL}</a></li>
                                    <li>构建日志:<a href=${BUILD_URL}console>${BUILD_URL}console</a></li>
534
                                    
535 536 537 538 539 540
                                </div>
                                </ul>
                            </td>
                        </tr>
                    </table></font>
                </body>
541
                </html>""",
L
liuyq-617 已提交
542
                to: "${env.CHANGE_AUTHOR_EMAIL}",
543 544 545 546 547
                from: "support@taosdata.com"
            )
        }
        failure {
            emailext (
548 549
                subject: "PR-result: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]' FAIL",
                body: """<!DOCTYPE html>
550 551 552 553 554 555 556 557 558 559 560 561 562 563 564
                <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">
565
                                    <li>构建名称>>分支:${env.BRANCH_NAME}</li>
L
liuyq-617 已提交
566
                                    <li>构建结果:<span style="color:red"> Failure </span></li>
567
                                    <li>构建编号:${BUILD_NUMBER}</li>
568
                                    <li>触发用户:${env.CHANGE_AUTHOR}</li>
L
fix  
liuyq-617 已提交
569
                                    <li>提交信息:${env.CHANGE_TITLE}</li>
570 571
                                    <li>构建地址:<a href=${BUILD_URL}>${BUILD_URL}</a></li>
                                    <li>构建日志:<a href=${BUILD_URL}console>${BUILD_URL}console</a></li>
572
                                    
573 574 575 576 577 578
                                </div>
                                </ul>
                            </td>
                        </tr>
                    </table></font>
                </body>
579
                </html>""",
L
liuyq-617 已提交
580
                to: "${env.CHANGE_AUTHOR_EMAIL}",
581 582 583
                from: "support@taosdata.com"
            )
        }
L
liuyq-617 已提交
584
    } 
X
xiaolei li 已提交
585
}