-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcopilot-regressiontest.sh
More file actions
executable file
Β·123 lines (106 loc) Β· 4.81 KB
/
copilot-regressiontest.sh
File metadata and controls
executable file
Β·123 lines (106 loc) Β· 4.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#!/bin/bash
# Load central configuration
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
source "${SCRIPT_DIR}/config.sh"
# ββ Config ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
PROJECT_DIR="${PROJECT_DIR:-/opt/yourproject}"
LOG_FILE="${LOG_FILE:-/opt/copilot-hive/copilot-regressiontest.log}"
NOTIFY="/opt/copilot-hive/notify-smartthings.sh"
CHANGELOG_DIR="${CHANGELOG_DIR:-/opt/copilot-hive/changelogs}"
API_BASE="${HEALTH_URL:-http://localhost:8080}"
WEB_BASE="${HEALTH_URL:-http://localhost:8080}"
# ββ Run βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
echo "======================================" >> "$LOG_FILE"
echo "Regression Test Started: $(date)" >> "$LOG_FILE"
RESULTS_FILE=$(mktemp)
trap "rm -f '$RESULTS_FILE'" EXIT
check() {
local name="$1" url="$2" expected="${3:-200}"
local code
code=$(curl -sf -o /dev/null -w "%{http_code}" --max-time 15 "$url" 2>/dev/null || echo "000")
if [ "$code" = "$expected" ]; then
echo "PASS|$name|$code|$expected" >> "$RESULTS_FILE"
else
echo "FAIL|$name|$code|$expected" >> "$RESULTS_FILE"
fi
}
check_json() {
local name="$1" url="$2"
local response code
response=$(curl -sf --max-time 15 "$url" 2>/dev/null)
if echo "$response" | python3 -c "import sys,json; json.load(sys.stdin)" 2>/dev/null; then
echo "PASS|$name|valid JSON|200" >> "$RESULTS_FILE"
else
code=$(curl -sf -o /dev/null -w "%{http_code}" --max-time 15 "$url" 2>/dev/null || echo "000")
echo "FAIL|$name|$code (invalid JSON)|200" >> "$RESULTS_FILE"
fi
}
# Run HTTP checks in parallel
echo "" >> "$LOG_FILE"
echo "ββ Core Health Tests ββ" >> "$LOG_FILE"
check "Homepage" "$WEB_BASE/" &
# Test common pages β these will gracefully PASS or FAIL based on what exists
for page in dashboard portal admin login about pricing services contact blog; do
check "$page" "$WEB_BASE/$page" &
done
# Test API endpoints if they exist
echo "" >> "$LOG_FILE"
echo "ββ API Endpoint Tests ββ" >> "$LOG_FILE"
check "API Root" "$API_BASE/api/" &
check "API Health" "$API_BASE/api/health" &
wait
# Collect parallel check results
TOTAL=0; PASSED=0; FAILED=0; FAILURES=""
while IFS='|' read -r result name status expected; do
TOTAL=$((TOTAL + 1))
if [ "$result" = "PASS" ]; then
PASSED=$((PASSED + 1))
echo " PASS $name ($status)" >> "$LOG_FILE"
else
FAILED=$((FAILED + 1))
echo " FAIL $name (got $status, expected $expected)" >> "$LOG_FILE"
FAILURES="${FAILURES}\n - ${name}: got ${status}, expected ${expected}"
fi
done < "$RESULTS_FILE"
echo "" >> "$LOG_FILE"
echo "ββ Container Health ββ" >> "$LOG_FILE"
for container in ${CONTAINER_API:-yourproject-api} ${CONTAINER_WEB:-yourproject-web} ${CONTAINER_DB:-yourproject-db}; do
TOTAL=$((TOTAL + 1))
STATE=$(docker inspect -f '{{.State.Status}}' "$container" 2>/dev/null || echo "missing")
HEALTH=$(docker inspect -f '{{.State.Health.Status}}' "$container" 2>/dev/null || echo "none")
if [ "$STATE" = "running" ]; then
PASSED=$((PASSED + 1))
echo " PASS Container $container ($STATE, health: $HEALTH)" >> "$LOG_FILE"
else
FAILED=$((FAILED + 1))
echo " FAIL Container $container ($STATE, health: $HEALTH)" >> "$LOG_FILE"
FAILURES="${FAILURES}\n - Container ${container}: ${STATE} (health: ${HEALTH})"
fi
done
# ββ Results βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
echo "" >> "$LOG_FILE"
echo "Results: $PASSED/$TOTAL passed, $FAILED failed" >> "$LOG_FILE"
if [ $FAILED -gt 0 ]; then
"$NOTIFY" "REGRESSION: $FAILED/$TOTAL tests failed at $(date '+%H:%M')" >> "$LOG_FILE" 2>&1
fi
# ββ Changelog βββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
mkdir -p "$CHANGELOG_DIR"
TIMESTAMP=$(date '+%Y-%m-%d_%H%M')
CHANGELOG_FILE="${CHANGELOG_DIR}/regression_${TIMESTAMP}.txt"
{
echo "============================================"
echo " REGRESSION TEST RUN β $(date)"
echo " Results: $PASSED/$TOTAL passed, $FAILED failed"
echo "============================================"
if [ $FAILED -gt 0 ]; then
echo ""
echo "FAILURES:"
echo -e "$FAILURES"
fi
echo ""
echo "Current containers:"
docker ps --format " {{.Names}}\t{{.Status}}" 2>/dev/null | head -20
} > "$CHANGELOG_FILE"
echo "Changelog saved: $CHANGELOG_FILE" >> "$LOG_FILE"
echo "Regression Test Finished: $(date)" >> "$LOG_FILE"
exit $FAILED