Skip to content

Commit e38f94c

Browse files
author
Mladen Rusev
committed
refactored script ver
1 parent 4d90fa8 commit e38f94c

File tree

1 file changed

+24
-54
lines changed

1 file changed

+24
-54
lines changed

hack/e2e/test.sh

Lines changed: 24 additions & 54 deletions
Original file line numberDiff line numberDiff line change
@@ -141,7 +141,7 @@ venctl components kubernetes apply \
141141

142142
kubectl apply -n venafi -f venafi-components.yaml
143143
kubectl set env deployments/venafi-kubernetes-agent -n venafi GOCOVERDIR=/coverage
144-
kubectl rollout status deployment/venafi-kubernetes-agent -n venafi --timeout=2m
144+
kubectl rollout status deployment/venafi-kubernetes-agent -n venafi --timeout=5m
145145

146146
subject="system:serviceaccount:venafi:venafi-components"
147147
audience="https://${VEN_API_HOST}"
@@ -249,56 +249,26 @@ getCertificate() {
249249
# Wait 5 minutes for the certificate to appear.
250250
for ((i=0;;i++)); do if getCertificate; then exit 0; fi; sleep 30; done | timeout -v -- 5m cat
251251

252-
#export AGENT_POD_NAME=$(kubectl get pods -n venafi -l app.kubernetes.io/name=venafi-kubernetes-agent -o jsonpath="{.items[0].metadata.name}")
253-
#
254-
#echo "Sending SIGQUIT to agent pod '${AGENT_POD_NAME}' to trigger graceful shutdown and flush coverage..."
255-
## Use kubectl debug to attach a busybox container to the running pod.
256-
## --target specifies the container to share the process space with.
257-
## --share-processes allows our new container to see and signal the agent process.
258-
## We then run 'kill -s QUIT 1' to signal PID 1 (the agent) to quit gracefully.
259-
#kubectl debug -q -n venafi "${AGENT_POD_NAME}" \
260-
# --image=busybox:1.36 \
261-
# --target=venafi-kubernetes-agent \
262-
# --share-processes \
263-
# -- sh -c 'kill -s QUIT 1'
264-
#
265-
#echo "Waiting for agent pod '${AGENT_POD_NAME}' to terminate gracefully..."
266-
## The pod will now terminate because its main process is exiting.
267-
## We wait for Kubernetes to recognize this and delete the pod object.
268-
#kubectl wait --for=delete pod/${AGENT_POD_NAME} -n venafi --timeout=90s
269-
#
270-
#echo "Scaling down deployment to prevent pod from restarting..."
271-
## Now that the pod is gone and coverage is flushed, we scale the deployment
272-
## to ensure the ReplicaSet controller doesn't create a new one.
273-
#kubectl scale deployment venafi-kubernetes-agent -n venafi --replicas=0
274-
#echo "Waiting for agent pod '${AGENT_POD_NAME}' to terminate as a result of the scale-down..."
275-
#kubectl wait --for=delete pod/${AGENT_POD_NAME} -n venafi --timeout=90s
276-
#echo "Starting helper pod to retrieve coverage files from the PVC..."
277-
#
278-
#kubectl apply -n venafi -f - <<EOF
279-
#apiVersion: v1
280-
#kind: Pod
281-
#metadata:
282-
# name: coverage-helper-pod
283-
#spec:
284-
# containers:
285-
# - name: helper
286-
# image: alpine:latest
287-
# command: ["sleep", "infinity"]
288-
# volumeMounts:
289-
# - name: coverage-storage
290-
# mountPath: /coverage-data
291-
# volumes:
292-
# - name: coverage-storage
293-
# persistentVolumeClaim:
294-
# claimName: coverage-pvc
295-
#EOF
296-
#
297-
#echo "Waiting for the helper pod to be ready..."
298-
#kubectl wait --for=condition=Ready pod/coverage-helper-pod -n venafi --timeout=2m
299-
#
300-
#echo "Copying coverage files from the helper pod..."
301-
#mkdir -p $COVERAGE_HOST_PATH
302-
#kubectl cp -n venafi "coverage-helper-pod:/coverage-data/." $COVERAGE_HOST_PATH
303-
#echo "Coverage files retrieved. Listing contents:"
304-
#ls -la $COVERAGE_HOST_PATH
252+
AGENT_POD_NAME=$(kubectl get pods -n venafi -l app.kubernetes.io/name=venafi-kubernetes-agent -o json | jq -r '.items[] | select(.status.phase=="Running") | .metadata.name' | head -n 1)
253+
254+
if [[ -z "${AGENT_POD_NAME}" ]]; then
255+
echo "ERROR: Could not find a running venafi-kubernetes-agent pod to collect coverage from."
256+
exit 1
257+
fi
258+
echo "INFO: Found running agent pod: ${AGENT_POD_NAME}"
259+
260+
261+
# 2. Start kubectl port-forward in the background.
262+
# We forward local port 8089 to the pod's admin server port 8089.
263+
echo "INFO: Starting port-forward to ${AGENT_POD_NAME}..."
264+
kubectl port-forward -n venafi "pod/${AGENT_POD_NAME}" 8089:8089
265+
266+
# Give the port-forward a moment to establish the connection.
267+
sleep 5
268+
269+
270+
echo "INFO: Downloading coverage files..."
271+
curl --fail-with-body -s http://localhost:8089/_debug/coverage/download -o "${COVERAGE_HOST_PATH}/coverage.out"
272+
curl --fail-with-body -s http://localhost:8089/_debug/coverage/meta/download -o "${COVERAGE_HOST_PATH}/coverage.meta"
273+
274+
ls -la $COVERAGE_HOST_PATH

0 commit comments

Comments
 (0)