2021-12-31 10:31:18 +00:00
|
|
|
|
|
|
|
String cron_timezone = 'TZ=Asia/Shanghai'
|
2022-01-04 12:57:25 +00:00
|
|
|
String cron_string = BRANCH_NAME == "master" ? "05 21 * * * " : ""
|
2021-12-31 10:31:18 +00:00
|
|
|
|
2022-05-09 06:51:52 +00:00
|
|
|
int total_timeout_minutes = 90
|
2021-12-31 10:31:18 +00:00
|
|
|
|
|
|
|
// pipeline
|
|
|
|
pipeline {
|
|
|
|
triggers {
|
|
|
|
cron """${cron_timezone}
|
|
|
|
${cron_string}"""
|
|
|
|
}
|
|
|
|
options {
|
|
|
|
timestamps()
|
|
|
|
timeout(time: total_timeout_minutes, unit: 'MINUTES')
|
|
|
|
}
|
|
|
|
|
|
|
|
agent {
|
|
|
|
kubernetes {
|
2022-01-06 01:41:20 +00:00
|
|
|
label 'milvus-scale-test'
|
|
|
|
// inheritFrom 'milvus-test'
|
|
|
|
defaultContainer 'milvus-test'
|
|
|
|
yamlFile "build/ci/jenkins/pod/scale-test.yaml"
|
|
|
|
customWorkspace "/home/jenkins/agent"
|
2021-12-31 10:31:18 +00:00
|
|
|
// idle 5 minutes to wait clean up tasks
|
|
|
|
idleMinutes 5
|
|
|
|
}
|
|
|
|
}
|
|
|
|
environment {
|
|
|
|
PROJECT_NAME = "milvus"
|
|
|
|
TEST_TYPE = "scale-test"
|
|
|
|
// SEMVER = "${BRANCH_NAME.contains('/') ? BRANCH_NAME.substring(BRANCH_NAME.lastIndexOf('/') + 1) : BRANCH_NAME}"
|
|
|
|
ARTIFACTS = "${env.WORKSPACE}/_artifacts"
|
2022-01-18 01:21:36 +00:00
|
|
|
MILVUS_LOGS = "/tmp/milvus_logs/*"
|
2021-12-31 10:31:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
stages {
|
|
|
|
stage ('Install'){
|
|
|
|
steps {
|
|
|
|
container('milvus-test') {
|
|
|
|
dir ('tests/python_client'){
|
|
|
|
sh """
|
2022-06-24 09:16:32 +00:00
|
|
|
pip install --upgrade setuptools
|
2022-06-08 09:02:07 +00:00
|
|
|
pip install --upgrade pip
|
2021-12-31 10:31:18 +00:00
|
|
|
pip install -r requirements.txt
|
|
|
|
"""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
stage ('Scale Test') {
|
|
|
|
steps {
|
|
|
|
container('milvus-test') {
|
|
|
|
dir ('tests/python_client/scale') {
|
|
|
|
script {
|
2022-01-06 10:49:25 +00:00
|
|
|
// pytest run scale case in parallel
|
2022-07-28 08:00:31 +00:00
|
|
|
sh 'pytest test_data_node_scale.py -v -s'
|
|
|
|
sh 'pytest test_index_node_scale.py -n 2 -v -s'
|
|
|
|
sh 'pytest test_proxy_scale.py -v -s'
|
|
|
|
sh 'pytest test_query_node_scale.py -n 3 -v -s'
|
2021-12-31 10:31:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
post {
|
2022-01-04 12:57:25 +00:00
|
|
|
unsuccessful {
|
|
|
|
container ('jnlp') {
|
|
|
|
script {
|
|
|
|
emailext subject: '$DEFAULT_SUBJECT',
|
|
|
|
body: '$DEFAULT_CONTENT',
|
|
|
|
// recipientProviders: [requestor()],
|
|
|
|
// replyTo: '$DEFAULT_REPLYTO',
|
|
|
|
to: 'qa@zilliz.com'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-12-31 10:31:18 +00:00
|
|
|
always {
|
|
|
|
container('milvus-test') {
|
|
|
|
dir ('tests/scripts') {
|
|
|
|
script {
|
|
|
|
dir("${env.ARTIFACTS}") {
|
|
|
|
sh "tar -zcvf artifacts-${PROJECT_NAME}-${TEST_TYPE}-pytest-logs.tar.gz /tmp/ci_logs --remove-files || true"
|
2022-01-18 01:21:36 +00:00
|
|
|
archiveArtifacts artifacts: "artifacts-${PROJECT_NAME}-${TEST_TYPE}-pytest-logs.tar.gz ", allowEmptyArchive: true
|
|
|
|
DIR_LIST = sh(returnStdout: true, script: 'ls -d1 ${MILVUS_LOGS}').trim()
|
|
|
|
for (d in DIR_LIST.tokenize("\n")) {
|
|
|
|
sh "echo $d"
|
|
|
|
def release_name = d.split('/')[-1]
|
|
|
|
sh "tar -zcvf artifacts-${PROJECT_NAME}-${TEST_TYPE}-${release_name}-logs.tar.gz ${d} --remove-files || true"
|
|
|
|
archiveArtifacts artifacts: "artifacts-${PROJECT_NAME}-${TEST_TYPE}-${release_name}-logs.tar.gz ", allowEmptyArchive: true
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
2021-12-31 10:31:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|