Skip to content

Commit

Permalink
Add SPM integration tests (#5640)
Browse files Browse the repository at this point in the history
## Which problem is this PR solving?
- #5608

## Description of the changes
- changelog: added basic build test for SPM

## How was this change tested?
- manual testing and CI

## Checklist
- [ ] I have read
https://github.com/jaegertracing/jaeger/blob/master/CONTRIBUTING_GUIDELINES.md
- [ ] I have signed all commits
- [ ] I have added unit tests for the new functionality
- [ ] I have run lint and test steps successfully
  - for `jaeger`: `make lint test`
  - for `jaeger-ui`: `yarn lint` and `yarn test`

---------

Signed-off-by: mehul gautam <[email protected]>
Signed-off-by: Yuri Shkuro <[email protected]>
Signed-off-by: Yuri Shkuro <[email protected]>
Signed-off-by: mehul gautam <[email protected]>
Co-authored-by: Yuri Shkuro <[email protected]>
Co-authored-by: Yuri Shkuro <[email protected]>
Co-authored-by: Raghuram Kannan <[email protected]>
Co-authored-by: mehul gautam <[email protected]>
  • Loading branch information
5 people authored Jun 24, 2024
1 parent afdd311 commit be558df
Show file tree
Hide file tree
Showing 3 changed files with 132 additions and 1 deletion.
4 changes: 4 additions & 0 deletions .github/workflows/ci-build-spm.yml
Original file line number Diff line number Diff line change
Expand Up @@ -42,3 +42,7 @@ jobs:
- name: Temporary - only run the build
run:
cd docker-compose/monitor && make build

- name: Run SPM Test
run: ./scripts/spm-integration-test.sh

2 changes: 1 addition & 1 deletion docker-compose/monitor/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ build: clean-jaeger
.PHONY: dev
dev: export JAEGER_IMAGE_TAG = dev
dev:
docker compose -f docker-compose.yml up
docker compose -f docker-compose.yml up $(DOCKER_COMPOSE_ARGS)

.PHONY: clean-jaeger
clean-jaeger:
Expand Down
127 changes: 127 additions & 0 deletions scripts/spm-integration-test.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,127 @@
#!/bin/bash

set -euf -o pipefail

compose_file=docker-compose/monitor/docker-compose.yml
timeout=300
end_time=$((SECONDS + timeout))
success="false"

check_service_health() {
local service_name=$1
local url=$2
echo "Checking health of service: $service_name at $url"

local wait_seconds=10
local curl_params=(
--silent
--output
/dev/null
--write-out
"%{http_code}"
)
while [ $SECONDS -lt $end_time ]; do
if [[ "$(curl "${curl_params[@]}" "${url}")" == "200" ]]; then
echo "$service_name is healthy"
return 0
fi
echo "Waiting for $service_name to be healthy..."
sleep $wait_seconds
done

echo "❌ ERROR: $service_name did not become healthy in time"
return 1
}

# Function to check if all services are healthy
wait_for_services() {
echo "Waiting for services to be up and running..."
check_service_health "Jaeger" "http://localhost:16686"
check_service_health "Prometheus" "http://localhost:9090/graph"
# Grafana is not actually important for the functional test,
# but it at least validates that the docker-compose file is correct.
check_service_health "Grafana" "http://localhost:3000"
}

# Function to validate the service metrics
validate_service_metrics() {
local service=$1
# Time constants in milliseconds
local fiveMinutes=300000
local oneMinute=60000
local fifteenSec=15000 # Prometheus is also configured to scrape every 15sec.
# When endTs=(blank) the server will default it to now().
local url="http://localhost:16686/api/metrics/calls?service=${service}&endTs=&lookback=${fiveMinutes}&step=${fifteenSec}&ratePer=${oneMinute}"
response=$(curl -s "$url")
service_name=$(echo "$response" | jq -r 'if .metrics and .metrics[0] then .metrics[0].labels[] | select(.name=="service_name") | .value else empty end')
if [ "$service_name" != "$service" ]; then
echo "⏳ No metrics found for service '$service'"
return 1
fi
# Store the values in an array
mapfile -t metric_points < <(echo "$response" | jq -r '.metrics[0].metricPoints[].gaugeValue.doubleValue')
echo "Metric datapoints found for service '$service': " "${metric_points[@]}"
# Check that all values are non-zero
local non_zero_count=0
for value in "${metric_points[@]}"; do
if [[ $(echo "$value > 0.0" | bc) == "1" ]]; then
non_zero_count=$((non_zero_count + 1))
else
echo "❌ ERROR: Zero values not expected"
return 1
fi
done
if [ $non_zero_count -lt 3 ]; then
echo "⏳ Expecting at least 3 non-zero data points"
return 1
fi
return 0
}

check_spm() {
local wait_seconds=10
local successful_service=0
services_list=("driver" "customer" "mysql" "redis" "frontend" "route" "ui")
for service in "${services_list[@]}"; do
echo "Processing service: $service"
while [ $SECONDS -lt $end_time ]; do
if validate_service_metrics "$service"; then
echo "✅ Found all expected metrics for service '$service'"
successful_service=$((successful_service + 1))
break
fi
sleep $wait_seconds
done
done
if [ $successful_service -lt ${#services_list[@]} ]; then
echo "❌ ERROR: Expected metrics from ${#services_list[@]} services, found only ${successful_service}"
exit 1
else
echo "✅ All services metrics are returned by the API"
fi
}

dump_logs() {
echo "::group:: docker logs"
docker compose -f $compose_file logs
echo "::endgroup::"
}

teardown_services() {
if [[ "$success" == "false" ]]; then
dump_logs
fi
docker compose -f $compose_file down
}

main() {
(cd docker-compose/monitor && make build && make dev DOCKER_COMPOSE_ARGS="-d")
wait_for_services
check_spm
success="true"
}

trap teardown_services EXIT INT

# Run the main function
main

0 comments on commit be558df

Please sign in to comment.