diff --git a/charts/qdrant/templates/configmap.yaml b/charts/qdrant/templates/configmap.yaml index 9889759..9685ea6 100644 --- a/charts/qdrant/templates/configmap.yaml +++ b/charts/qdrant/templates/configmap.yaml @@ -8,7 +8,7 @@ data: SET_INDEX=${HOSTNAME##*-} {{- if and (.Values.snapshotRestoration.enabled) (eq (.Values.replicaCount | quote) (1 | quote)) }} echo "Starting initializing for pod $SET_INDEX and snapshots restoration" - ./entrypoint.sh {{ range .Values.snapshotRestoration.snapshots }} --snapshot {{ . }} {{ end }} + exec ./entrypoint.sh --uri 'http://{{ include "qdrant.fullname" . }}-0.{{ include "qdrant.fullname" . }}-headless:6335' {{ range .Values.snapshotRestoration.snapshots }} --snapshot {{ . }} {{ end }} {{- else }} echo "Starting initializing for pod $SET_INDEX" if [ "$SET_INDEX" = "0" ]; then diff --git a/test/integration/assets/snapshot-pvc.yaml b/test/integration/assets/snapshot-pvc.yaml new file mode 100644 index 0000000..d7826b1 --- /dev/null +++ b/test/integration/assets/snapshot-pvc.yaml @@ -0,0 +1,10 @@ +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: snapshots-pvc +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 1Gi diff --git a/test/integration/assets/snapshot-values.yaml b/test/integration/assets/snapshot-values.yaml new file mode 100644 index 0000000..7cf154d --- /dev/null +++ b/test/integration/assets/snapshot-values.yaml @@ -0,0 +1,6 @@ +updateConfigurationOnChange: true +snapshotRestoration: + enabled: true + pvcName: snapshots-pvc + # To be supplied via --set + snapshots: [] diff --git a/test/integration/snapshot_restore.bats b/test/integration/snapshot_restore.bats new file mode 100644 index 0000000..d3f4c7e --- /dev/null +++ b/test/integration/snapshot_restore.bats @@ -0,0 +1,27 @@ +# Inspired by https://github.com/qdrant/qdrant/blob/v1.6.1/tests/snapshots/snapshots-recovery.sh + +QDRANT_URL="http://qdrant.qdrant-helm-integration:6333" + +setup_file() { + # Create the PVC, then helm upgrade with no snapshots so that the PVC gets mounted + kubectl apply -f test/integration/assets/snapshot-pvc.yaml -n qdrant-helm-integration + helm upgrade --install qdrant charts/qdrant -n qdrant-helm-integration -f test/integration/assets/snapshot-values.yaml --set snapshotRestoration.snapshots=null --wait + kubectl rollout status statefulset qdrant -n qdrant-helm-integration + + # Create the test data and create a snapshot + helm test qdrant -n qdrant-helm-integration --logs + SNAPSHOT_NAME=$(kubectl exec -n default curl -- curl -X POST "$QDRANT_URL/collections/test_collection/snapshots" | grep -o 'test_collection.*\.snapshot') +} + + +@test "snapshot restoration works" { + kubectl exec -n default curl -- curl -X DELETE "$QDRANT_URL/collections/test_collection?wait" + + helm upgrade --install qdrant charts/qdrant -n qdrant-helm-integration -f test/integration/assets/snapshot-values.yaml --set snapshotRestoration.snapshots="{/qdrant/snapshots/test_collection/$SNAPSHOT_NAME\:test_collection}" --wait + kubectl rollout status statefulset qdrant -n qdrant-helm-integration + # Wait for snapshot restoration step to finish + sleep 2 + run kubectl exec -n default curl -- curl -s $QDRANT_URL/collections/test_collection/points/6 --fail-with-body + [ $status -eq 0 ] + [[ "${output}" =~ .*\"Mumbai\".* ]] +}