aboutsummaryrefslogtreecommitdiff
path: root/tests/lib.sh
blob: 07ecbef76145305e2a43ad370fce5113bd3c8b89 (plain) (blame)
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
#!/bin/sh

end="\033[0m"
red="\033[0;31m"
green="\033[0;32m"
yellow="\033[0;33m"

N=
OUT=
ERR=
STATUS=

ERROR() {
	# shellcheck disable=2059
	printf "${red}ERROR${end}"
}

print_debug_info() {
	# shellcheck disable=2016
	printf 'LINENO:   %s\n$OUT:      %s\n$ERR:      %s\n' \
		"$N" "$OUT" "$ERR" >&2
}

assert_status() {
	if [ "$STATUS" != "$1" ]; then
		printf '\n%s: Bad status.\n\nexpected: %s\ngot:      %s\n' \
			"$(ERROR)" "$1" "$STATUS" >&2
		print_debug_info
		exit 1
	fi
}

assert_usage() {
	if ! grep -Fq 'Usage' "$1"; then
		echo 'Expected to find "Usage" text, it was missing:' >&2
		cat "$1" >&2
		print_debug_info
		exit 1
	fi
}

assert_empty_stream() {
	if [ -s "$2" ]; then
		FMT='\n%s: Expected %s (%s) to be empty, but has content:\n%s\n'
		# shellcheck disable=2059
		printf "$FMT" \
			"$(ERROR)" "$1" "$2" "$(cat "$2")" >&2
		print_debug_info
		exit 1
	fi
}

assert_empty_stdout() {
	assert_empty_stream STDOUT "$OUT"
}

assert_empty_stderr() {
	assert_empty_stream STDERR "$ERR"
}

assert_stream() {
	if [ "$(cat "$2")" != "$3" ]; then
		printf '\n%s: Bad %s (%s)\n\nexpected: %s\ngot:      %s\n' \
			"$(ERROR)" "$1" "$2" "$3" "$(cat "$2")" >&2
		print_debug_info
		exit 1
	fi
}

assert_stdout() {
	assert_stream STDOUT "$OUT" "$1"
}

assert_stderr() {
	assert_stream STDERR "$ERR" "$1"
}

assert_grep_stream() {
	if ! grep -qE "$3" "$2"; then
		printf '\n%s: Bad %s (%s)\n\ngrepping: %s\nin:\n%s\n' \
			"$(ERROR)" "$1" "$2" "$3"  "$(cat "$2")" >&2
		print_debug_info
		exit 1
	fi
}

assert_grep_stdout() {
	assert_grep_stream STDOUT "$OUT" "$1"
}

assert_grep_stderr() {
	assert_grep_stream STDERR "$ERR" "$1"
}

assert_fgrep_stream() {
	if ! grep -Fq -- "$3" "$2"; then
		printf '\n%s: Bad %s (%s)\n\ngrepping: %s\nin:\n%s\n' \
			"$(ERROR)" "$1" "$2" "$3"  "$(cat "$2")" >&2
		print_debug_info
		exit 1
	fi
}

assert_fgrep_stdout() {
	assert_fgrep_stream STDOUT "$OUT" "$1"
}

assert_fgrep_stderr() {
	assert_fgrep_stream STDERR "$ERR" "$1"
}

testing() {
	printf "${yellow}testing${end}: %s..." "$1" >&2
}

test_ok() {
	# shellcheck disable=2059
	printf " ${green}OK${end}.\n" >&2
}