File: check.sh

package info (click to toggle)
hugo 0.155.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 43,600 kB
  • sloc: javascript: 31,879; ansic: 2,350; xml: 350; makefile: 196; sh: 110
file content (82 lines) | stat: -rwxr-xr-x 1,835 bytes parent folder | download
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
#!/bin/bash

set -e

# Default to all packages if none specified
PACKAGES="${1:-./...}"

echo "==> Checking packages: $PACKAGES"

# Timing arrays
declare -a STEP_NAMES
declare -a STEP_TIMES

time_step() {
    local name="$1"
    shift
    local start=$(date +%s.%N)
    "$@"
    local end=$(date +%s.%N)
    local elapsed=$(echo "$end - $start" | bc)
    STEP_NAMES+=("$name")
    STEP_TIMES+=("$elapsed")
}

# Check gofmt
run_gofmt() {
    echo "==> Running gofmt..."
    # Convert package pattern to path (e.g., ./hugolib/... -> ./hugolib)
    local path="${PACKAGES%/...}"
    GOFMT_OUTPUT=$(gofmt -l "$path" 2>&1) || true
    if [ -n "$GOFMT_OUTPUT" ]; then
        echo "gofmt found issues in:"
        echo "$GOFMT_OUTPUT"
        exit 1
    fi
    echo "    OK"
}

# Run staticcheck
run_staticcheck() {
    # Check if staticcheck is installed, install if not
    if ! command -v staticcheck &> /dev/null; then
        echo "==> Installing staticcheck..."
        go install honnef.co/go/tools/cmd/staticcheck@latest
    fi
    echo "==> Running staticcheck..."
    staticcheck $PACKAGES
    echo "    OK"
}

# Run tests
run_tests() {
    echo "==> Running tests..."
    local output
    if ! output=$(go test $PACKAGES 2>&1); then
        echo "$output"
        exit 1
    fi
    echo "    OK"
}

# Run all steps with timing
TOTAL_START=$(date +%s.%N)

time_step "gofmt" run_gofmt
time_step "staticcheck" run_staticcheck
time_step "tests" run_tests

TOTAL_END=$(date +%s.%N)
TOTAL_ELAPSED=$(echo "$TOTAL_END - $TOTAL_START" | bc)

# Print timing summary
echo ""
echo "==> All checks passed!"
echo ""
echo "Timing summary:"
echo "---------------"
for i in "${!STEP_NAMES[@]}"; do
    printf "  %-15s %6.2fs\n" "${STEP_NAMES[$i]}" "${STEP_TIMES[$i]}"
done
echo "---------------"
printf "  %-15s %6.2fs\n" "Total" "$TOTAL_ELAPSED"