milvus/ci/jenkins/Nightly2.groovy
yellow-shine b3de4b0edd
enhance: refine the pipeline (#37412)
1. enhance: allow to pass conan repo url
2. enhance: add throttle for cpu-e2e and cpp-unit-test pipeline

---------

Signed-off-by: Yellow Shine <sammy.huang@zilliz.com>
2024-11-06 10:24:30 +08:00

159 lines
6.5 KiB
Groovy

@Library('jenkins-shared-library@v0.67.0') _
def pod = libraryResource 'io/milvus/pod/tekton-4am.yaml'
String cron_timezone = 'TZ=Asia/Shanghai'
String cron_string = BRANCH_NAME == 'master' ? '50 1 * * * ' : ''
// Make timeout 4 hours so that we can run two nightly during the ci
int total_timeout_minutes = 7 * 60
def milvus_helm_chart_version = '4.2.18'
pipeline {
triggers {
cron """${cron_timezone}
${cron_string}"""
}
options {
skipDefaultCheckout true
timeout(time: total_timeout_minutes, unit: 'MINUTES')
// parallelsAlwaysFailFast()
buildDiscarder logRotator(artifactDaysToKeepStr: '30')
preserveStashes(buildCount: 5)
disableConcurrentBuilds(abortPrevious: true)
}
agent {
kubernetes {
cloud '4am'
yaml pod
}
}
stages {
stage('meta') {
steps {
container('jnlp') {
script {
isPr = env.CHANGE_ID != null
gitMode = isPr ? 'merge' : 'fetch'
gitBaseRef = isPr ? "$env.CHANGE_TARGET" : "$env.BRANCH_NAME"
get_helm_release_name = tekton.helm_release_name client: 'py',
ciMode: 'nightly',
changeId: "${isPr ? env.CHANGE_ID : env.BRANCH_NAME }",
buildId:"${env.BUILD_ID}"
}
}
}
}
stage('build') {
steps {
container('tkn') {
script {
def job_name = tekton.run arch: 'amd64',
isPr: isPr,
gitMode: gitMode ,
gitBaseRef: gitBaseRef,
pullRequestNumber: "$env.CHANGE_ID",
suppress_suffix_of_image_tag: true,
make_cmd: "make clean && make install use_disk_index=ON",
images: '["milvus","pytest","helm"]',
tekton_log_timeout: '30m'
milvus_image_tag = tekton.query_result job_name, 'milvus-image-tag'
pytest_image = tekton.query_result job_name, 'pytest-image-fqdn'
helm_image = tekton.query_result job_name, 'helm-image-fqdn'
}
}
}
post {
always {
container('tkn') {
script {
tekton.sure_stop()
}
}
}
}
}
stage('E2E Test') {
matrix {
agent {
kubernetes {
cloud '4am'
// 'milvus' template defined a ephemeral volume used for pytest result archiving
// pvc name would be <pod-name>-volume-0
inheritFrom 'milvus'
yaml pod
}
}
axes {
axis {
name 'milvus_deployment_option'
values 'standalone', 'distributed-pulsar', 'distributed-kafka', 'standalone-authentication', 'standalone-one-pod', 'distributed-streaming-service'
}
}
stages {
stage('E2E Test') {
steps {
container('tkn') {
script {
def helm_release_name = get_helm_release_name milvus_deployment_option
// pvc name would be <pod-name>-volume-0, used for pytest result archiving
def pvc = env.JENKINS_AGENT_NAME + '-volume-0'
tekton.pytest helm_release_name: helm_release_name,
pvc: pvc,
milvus_helm_version: milvus_helm_chart_version,
ciMode: 'nightly',
milvus_image_tag: milvus_image_tag,
pytest_image: pytest_image,
helm_image: helm_image,
milvus_deployment_option: milvus_deployment_option,
tekton_log_timeout: '30m',
verbose: 'false'
}
}
}
post {
always {
container('tkn') {
script {
tekton.sure_stop()
}
}
container('archive') {
script {
def helm_release_name = get_helm_release_name milvus_deployment_option
tekton.archive milvus_deployment_option: milvus_deployment_option,
release_name: helm_release_name ,
change_id: env.CHANGE_ID,
build_id: env.BUILD_ID
}
}
container('jnlp') {
script {
tekton.archive_pytest_logs(milvus_deployment_option)
}
}
}
}
}
}
}
}
}
post {
unsuccessful {
container('jnlp') {
script {
sendEmail.toQA()
}
}
}
}
}