2024-10-24 02:13:28 +00:00
|
|
|
@Library('jenkins-shared-library@v0.62.0') _
|
2024-09-18 11:57:11 +00:00
|
|
|
|
|
|
|
def pod = libraryResource 'io/milvus/pod/tekton-4am.yaml'
|
|
|
|
def milvus_helm_chart_version = '4.2.8'
|
2022-07-15 03:40:26 +00:00
|
|
|
|
|
|
|
pipeline {
|
|
|
|
options {
|
2024-09-18 11:57:11 +00:00
|
|
|
skipDefaultCheckout true
|
2022-07-18 03:14:27 +00:00
|
|
|
parallelsAlwaysFailFast()
|
2024-09-18 11:57:11 +00:00
|
|
|
buildDiscarder logRotator(artifactDaysToKeepStr: '30')
|
2022-07-15 03:40:26 +00:00
|
|
|
preserveStashes(buildCount: 5)
|
|
|
|
disableConcurrentBuilds(abortPrevious: true)
|
|
|
|
}
|
|
|
|
agent {
|
2024-09-18 11:57:11 +00:00
|
|
|
kubernetes {
|
|
|
|
cloud '4am'
|
|
|
|
yaml pod
|
|
|
|
}
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
stages {
|
2024-09-18 11:57:11 +00:00
|
|
|
stage('meta') {
|
2022-07-15 03:40:26 +00:00
|
|
|
steps {
|
2024-09-18 11:57:11 +00:00
|
|
|
container('jnlp') {
|
|
|
|
script {
|
|
|
|
isPr = env.CHANGE_ID != null
|
|
|
|
gitMode = isPr ? 'merge' : 'fetch'
|
|
|
|
gitBaseRef = isPr ? "$env.CHANGE_TARGET" : "$env.BRANCH_NAME"
|
2022-07-15 03:40:26 +00:00
|
|
|
|
2024-09-18 11:57:11 +00:00
|
|
|
get_helm_release_name = tekton.helm_release_name client: 'py',
|
|
|
|
changeId: "${env.CHANGE_ID}",
|
|
|
|
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,
|
2024-10-29 06:14:24 +00:00
|
|
|
make_cmd: "make clean && make install USE_ASAN=ON use_disk_index=ON",
|
2024-09-18 11:57:11 +00:00
|
|
|
images: '["milvus","pytest","helm"]'
|
2022-07-15 03:40:26 +00:00
|
|
|
|
2024-09-18 11:57:11 +00:00
|
|
|
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()
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-09-18 11:57:11 +00:00
|
|
|
stage('E2E Test') {
|
2022-07-15 03:40:26 +00:00
|
|
|
matrix {
|
2024-09-18 11:57:11 +00:00
|
|
|
agent {
|
|
|
|
kubernetes {
|
|
|
|
cloud '4am'
|
2024-10-15 02:39:22 +00:00
|
|
|
// 'milvus' template defined a ephemeral volume used for pytest result archiving
|
|
|
|
// pvc name would be <pod-name>-volume-0
|
|
|
|
inheritFrom 'milvus'
|
2024-09-18 11:57:11 +00:00
|
|
|
yaml pod
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
2024-09-18 11:57:11 +00:00
|
|
|
}
|
|
|
|
axes {
|
2022-07-15 03:40:26 +00:00
|
|
|
axis {
|
2024-09-18 11:57:11 +00:00
|
|
|
name 'milvus_deployment_option'
|
2024-10-09 11:03:19 +00:00
|
|
|
values 'standalone', 'distributed', 'standalone-kafka-mmap', 'distributed-streaming-service'
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
stages {
|
2024-09-18 11:57:11 +00:00
|
|
|
stage('E2E Test') {
|
2022-07-15 03:40:26 +00:00
|
|
|
steps {
|
2024-09-18 11:57:11 +00:00
|
|
|
container('tkn') {
|
2022-07-15 03:40:26 +00:00
|
|
|
script {
|
2024-09-18 11:57:11 +00:00
|
|
|
def helm_release_name = get_helm_release_name milvus_deployment_option
|
2024-10-15 02:39:22 +00:00
|
|
|
// pvc name would be <pod-name>-volume-0, used for pytest result archiving
|
|
|
|
def pvc = env.JENKINS_AGENT_NAME + '-volume-0'
|
2024-09-18 11:57:11 +00:00
|
|
|
|
|
|
|
if (milvus_deployment_option == 'distributed-streaming-service') {
|
|
|
|
try {
|
|
|
|
tekton.pytest helm_release_name: helm_release_name,
|
2024-10-15 02:39:22 +00:00
|
|
|
pvc: pvc,
|
2024-09-18 11:57:11 +00:00
|
|
|
milvus_helm_version: milvus_helm_chart_version,
|
|
|
|
ciMode: 'e2e',
|
|
|
|
milvus_image_tag: milvus_image_tag,
|
|
|
|
pytest_image: pytest_image,
|
|
|
|
helm_image: helm_image,
|
|
|
|
milvus_deployment_option: milvus_deployment_option,
|
|
|
|
verbose: 'false'
|
|
|
|
} catch (Exception e) {
|
|
|
|
println e
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
2024-09-18 11:57:11 +00:00
|
|
|
} else {
|
|
|
|
tekton.pytest helm_release_name: helm_release_name,
|
2024-10-15 02:39:22 +00:00
|
|
|
pvc: pvc,
|
2024-09-18 11:57:11 +00:00
|
|
|
milvus_helm_version: milvus_helm_chart_version,
|
|
|
|
ciMode: 'e2e',
|
|
|
|
milvus_image_tag: milvus_image_tag,
|
|
|
|
pytest_image: pytest_image,
|
|
|
|
helm_image: helm_image,
|
|
|
|
milvus_deployment_option: milvus_deployment_option,
|
|
|
|
verbose: 'false'
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-09-18 11:57:11 +00:00
|
|
|
|
|
|
|
post {
|
2022-07-15 03:40:26 +00:00
|
|
|
always {
|
2024-09-18 11:57:11 +00:00
|
|
|
container('tkn') {
|
|
|
|
script {
|
|
|
|
tekton.sure_stop()
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
}
|
2023-08-28 02:22:25 +00:00
|
|
|
|
2024-09-18 11:57:11 +00:00
|
|
|
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
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
}
|
2024-10-15 02:39:22 +00:00
|
|
|
container('jnlp') {
|
|
|
|
script {
|
|
|
|
tekton.archive_pytest_logs(milvus_deployment_option)
|
|
|
|
}
|
|
|
|
}
|
2022-07-15 03:40:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|