|
| 1 | +#!/bin/bash |
| 2 | +cd /var/home/edward/projects/Canopy/build_coroutine_debug |
| 3 | + |
| 4 | +# Enable leak detection with suppressions, suppress protobuf container-overflow |
| 5 | +export ASAN_OPTIONS="detect_leaks=1:detect_container_overflow=0" |
| 6 | +export LSAN_OPTIONS="suppressions=../tests/lsan.supp:print_suppressions=0" |
| 7 | + |
| 8 | +# Get all test names properly |
| 9 | +CURRENT_SUITE="" |
| 10 | +declare -a TEST_ARRAY |
| 11 | + |
| 12 | +echo "Collecting test list..." |
| 13 | +while IFS= read -r line; do |
| 14 | + # Check if it's a test suite line (e.g., "type_test/0. # TypeParam...") |
| 15 | + if [[ $line =~ ^([A-Za-z0-9_]+)/([0-9]+)\. ]]; then |
| 16 | + CURRENT_SUITE="${BASH_REMATCH[1]}/${BASH_REMATCH[2]}" |
| 17 | + # Check if it's a test case (starts with spaces) |
| 18 | + elif [[ $line =~ ^[[:space:]]+([A-Za-z0-9_]+)$ ]]; then |
| 19 | + TEST_NAME="${BASH_REMATCH[1]}" |
| 20 | + if [ -n "$CURRENT_SUITE" ]; then |
| 21 | + TEST_ARRAY+=("${CURRENT_SUITE}.${TEST_NAME}") |
| 22 | + fi |
| 23 | + fi |
| 24 | +done < <(./output/rpc_test --gtest_list_tests 2>&1) |
| 25 | + |
| 26 | +TOTAL_COUNT=${#TEST_ARRAY[@]} |
| 27 | +PASSED_COUNT=0 |
| 28 | +FAILED_COUNT=0 |
| 29 | +LEAK_COUNT=0 |
| 30 | +FAILED_TESTS=() |
| 31 | +LEAK_TESTS=() |
| 32 | + |
| 33 | +echo "==========================================" |
| 34 | +echo "Running AddressSanitizer Tests with Leak Detection (Coroutine)" |
| 35 | +echo "Total tests to run: $TOTAL_COUNT" |
| 36 | +echo "==========================================" |
| 37 | +echo "" |
| 38 | + |
| 39 | +for i in "${!TEST_ARRAY[@]}"; do |
| 40 | + FULL_TEST="${TEST_ARRAY[$i]}" |
| 41 | + TEST_NUM=$((i + 1)) |
| 42 | + |
| 43 | + echo -n "[$TEST_NUM/$TOTAL_COUNT] Running: $FULL_TEST ... " |
| 44 | + |
| 45 | + # Run the test and capture output |
| 46 | + if timeout 30 ./output/rpc_test --gtest_filter="$FULL_TEST" > /tmp/test_output_coro_leak.log 2>&1; then |
| 47 | + # Check for memory leaks |
| 48 | + if grep -q "ERROR: LeakSanitizer: detected memory leaks" /tmp/test_output_coro_leak.log; then |
| 49 | + echo "MEMORY LEAK" |
| 50 | + LEAK_TESTS+=("$FULL_TEST") |
| 51 | + LEAK_COUNT=$((LEAK_COUNT + 1)) |
| 52 | + cp /tmp/test_output_coro_leak.log "/tmp/leak_coro_${FULL_TEST//\//_}.log" |
| 53 | + # Check if AddressSanitizer found any other errors (excluding container-overflow) |
| 54 | + elif grep -q "AddressSanitizer.*ERROR" /tmp/test_output_coro_leak.log | grep -v "container-overflow"; then |
| 55 | + echo "ASAN ERROR" |
| 56 | + FAILED_TESTS+=("$FULL_TEST") |
| 57 | + FAILED_COUNT=$((FAILED_COUNT + 1)) |
| 58 | + cp /tmp/test_output_coro_leak.log "/tmp/asan_coro_leak_error_${FULL_TEST//\//_}.log" |
| 59 | + else |
| 60 | + echo "PASSED" |
| 61 | + PASSED_COUNT=$((PASSED_COUNT + 1)) |
| 62 | + fi |
| 63 | + else |
| 64 | + echo "FAILED/TIMEOUT" |
| 65 | + FAILED_TESTS+=("$FULL_TEST") |
| 66 | + FAILED_COUNT=$((FAILED_COUNT + 1)) |
| 67 | + cp /tmp/test_output_coro_leak.log "/tmp/asan_coro_leak_error_${FULL_TEST//\//_}.log" |
| 68 | + fi |
| 69 | +done |
| 70 | + |
| 71 | +echo "" |
| 72 | +echo "==========================================" |
| 73 | +echo "Summary (Coroutine - Leak Detection Enabled)" |
| 74 | +echo "==========================================" |
| 75 | +echo "Total tests: $TOTAL_COUNT" |
| 76 | +echo "Passed: $PASSED_COUNT" |
| 77 | +echo "Failed (ASan errors): $FAILED_COUNT" |
| 78 | +echo "Memory leaks detected: $LEAK_COUNT" |
| 79 | +echo "" |
| 80 | + |
| 81 | +if [ ${#FAILED_TESTS[@]} -gt 0 ]; then |
| 82 | + echo "Failed tests (ASan errors):" |
| 83 | + for test in "${FAILED_TESTS[@]}"; do |
| 84 | + echo " - $test" |
| 85 | + echo " Log: /tmp/asan_coro_leak_error_${test//\//_}.log" |
| 86 | + done |
| 87 | + echo "" |
| 88 | +fi |
| 89 | + |
| 90 | +if [ ${#LEAK_TESTS[@]} -gt 0 ]; then |
| 91 | + echo "Tests with memory leaks:" |
| 92 | + for test in "${LEAK_TESTS[@]}"; do |
| 93 | + echo " - $test" |
| 94 | + echo " Log: /tmp/leak_coro_${test//\//_}.log" |
| 95 | + done |
| 96 | +fi |
0 commit comments