123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 |
- pipeline {
- options {
- timestamps()
- }
- agent {
- kubernetes {
- label "milvus-test"
- defaultContainer 'main'
- yamlFile "build/ci/jenkins/pod/chaos-test.yaml"
- customWorkspace '/home/jenkins/agent/workspace'
- // idle 5 minutes to wait clean up tasks
- idleMinutes 5
- }
- }
- parameters{
- choice(
- description: 'Choose tools to deploy Milvus',
- name: 'deploy_tool',
- choices: ['helm']
- )
- choice(
- description: 'Milvus Mode',
- name: 'milvus_mode',
- choices: ["standalone", "cluster"]
- )
- choice(
- description: 'Deploy Test Task',
- name: 'deploy_task',
- choices: ['reinstall', 'upgrade']
- )
- string(
- description: 'Old Image Repository',
- name: 'old_image_repository',
- defaultValue: 'milvusdb/milvus'
- )
- string(
- description: 'Old Version Image Tag',
- name: 'old_image_tag',
- defaultValue: 'latest'
- )
- string(
- description: 'New Image Repository',
- name: 'new_image_repository',
- defaultValue: 'harbor.milvus.io/dockerhub/milvusdb/milvus'
- )
- string(
- description: 'New Version Image Tag',
- name: 'new_image_tag',
- defaultValue: 'master-latest'
- )
- string(
- description: 'Etcd Image Repository',
- name: 'etcd_image_repository',
- defaultValue: "milvusdb/etcd"
- )
- string(
- description: 'Etcd Image Tag',
- name: 'etcd_image_tag',
- defaultValue: "3.5.0-r6"
- )
- string(
- description: 'Querynode Nums',
- name: 'querynode_nums',
- defaultValue: '3'
- )
- string(
- description: 'DataNode Nums',
- name: 'datanode_nums',
- defaultValue: '2'
- )
- string(
- description: 'IndexNode Nums',
- name: 'indexnode_nums',
- defaultValue: '1'
- )
- string(
- description: 'Proxy Nums',
- name: 'proxy_nums',
- defaultValue: '1'
- )
- string(
- description: 'Data Size',
- name: 'data_size',
- defaultValue: '3000'
- )
- string(
- description: 'Idle Time in Minutes',
- name: 'idel_time',
- defaultValue: '1'
- )
- booleanParam(
- description: 'Keep Env',
- name: 'keep_env',
- defaultValue: 'false'
- )
- }
-
- environment {
- ARTIFACTS = "${env.WORKSPACE}/_artifacts"
- RELEASE_NAME = "${params.milvus_mode}-${params.deploy_task}-${env.BUILD_ID}"
- NAMESPACE = "chaos-testing"
- new_image_tag_modified = ""
- }
- stages {
- stage ('Install Dependency') {
- steps {
- container('main') {
- dir ('tests/python_client') {
- script {
- sh "pip install -r requirements.txt --trusted-host https://test.pypi.org"
- }
- }
- }
- }
- }
- stage ('Modify Milvus chart values') {
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- sh """
- yq -i '.queryNode.replicas = "${params.querynode_nums}"' cluster-values.yaml
- yq -i '.dataNode.replicas = "${params.datanode_nums}"' cluster-values.yaml
- yq -i '.indexNode.replicas = "${params.indexnode_nums}"' cluster-values.yaml
- yq -i '.proxy.replicas = "${params.proxy_nums}"' cluster-values.yaml
- yq -i '.etcd.image.repository = "${params.etcd_image_repository}"' cluster-values.yaml
- yq -i '.etcd.image.tag = "${params.etcd_image_tag}"' cluster-values.yaml
- yq -i '.etcd.image.repository = "${params.etcd_image_repository}"' standalone-values.yaml
- yq -i '.etcd.image.tag = "${params.etcd_image_tag}"' standalone-values.yaml
- cat cluster-values.yaml
- """
- }
- }
- }
- }
- }
- stage ('First Milvus Deployment') {
- options {
- timeout(time: 15, unit: 'MINUTES') // timeout on this stage
- }
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- def old_image_tag_modified = ""
- def new_image_tag_modified = ""
- def old_image_repository_modified = ""
- def new_image_repository_modified = ""
- if ("${params.old_image_tag}" == "master-latest") {
- old_image_tag_modified = sh(returnStdout: true, script: 'bash ../../../scripts/docker_image_find_tag.sh -n milvusdb/milvus -t master-latest -f master- -F -L -q').trim()
- }
- else if ("${params.old_image_tag}" == "latest") {
- old_image_tag_modified = sh(returnStdout: true, script: 'bash ../../../scripts/docker_image_find_tag.sh -n milvusdb/milvus -t latest -F -L -q').trim()
- }
- else {
- old_image_tag_modified = "${params.old_image_tag}"
- }
- if ("${params.new_image_tag}" == "master-latest") {
- new_image_tag_modified = sh(returnStdout: true, script: 'bash ../../../scripts/docker_image_find_tag.sh -n milvusdb/milvus -t master-latest -f master- -F -L -q').trim()
- }
- else {
- new_image_tag_modified = "${params.new_image_tag}"
- }
- sh "echo ${old_image_tag_modified}"
- sh "echo ${new_image_tag_modified}"
- sh "echo ${new_image_tag_modified} > new_image_tag_modified.txt"
- stash includes: 'new_image_tag_modified.txt', name: 'new_image_tag_modified'
- env.new_image_tag_modified = new_image_tag_modified
- if ("${params.deploy_task}" == "reinstall"){
- echo "reinstall Milvus with new image tag"
- old_image_tag_modified = new_image_tag_modified
- }
- if ("${params.deploy_task}" == "reinstall"){
- echo "reinstall Milvus with new image repository"
- old_image_repository_modified = "${params.new_image_repository}"
- }
- else {
- old_image_repository_modified = "${params.old_image_repository}"
- }
- sh "helm repo add milvus https://zilliztech.github.io/milvus-helm"
- sh "helm repo update"
- if ("${params.deploy_task}" == "upgrade"){
- if ("${params.milvus_mode}" == "standalone") {
- sh "helm install --wait --timeout 720s ${env.RELEASE_NAME} milvus/milvus --set image.all.repository=${old_image_repository_modified} --set image.all.tag=${old_image_tag_modified} --set etcd.image.repository=bitnami/etcd --set etcd.image.tag=3.5.0-debian-10-r24 -f standalone-values.yaml;"
- }
- if ("${params.milvus_mode}" == "cluster") {
- sh "helm install --wait --timeout 720s ${env.RELEASE_NAME} milvus/milvus --set image.all.repository=${old_image_repository_modified} --set image.all.tag=${old_image_tag_modified} --set etcd.image.repository=bitnami/etcd --set etcd.image.tag=3.5.0-debian-10-r24 -f cluster-values.yaml;"
- }
- }
- if ("${params.deploy_task}" == "reinstall"){
- if ("${params.milvus_mode}" == "standalone") {
- sh "helm install --wait --timeout 720s ${env.RELEASE_NAME} milvus/milvus --set image.all.repository=${old_image_repository_modified} --set image.all.tag=${old_image_tag_modified} -f standalone-values.yaml;"
- }
- if ("${params.milvus_mode}" == "cluster") {
- sh "helm install --wait --timeout 720s ${env.RELEASE_NAME} milvus/milvus --set image.all.repository=${old_image_repository_modified} --set image.all.tag=${old_image_tag_modified} -f cluster-values.yaml;"
- }
- }
- sh "kubectl wait --for=condition=Ready pod -l app.kubernetes.io/instance=${env.RELEASE_NAME} -n ${env.NAMESPACE} --timeout=360s"
- sh "kubectl wait --for=condition=Ready pod -l release=${env.RELEASE_NAME} -n ${env.NAMESPACE} --timeout=360s"
- sh "kubectl get pods -o wide|grep ${env.RELEASE_NAME}"
- }
- }
- }
- }
- }
- stage ('Run first test') {
- options {
- timeout(time: 30, unit: 'MINUTES') // timeout on this stage
- }
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- def host = sh(returnStdout: true, script: "kubectl get svc/${env.RELEASE_NAME}-milvus -o jsonpath=\"{.spec.clusterIP}\"").trim()
-
- if ("${params.deploy_task}" == "reinstall") {
- sh "python3 scripts/action_before_reinstall.py --host ${host} --data_size ${params.data_size}"
- }
- if ("${params.deploy_task}" == "upgrade") {
- sh "python3 scripts/action_before_upgrade.py --host ${host} --data_size ${params.data_size}"
- }
- }
- }
- }
- }
-
- }
- stage ('Milvus Idle Time') {
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- echo "sleep ${params.idel_time}m"
- sh "sleep ${params.idel_time}m"
- }
- }
- }
- }
- }
- stage ('Export log for first deployment') {
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- echo "get pod status"
- sh "kubectl get pods -o wide|grep ${env.RELEASE_NAME} || true"
- echo "collecte logs"
- sh "bash ../../scripts/export_log_k8s.sh ${env.NAMESPACE} ${env.RELEASE_NAME} k8s_log/${env.RELEASE_NAME}/first_deployment || echo 'export log failed'"
- }
- }
- }
- }
- }
- stage ('Uninstall Milvus') {
- options {
- timeout(time: 15, unit: 'MINUTES') // timeout on this stage
- }
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- if ("${params.milvus_mode}" == "standalone") {
- sh "kubectl delete pod -l app.kubernetes.io/instance=${env.RELEASE_NAME} --grace-period=0 --force"
- sh "kubectl delete pod -l release=${env.RELEASE_NAME} --grace-period=0 --force"
- sh "kubectl wait --for=condition=Ready pod -l app.kubernetes.io/instance=${env.RELEASE_NAME} -n ${env.NAMESPACE} --timeout=360s"
- sh "kubectl wait --for=condition=Ready pod -l release=${env.RELEASE_NAME} -n ${env.NAMESPACE} --timeout=360s"
- }
- if ("${params.milvus_mode}" == "cluster") {
- sh "helm uninstall ${env.RELEASE_NAME}"
- }
- }
- }
- }
- }
-
- }
- stage ('Second Milvus Deployment') {
- options {
- timeout(time: 20, unit: 'MINUTES') // timeout on this stage
- }
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- // in case of master-latest is different in two stages, we need use the new_image_tag_modified.txt to store the new_image_tag in first stage
- def new_image_tag_modified = ""
- dir ("new_image_tag_modified"){
- try{
- unstash 'new_image_tag_modified'
- new_image_tag_modified=sh(returnStdout: true, script: 'cat new_image_tag_modified.txt | tr -d \'\n\r\'')
- }catch(e){
- print "No image tag info remained"
- exit 1
- }
- }
- if ("${params.milvus_mode}" == "standalone") {
- sh "helm upgrade --wait --timeout 720s ${env.RELEASE_NAME} milvus/milvus --set image.all.repository=${params.new_image_repository} --set image.all.tag=${new_image_tag_modified} -f standalone-values.yaml"
- }
- if ("${params.milvus_mode}" == "cluster") {
- sh "helm install --wait --timeout 720s ${env.RELEASE_NAME} milvus/milvus --set image.all.repository=${params.new_image_repository} --set image.all.tag=${new_image_tag_modified} -f cluster-values.yaml"
- }
- sh "sleep 60s"
- // sh "kubectl wait --for=condition=Ready pod -l app.kubernetes.io/instance=${env.RELEASE_NAME} -n ${env.NAMESPACE} --timeout=360s"
- // sh "kubectl wait --for=condition=Ready pod -l release=${env.RELEASE_NAME} -n ${env.NAMESPACE} --timeout=360s"
- sh "kubectl get pods -o wide|grep ${env.RELEASE_NAME}"
- }
- }
- }
- }
-
- }
- stage ('Run Second Test') {
- options {
- timeout(time: 30, unit: 'MINUTES') // timeout on this stage
- }
- steps {
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- sh "sleep 60s" // wait loading data for the second deployment to be ready
- def host = sh(returnStdout: true, script: "kubectl get svc/${env.RELEASE_NAME}-milvus -o jsonpath=\"{.spec.clusterIP}\"").trim()
- if ("${params.deploy_task}" == "reinstall") {
- sh "python3 scripts/action_after_reinstall.py --host ${host} --data_size ${params.data_size}"
- }
- if ("${params.deploy_task}" == "upgrade") {
- sh "python3 scripts/action_after_upgrade.py --host ${host} --data_size ${params.data_size}"
- }
- }
- }
- }
- }
-
- }
-
- }
- post {
- always {
- echo 'upload logs'
- container('main') {
- dir ('tests/python_client/deploy') {
- script {
- echo "get pod status"
- sh "kubectl get pods -o wide|grep ${env.RELEASE_NAME} || true"
- echo "collecte logs"
- sh "bash ../../scripts/export_log_k8s.sh ${env.NAMESPACE} ${env.RELEASE_NAME} k8s_log/${env.RELEASE_NAME}/second_deployment || echo 'export log failed'"
- echo "upload logs"
- sh "tar -zcvf artifacts-${env.RELEASE_NAME}-logs.tar.gz k8s_log/ --remove-files || true"
- archiveArtifacts artifacts: "artifacts-${env.RELEASE_NAME}-logs.tar.gz", allowEmptyArchive: true
- if ("${params.keep_env}" == "false"){
- sh "bash ../chaos/scripts/uninstall_milvus.sh ${env.RELEASE_NAME}"
- }
- }
- }
- }
-
- }
- success {
- echo 'I succeeeded!'
- container('main') {
- dir ('tests/python_client/chaos/scripts') {
- script {
- sh "bash uninstall_milvus.sh ${env.RELEASE_NAME} || true"
- }
- }
- }
- }
- unstable {
- echo 'I am unstable :/'
- }
- failure {
- echo 'I failed :('
- }
- changed {
- echo 'Things were different before...'
- }
- }
- }
|