Skip to content

Commit

Permalink
fixup post review 4 - refactor e2e tests
Browse files Browse the repository at this point in the history
  • Loading branch information
anurag4DSB committed Jan 7, 2025
1 parent 8482a38 commit 491a516
Showing 1 changed file with 27 additions and 48 deletions.
75 changes: 27 additions & 48 deletions .github/scripts/e2e_tests_metrics.sh
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,29 @@ log_and_run() {
"$@" 2>&1 | tee -a "$LOG_FILE"
}

validate_metric() {
local action="$1"
local count="$2"
local expected="$3"
local duration="$4"

# Print details for the metric
echo "$action Count: $count, Expected: $expected" | tee -a "$LOG_FILE"
echo "$action Duration: $duration" | tee -a "$LOG_FILE"

# Validate counts
if [[ "$count" -ne "$expected" ]]; then
echo "Error: $action count mismatch. Found: $count, Expected: $expected" | tee -a "$LOG_FILE"
exit 1
fi

# Validate durations are greater than 0
if (( $(echo "$duration <= 0" | bc -l) )); then
echo "Error: $action duration is not greater than 0. Duration: $duration" | tee -a "$LOG_FILE"
exit 1
fi
}

# Fetch services and validate the target service exists
log_and_run kubectl get svc --all-namespaces

Expand Down Expand Up @@ -115,54 +138,10 @@ if [[ "$EXPECTED_CREATE_BUCKET" -gt 0 ]]; then
CREATE_USER_DURATION="$(echo "$S3_IAM_METRICS_OUTPUT" | grep 'scality_cosi_driver_iam_request_duration_seconds_sum' | grep 'action="CreateUser"' | awk '{print $NF}')"
DELETE_USER_DURATION="$(echo "$S3_IAM_METRICS_OUTPUT" | grep 'scality_cosi_driver_iam_request_duration_seconds_sum' | grep 'action="DeleteUser"' | awk '{print $NF}')"

echo "CreateBucket Count: $CREATE_BUCKET_COUNT, Expected: $EXPECTED_CREATE_BUCKET" | tee -a "$LOG_FILE"
echo "DeleteBucket Count: $DELETE_BUCKET_COUNT, Expected: $EXPECTED_DELETE_BUCKET" | tee -a "$LOG_FILE"
echo "CreateUser Count: $CREATE_USER_COUNT, Expected: $EXPECTED_GRANT_ACCESS" | tee -a "$LOG_FILE"
echo "DeleteUser Count: $DELETE_USER_COUNT, Expected: $EXPECTED_REVOKE_ACCESS" | tee -a "$LOG_FILE"

echo "CreateBucket Duration: $CREATE_BUCKET_DURATION" | tee -a "$LOG_FILE"
echo "DeleteBucket Duration: $DELETE_BUCKET_DURATION" | tee -a "$LOG_FILE"
echo "CreateUser Duration: $CREATE_USER_DURATION" | tee -a "$LOG_FILE"
echo "DeleteUser Duration: $DELETE_USER_DURATION" | tee -a "$LOG_FILE"

# Validate counts
if [[ "$CREATE_BUCKET_COUNT" -ne "$EXPECTED_CREATE_BUCKET" ]]; then
echo "Error: CreateBucket count mismatch. Found: $CREATE_BUCKET_COUNT, Expected: $EXPECTED_CREATE_BUCKET" | tee -a "$LOG_FILE"
exit 1
fi
if [[ "$DELETE_BUCKET_COUNT" -ne "$EXPECTED_DELETE_BUCKET" ]]; then
echo "Error: DeleteBucket count mismatch. Found: $DELETE_BUCKET_COUNT, Expected: $EXPECTED_DELETE_BUCKET" | tee -a "$LOG_FILE"
exit 1
fi
if [[ "$CREATE_USER_COUNT" -ne "$EXPECTED_GRANT_ACCESS" ]]; then
echo "Error: CreateUser count mismatch. Found: $CREATE_USER_COUNT, Expected: $EXPECTED_GRANT_ACCESS" | tee -a "$LOG_FILE"
exit 1
fi

if [[ "$DELETE_USER_COUNT" -ne "$EXPECTED_REVOKE_ACCESS" ]]; then
echo "Error: DeleteUser count mismatch. Found: $DELETE_USER_COUNT, Expected: $EXPECTED_REVOKE_ACCESS" | tee -a "$LOG_FILE"
exit 1
fi

# Validate durations are greater than 0
if (( $(echo "$CREATE_BUCKET_DURATION <= 0" | bc -l) )); then
echo "Error: CreateBucket duration is not greater than 0. Duration: $CREATE_BUCKET_DURATION" | tee -a "$LOG_FILE"
exit 1
fi
if (( $(echo "$DELETE_BUCKET_DURATION <= 0" | bc -l) )); then
echo "Error: DeleteBucket duration is not greater than 0. Duration: $DELETE_BUCKET_DURATION" | tee -a "$LOG_FILE"
exit 1
fi

if (( $(echo "$CREATE_USER_DURATION <= 0" | bc -l) )); then
echo "Error: CreateUser duration is not greater than 0. Duration: $CREATE_USER_DURATION" | tee -a "$LOG_FILE"
exit 1
fi

if (( $(echo "$DELETE_USER_DURATION <= 0" | bc -l) )); then
echo "Error: DeleteUser duration is not greater than 0. Duration: $DELETE_USER_DURATION" | tee -a "$LOG_FILE"
exit 1
fi
validate_metric "CreateBucket" "$CREATE_BUCKET_COUNT" "$EXPECTED_CREATE_BUCKET" "$CREATE_BUCKET_DURATION"
validate_metric "DeleteBucket" "$DELETE_BUCKET_COUNT" "$EXPECTED_DELETE_BUCKET" "$DELETE_BUCKET_DURATION"
validate_metric "CreateUser" "$CREATE_USER_COUNT" "$EXPECTED_GRANT_ACCESS" "$CREATE_USER_DURATION"
validate_metric "DeleteUser" "$DELETE_USER_COUNT" "$EXPECTED_REVOKE_ACCESS" "$DELETE_USER_DURATION"
fi

echo "Metrics validation successful!" | tee -a "$LOG_FILE"

0 comments on commit 491a516

Please sign in to comment.