Compare commits
	
		
			3 Commits
		
	
	
		
			b753866b98
			...
			v3.1.19
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4336e99e0c | |||
| 455259a852 | |||
| d8709c0849 | 
| @@ -185,89 +185,97 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Deploy to production (Local Test) |       - name: Deploy to production (Local Test) | ||||||
|         run: | |         run: | | ||||||
|  |           set -euo pipefail | ||||||
|           echo "🚀 Testing ${{ needs.create-release.outputs.version }} deployment locally..." |           echo "🚀 Testing ${{ needs.create-release.outputs.version }} deployment locally..." | ||||||
|  |            | ||||||
|  |           # Create a dedicated network so we can resolve by container name | ||||||
|  |           docker network create ci_net || true | ||||||
|  |            | ||||||
|           # Pull the built image |           # Pull the built image | ||||||
|           docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.create-release.outputs.version }} |           docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.create-release.outputs.version }} | ||||||
|  |            | ||||||
|           # Stop any existing containers |           # Stop & remove any existing container | ||||||
|           docker stop ping-river-monitor-test || true |           docker rm -f ping-river-monitor-test 2>/dev/null || true | ||||||
|           docker rm ping-river-monitor-test || true |            | ||||||
|  |           # Start the container on the user-defined network | ||||||
|           # Start the container for testing |  | ||||||
|           docker run -d \ |           docker run -d \ | ||||||
|             --name ping-river-monitor-test \ |             --name ping-river-monitor-test \ | ||||||
|  |             --network ci_net \ | ||||||
|             -p 8080:8000 \ |             -p 8080:8000 \ | ||||||
|             -e LOG_LEVEL=INFO \ |             -e LOG_LEVEL=INFO \ | ||||||
|             -e DB_TYPE=sqlite \ |             -e DB_TYPE=sqlite \ | ||||||
|             ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.create-release.outputs.version }} |             ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.create-release.outputs.version }} | ||||||
|  |            | ||||||
|           echo "✅ Container started for testing" |           echo "✅ Container started for testing" | ||||||
|  |  | ||||||
|       - name: Health check after deployment |       - name: Health check after deployment | ||||||
|         run: | |         run: | | ||||||
|  |           set -euo pipefail | ||||||
|           echo "⏳ Waiting for application to start..." |           echo "⏳ Waiting for application to start..." | ||||||
|           sleep 30 |  | ||||||
|  |  | ||||||
|           echo "🔍 Running health checks against local container..." |  | ||||||
|  |  | ||||||
|           # Check if container is running |  | ||||||
|           docker ps | grep ping-river-monitor-test || echo "⚠️ Container not found in docker ps" |  | ||||||
|  |  | ||||||
|           # Check container logs for any startup issues |  | ||||||
|           echo "📋 Recent container logs:" |  | ||||||
|           docker logs --tail 10 ping-river-monitor-test || true |  | ||||||
|  |  | ||||||
|           # Wait for the application to be ready with more robust checking |  | ||||||
|           echo "🔍 Testing application readiness..." |  | ||||||
|           for i in {1..15}; do |  | ||||||
|             echo "⏳ Attempt $i/15: Testing health endpoint..." |  | ||||||
|              |  | ||||||
|             # Test health endpoint with detailed debugging |  | ||||||
|             echo "Testing health endpoint..." |  | ||||||
|              |  | ||||||
|             # First try with verbose output to see what's happening |  | ||||||
|             response=$(curl -s --max-time 10 --connect-timeout 5 -w "HTTP_CODE:%{http_code}" http://127.0.0.1:8080/health) |  | ||||||
|             http_code=$(echo "$response" | grep -o "HTTP_CODE:[0-9]*" | cut -d: -f2) |  | ||||||
|             response_body=$(echo "$response" | sed 's/HTTP_CODE:[0-9]*$//') |  | ||||||
|              |  | ||||||
|             echo "HTTP Code: $http_code" |  | ||||||
|             echo "Response Body: $response_body" |  | ||||||
|              |  | ||||||
|             if [ "$http_code" = "200" ] && [ -n "$response_body" ]; then |  | ||||||
|               echo "✅ Health endpoint responding successfully!" |  | ||||||
|               break |  | ||||||
|             else |  | ||||||
|               echo "❌ Health check failed (HTTP: $http_code), waiting 15 seconds..." |  | ||||||
|               # Show what's happening with the container |  | ||||||
|               echo "Container status:" |  | ||||||
|               docker ps | grep ping-river-monitor-test || echo "Container not found" |  | ||||||
|               echo "Recent container logs:" |  | ||||||
|               docker logs --tail 5 ping-river-monitor-test || true |  | ||||||
|               sleep 15 |  | ||||||
|             fi |  | ||||||
|           done |  | ||||||
|  |  | ||||||
|           # Test API endpoints with better error handling |  | ||||||
|           echo "🧪 Testing API endpoints..." |  | ||||||
|            |            | ||||||
|           endpoints=("health" "docs" "stations" "metrics") |           # Pull a curl-only image for probing (keeps your app image slim) | ||||||
|           for endpoint in "${endpoints[@]}"; do |           docker pull curlimages/curl:8.10.1 | ||||||
|             echo "Testing /$endpoint..." |            | ||||||
|             response=$(curl -s --max-time 10 -w "HTTP_CODE:%{http_code}" http://127.0.0.1:8080/$endpoint) |           # Helper: curl via a sibling container on the SAME Docker network | ||||||
|             http_code=$(echo "$response" | grep -o "HTTP_CODE:[0-9]*" | cut -d: -f2) |           probe() { | ||||||
|  |             local url="$1" | ||||||
|  |             docker run --rm --network ci_net curlimages/curl:8.10.1 \ | ||||||
|  |               -sS --max-time 5 --connect-timeout 3 -w "HTTP_CODE:%{http_code}" "$url" || true | ||||||
|  |           } | ||||||
|  |            | ||||||
|  |           # Wait for /health (up to ~3m 45s) | ||||||
|  |           for i in {1..15}; do | ||||||
|  |             echo "🔍 Attempt $i/15: checking http://ping-river-monitor-test:8000/health" | ||||||
|  |             resp="$(probe http://ping-river-monitor-test:8000/health)" | ||||||
|  |             code="$(echo "$resp" | sed -n 's/.*HTTP_CODE:\([0-9]\+\).*/\1/p')" | ||||||
|  |             body="$(echo "$resp" | sed 's/HTTP_CODE:[0-9]*$//')" | ||||||
|              |              | ||||||
|             if [ "$http_code" = "200" ]; then |             echo "HTTP: ${code:-<none>} | Body: ${body:-<empty>}" | ||||||
|               echo "✅ /$endpoint: OK (HTTP $http_code)" |              | ||||||
|             else |             if [ "${code:-}" = "200" ] && [ -n "${body:-}" ]; then | ||||||
|               echo "❌ /$endpoint: FAILED (HTTP $http_code)" |               echo "✅ Health endpoint responding successfully" | ||||||
|               echo "Response: $(echo "$response" | sed 's/HTTP_CODE:[0-9]*$//')" |               break | ||||||
|  |             fi | ||||||
|  |              | ||||||
|  |             echo "❌ Not ready yet. Showing recent logs…" | ||||||
|  |             docker logs --tail 20 ping-river-monitor-test || true | ||||||
|  |             sleep 15 | ||||||
|  |              | ||||||
|  |             if [ "$i" -eq 15 ]; then | ||||||
|  |               echo "❌ Health never reached 200. Failing." | ||||||
|               exit 1 |               exit 1 | ||||||
|             fi |             fi | ||||||
|           done |           done | ||||||
|  |            | ||||||
|  |           echo "🧪 Testing API endpoints…" | ||||||
|  |           endpoints=("health" "docs" "stations" "metrics") | ||||||
|  |           for ep in "${endpoints[@]}"; do | ||||||
|  |             url="http://ping-river-monitor-test:8000/$ep" | ||||||
|  |             resp="$(probe "$url")" | ||||||
|  |             code="$(echo "$resp" | sed -n 's/.*HTTP_CODE:\([0-9]\+\).*/\1/p')" | ||||||
|  |              | ||||||
|  |             if [ "${code:-}" = "200" ]; then | ||||||
|  |               echo "✅ /$ep: OK" | ||||||
|  |             else | ||||||
|  |               echo "❌ /$ep: FAILED (HTTP ${code:-<none>})" | ||||||
|  |               echo "Response: $(echo "$resp" | sed 's/HTTP_CODE:[0-9]*$//')" | ||||||
|  |               exit 1 | ||||||
|  |             fi | ||||||
|  |           done | ||||||
|  |            | ||||||
|           echo "✅ All health checks passed!" |           echo "✅ All health checks passed!" | ||||||
|  |  | ||||||
|  |       - name: (Fallback) Probe via host-published port | ||||||
|  |         if: always() | ||||||
|  |         run: | | ||||||
|  |           set -euo pipefail | ||||||
|  |           # In case you also want to verify the host-published port from inside the job container: | ||||||
|  |           HOST_GATEWAY="$(ip route | awk '/default/ {print $3}')" | ||||||
|  |           echo "🔎 Host gateway is $HOST_GATEWAY — probing http://$HOST_GATEWAY:8080/health" | ||||||
|  |           docker run --rm curlimages/curl:8.10.1 \ | ||||||
|  |             -sS --max-time 5 --connect-timeout 3 -w "HTTP_CODE:%{http_code}\n" \ | ||||||
|  |             "http://$HOST_GATEWAY:8080/health" || true | ||||||
|  |  | ||||||
|       - name: Container logs and cleanup |       - name: Container logs and cleanup | ||||||
|         if: always() |         if: always() | ||||||
|         run: | |         run: | | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user