-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathpy_cli_test.sh
More file actions
executable file
·78 lines (62 loc) · 2.47 KB
/
py_cli_test.sh
File metadata and controls
executable file
·78 lines (62 loc) · 2.47 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
#!/usr/bin/env bash
# py_cli_test.sh — Test Python CLI for sql5
set -uo pipefail
PROJECT_DIR="$(cd "$(dirname "$0")" && pwd)"
BINARY="$PROJECT_DIR/target/release/sql5"
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[0;33m'
BLUE='\033[0;34m'
RESET='\033[0m'
echo ""
echo "=============================================="
echo -e "${BLUE}Python CLI Tests${RESET}"
echo "=============================================="
echo ""
if [[ ! -x "$BINARY" ]]; then
echo -e "${RED}ERROR: Binary not found. Building...${RESET}"
cd "$PROJECT_DIR" && cargo build --release
fi
export SQL5_BINARY="$BINARY"
TESTS_PASSED=0
TESTS_FAILED=0
run_test() {
local name="$1"
local expected="$2"
local cmd="$3"
echo -n " $name ... "
local result
result=$(eval "$cmd" 2>&1)
if echo "$result" | grep -q "$expected"; then
echo -e "${GREEN}PASS${RESET}"
((TESTS_PASSED++))
else
echo -e "${RED}FAIL${RESET}"
echo " Expected: $expected"
echo " Got: $result"
((TESTS_FAILED++))
fi
}
cd "$PROJECT_DIR"
echo -e "${BLUE}[Basic Tests]${RESET}"
run_test "SELECT 1" "Connected to memory" 'uv run python -m sql5 -c "SELECT 1" 2>&1 | head -1'
run_test "SELECT 1 result" "1$" 'uv run python -m sql5 -c "SELECT 1 AS result" 2>&1 | tail -1'
run_test "Multiple columns" "1 | 2 | 3" 'uv run python -m sql5 -c "SELECT 1, 2, 3" 2>&1 | tail -1'
echo ""
echo -e "${BLUE}[Table Tests]${RESET}"
run_test "CREATE TABLE" "table created" 'uv run python -m sql5 -c "CREATE TABLE users(id INTEGER, name TEXT)" 2>&1 | tail -1'
run_test ".tables" "users" "uv run python -m sql5 -c 'CREATE TABLE users(id INTEGER); .tables' 2>&1 | tail -1'
run_test ".schema" "users" "uv run python -m sql5 -c 'CREATE TABLE users(id INTEGER); .schema users' 2>&1 | tail -1'
echo ""
echo -e "${BLUE}[INSERT/SELECT Tests]${RESET}"
run_test "INSERT" "1 row(s) inserted" 'uv run python -m sql5 -c "CREATE TABLE u(id INTEGER); INSERT INTO u VALUES(1)" 2>&1 | tail -1'
run_test "SELECT *" "1$" 'uv run python -m sql5 -c "CREATE TABLE u(id INTEGER); INSERT INTO u VALUES(1); SELECT * FROM u" 2>&1 | tail -1'
run_test "SELECT id FROM u" "affected" 'uv run python -m sql5 -c "CREATE TABLE u(id INTEGER); SELECT id FROM u" 2>&1 | tail -1'
echo ""
echo "=============================================="
echo -e "Results: ${GREEN}$TESTS_PASSED passed${RESET}, ${RED}$TESTS_FAILED failed${RESET}"
echo "=============================================="
if [[ $TESTS_FAILED -gt 0 ]]; then
exit 1
fi
exit 0