mirror of https://github.com/milvus-io/milvus.git
159 lines
6.5 KiB
Groovy
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()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|