2021-11-16 21:30:23 +08:00
|
|
|
#!/usr/bin/env groovy
|
|
|
|
|
|
|
|
// When scheduling a job that gets automatically triggered by changes,
|
|
|
|
// you need to include a [cronjob] tag within the commit message.
|
|
|
|
String cron_timezone = 'TZ=Asia/Shanghai'
|
|
|
|
String cron_string = BRANCH_NAME == "master" ? "50 22 * * * " : ""
|
|
|
|
|
|
|
|
int total_timeout_minutes = 660
|
2021-11-24 19:47:15 +08:00
|
|
|
def imageTag=''
|
2021-12-09 10:07:15 +08:00
|
|
|
|
2021-11-16 21:30:23 +08:00
|
|
|
pipeline {
|
|
|
|
triggers {
|
|
|
|
cron """${cron_timezone}
|
|
|
|
${cron_string}"""
|
|
|
|
}
|
|
|
|
options {
|
|
|
|
timestamps()
|
|
|
|
timeout(time: total_timeout_minutes, unit: 'MINUTES')
|
|
|
|
buildDiscarder logRotator(artifactDaysToKeepStr: '30')
|
|
|
|
// parallelsAlwaysFailFast()
|
2021-11-24 19:47:15 +08:00
|
|
|
preserveStashes(buildCount: 5)
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
agent {
|
|
|
|
kubernetes {
|
2021-12-03 13:28:18 +08:00
|
|
|
label "milvus-e2e-test-nightly"
|
2021-11-16 21:30:23 +08:00
|
|
|
inheritFrom 'default'
|
|
|
|
defaultContainer 'main'
|
|
|
|
yamlFile "build/ci/jenkins/pod/rte.yaml"
|
|
|
|
customWorkspace '/home/jenkins/agent/workspace'
|
2021-12-07 10:11:45 +08:00
|
|
|
// idle 5 minutes to wait clean up tasks
|
|
|
|
idleMinutes 5
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
environment {
|
|
|
|
PROJECT_NAME = "milvus"
|
|
|
|
SEMVER = "${BRANCH_NAME.contains('/') ? BRANCH_NAME.substring(BRANCH_NAME.lastIndexOf('/') + 1) : BRANCH_NAME}"
|
|
|
|
DOCKER_BUILDKIT = 1
|
|
|
|
ARTIFACTS = "${env.WORKSPACE}/_artifacts"
|
|
|
|
DOCKER_CREDENTIALS_ID = "f0aacc8e-33f2-458a-ba9e-2c44f431b4d2"
|
|
|
|
TARGET_REPO = "milvusdb"
|
|
|
|
CI_DOCKER_CREDENTIAL_ID = "ci-docker-registry"
|
|
|
|
MILVUS_HELM_NAMESPACE = "milvus-ci"
|
|
|
|
DISABLE_KIND = true
|
|
|
|
HUB = "registry.milvus.io/milvus"
|
|
|
|
JENKINS_BUILD_ID = "${env.BUILD_ID}"
|
2022-01-06 14:27:20 +08:00
|
|
|
CI_MODE="nightly"
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
stages {
|
|
|
|
stage ('Build'){
|
|
|
|
steps {
|
|
|
|
container('main') {
|
2021-12-01 13:11:44 +08:00
|
|
|
dir ('build'){
|
|
|
|
sh './set_docker_mirror.sh'
|
|
|
|
}
|
2021-11-16 21:30:23 +08:00
|
|
|
dir ('tests/scripts') {
|
|
|
|
script {
|
|
|
|
sh 'printenv'
|
|
|
|
def date = sh(returnStdout: true, script: 'date +%Y%m%d').trim()
|
2021-11-24 19:47:15 +08:00
|
|
|
def gitShortCommit = sh(returnStdout: true, script: 'git rev-parse --short HEAD').trim()
|
2021-12-22 14:09:57 +08:00
|
|
|
imageTag="${env.BRANCH_NAME}-${date}-${gitShortCommit}"
|
2021-11-16 21:30:23 +08:00
|
|
|
withCredentials([usernamePassword(credentialsId: "${env.CI_DOCKER_CREDENTIAL_ID}", usernameVariable: 'CI_REGISTRY_USERNAME', passwordVariable: 'CI_REGISTRY_PASSWORD')]){
|
|
|
|
sh """
|
2021-11-24 19:47:15 +08:00
|
|
|
TAG="${imageTag}" \
|
2021-11-16 21:30:23 +08:00
|
|
|
./e2e-k8s.sh \
|
|
|
|
--skip-export-logs \
|
|
|
|
--skip-install \
|
|
|
|
--skip-cleanup \
|
|
|
|
--skip-setup \
|
2021-12-22 14:09:57 +08:00
|
|
|
--skip-test
|
2021-11-16 21:30:23 +08:00
|
|
|
"""
|
2021-11-24 19:47:15 +08:00
|
|
|
// stash imageTag info for rebuild install & E2E Test only
|
|
|
|
sh "echo ${imageTag} > imageTag.txt"
|
|
|
|
stash includes: 'imageTag.txt', name: 'imageTag'
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
stage ('Install & E2E Test') {
|
|
|
|
matrix {
|
|
|
|
axes {
|
|
|
|
axis {
|
|
|
|
name 'MILVUS_SERVER_TYPE'
|
|
|
|
values 'standalone', 'distributed'
|
|
|
|
}
|
|
|
|
axis {
|
|
|
|
name 'MILVUS_CLIENT'
|
|
|
|
values 'pymilvus'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
stages {
|
|
|
|
stage('Install') {
|
|
|
|
steps {
|
|
|
|
container('main') {
|
|
|
|
dir ('tests/scripts') {
|
|
|
|
script {
|
|
|
|
sh 'printenv'
|
|
|
|
def clusterEnabled = "false"
|
2021-11-23 19:55:14 +08:00
|
|
|
// def setMemoryResourceLimitArgs="--set standalone.resources.limits.memory=4Gi"
|
2021-11-16 21:30:23 +08:00
|
|
|
if ("${MILVUS_SERVER_TYPE}" == "distributed") {
|
|
|
|
clusterEnabled = "true"
|
2021-11-23 19:55:14 +08:00
|
|
|
// setMemoryResourceLimitArgs="--set queryNode.resources.limits.memory=4Gi"
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
if ("${MILVUS_CLIENT}" == "pymilvus") {
|
2021-11-24 19:47:15 +08:00
|
|
|
if ("${imageTag}"==''){
|
|
|
|
dir ("imageTag"){
|
|
|
|
try{
|
|
|
|
unstash 'imageTag'
|
|
|
|
imageTag=sh(returnStdout: true, script: 'cat imageTag.txt | tr -d \'\n\r\'')
|
|
|
|
}catch(e){
|
|
|
|
print "No Image Tag info remained ,please rerun build to build new image."
|
|
|
|
exit 1
|
|
|
|
}
|
2021-11-25 10:31:15 +08:00
|
|
|
}
|
2021-11-24 19:47:15 +08:00
|
|
|
}
|
2021-11-16 21:30:23 +08:00
|
|
|
withCredentials([usernamePassword(credentialsId: "${env.CI_DOCKER_CREDENTIAL_ID}", usernameVariable: 'CI_REGISTRY_USERNAME', passwordVariable: 'CI_REGISTRY_PASSWORD')]){
|
|
|
|
sh """
|
|
|
|
MILVUS_CLUSTER_ENABLED=${clusterEnabled} \
|
2021-11-24 19:47:15 +08:00
|
|
|
TAG="${imageTag}" \
|
2021-11-16 21:30:23 +08:00
|
|
|
./e2e-k8s.sh \
|
|
|
|
--skip-export-logs \
|
|
|
|
--skip-cleanup \
|
|
|
|
--skip-setup \
|
|
|
|
--skip-test \
|
|
|
|
--skip-build \
|
|
|
|
--skip-build-image \
|
2021-12-06 14:21:35 +08:00
|
|
|
--install-extra-arg "--set etcd.persistence.storageClass=local-path \
|
|
|
|
--set minio.persistence.storageClass=local-path \
|
|
|
|
--set etcd.metrics.enabled=true \
|
2021-12-09 17:57:04 +08:00
|
|
|
--set etcd.metrics.podMonitor.enabled=true \
|
2021-12-10 11:57:21 +08:00
|
|
|
--set etcd.nodeSelector.disk=fast \
|
2021-12-22 14:09:57 +08:00
|
|
|
--set metrics.serviceMonitor.enabled=true"
|
2021-11-16 21:30:23 +08:00
|
|
|
"""
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
error "Error: Unsupported Milvus client: ${MILVUS_CLIENT}"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage('E2E Test'){
|
|
|
|
steps {
|
|
|
|
container('pytest') {
|
|
|
|
dir ('tests/scripts') {
|
|
|
|
script {
|
|
|
|
def release_name=sh(returnStdout: true, script: './get_release_name.sh')
|
|
|
|
def clusterEnabled = "false"
|
|
|
|
int e2e_timeout_seconds = 6 * 60 * 60
|
|
|
|
if ("${MILVUS_SERVER_TYPE}" == "distributed") {
|
|
|
|
clusterEnabled = "true"
|
|
|
|
e2e_timeout_seconds = 10 * 60 * 60
|
|
|
|
}
|
|
|
|
if ("${MILVUS_CLIENT}" == "pymilvus") {
|
|
|
|
sh """
|
|
|
|
MILVUS_HELM_RELEASE_NAME="${release_name}" \
|
2021-12-31 14:14:17 +08:00
|
|
|
MILVUS_HELM_NAMESPACE="milvus-ci" \
|
2021-11-16 21:30:23 +08:00
|
|
|
MILVUS_CLUSTER_ENABLED="${clusterEnabled}" \
|
2021-11-24 16:13:15 +08:00
|
|
|
TEST_TIMEOUT="${e2e_timeout_seconds}" \
|
2021-12-09 15:44:13 +08:00
|
|
|
./ci_e2e.sh "--workers 4 --tags L0 L1 L2 --repeat-scope=session --random-order-bucket=global"
|
2021-11-16 21:30:23 +08:00
|
|
|
"""
|
|
|
|
} else {
|
|
|
|
error "Error: Unsupported Milvus client: ${MILVUS_CLIENT}"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
post {
|
|
|
|
unsuccessful {
|
|
|
|
container('jnlp') {
|
|
|
|
script {
|
|
|
|
emailext subject: '$DEFAULT_SUBJECT',
|
|
|
|
body: '$DEFAULT_CONTENT',
|
|
|
|
recipientProviders: [requestor()],
|
|
|
|
replyTo: '$DEFAULT_REPLYTO',
|
2021-12-22 14:09:57 +08:00
|
|
|
to: 'qa@zilliz.com,devops@zilliz.com'
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
success {
|
|
|
|
container('main') {
|
|
|
|
script {
|
|
|
|
withCredentials([usernamePassword(credentialsId: "${env.DOCKER_CREDENTIALS_ID}", usernameVariable: 'DOCKER_USERNAME', passwordVariable: 'DOCKER_PASSWORD')]) {
|
|
|
|
sh 'docker login -u ${DOCKER_USERNAME} -p ${DOCKER_PASSWORD}'
|
|
|
|
|
|
|
|
// Use ci registry instead of local registry
|
|
|
|
sh """
|
|
|
|
docker tag ${HUB}/milvus:${imageTag} ${TARGET_REPO}/milvus-nightly:${imageTag}
|
|
|
|
docker tag ${HUB}/milvus:${imageTag} ${TARGET_REPO}/milvus-nightly:${env.BRANCH_NAME}-latest
|
|
|
|
docker push ${TARGET_REPO}/milvus-nightly:${imageTag}
|
|
|
|
docker push ${TARGET_REPO}/milvus-nightly:${env.BRANCH_NAME}-latest
|
|
|
|
"""
|
|
|
|
sh 'docker logout'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-12-09 15:55:19 +08:00
|
|
|
always {
|
|
|
|
container('main') {
|
|
|
|
dir ('tests/scripts') {
|
|
|
|
script {
|
|
|
|
def release_name=sh(returnStdout: true, script: './get_release_name.sh')
|
|
|
|
sh "./uninstall_milvus.sh --release-name ${release_name}"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-11-16 21:30:23 +08:00
|
|
|
container('pytest') {
|
|
|
|
dir ('tests/scripts') {
|
|
|
|
script {
|
2021-12-09 15:55:19 +08:00
|
|
|
def release_name = sh(returnStdout: true, script: './get_release_name.sh ')
|
2021-11-16 21:30:23 +08:00
|
|
|
sh "./ci_logs.sh --log-dir /ci-logs --artifacts-name ${env.ARTIFACTS}/artifacts-${PROJECT_NAME}-${MILVUS_SERVER_TYPE}-${SEMVER}-${env.BUILD_NUMBER}-${MILVUS_CLIENT}-e2e-logs \
|
2021-12-09 15:55:19 +08:00
|
|
|
--release-name ${release_name}"
|
2021-11-16 21:30:23 +08:00
|
|
|
dir("${env.ARTIFACTS}") {
|
2021-12-09 15:55:19 +08:00
|
|
|
if ("${MILVUS_CLIENT}" == "pymilvus") {
|
2021-11-16 21:30:23 +08:00
|
|
|
sh "tar -zcvf artifacts-${PROJECT_NAME}-${MILVUS_SERVER_TYPE}-${MILVUS_CLIENT}-pytest-logs.tar.gz /tmp/ci_logs/test --remove-files || true"
|
2021-12-09 15:55:19 +08:00
|
|
|
}
|
|
|
|
archiveArtifacts artifacts: "artifacts-${PROJECT_NAME}-${MILVUS_SERVER_TYPE}-${MILVUS_CLIENT}-pytest-logs.tar.gz ", allowEmptyArchive: true
|
|
|
|
archiveArtifacts artifacts: "artifacts-${PROJECT_NAME}-${MILVUS_SERVER_TYPE}-${SEMVER}-${env.BUILD_NUMBER}-${MILVUS_CLIENT}-e2e-logs.tar.gz", allowEmptyArchive: true
|
2021-11-16 21:30:23 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|