diff options
| author | nsfisis <nsfisis@gmail.com> | 2025-09-03 19:03:48 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2025-09-10 23:51:52 +0900 |
| commit | 9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487 (patch) | |
| tree | 5fc0c3e0c3cd7159119d0560b5061b3545216f35 /tests/helpers.sh | |
| parent | b447618c33683b947c1fb26f1e7cd9033e20e5cb (diff) | |
| download | ducc-9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487.tar.gz ducc-9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487.tar.zst ducc-9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487.zip | |
test: merge test scripts
Diffstat (limited to 'tests/helpers.sh')
| -rw-r--r-- | tests/helpers.sh | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/tests/helpers.sh b/tests/helpers.sh new file mode 100644 index 0000000..eaccd5c --- /dev/null +++ b/tests/helpers.sh @@ -0,0 +1,68 @@ +function test_exit_code() { + cat > main.c + + "$ducc" -o a.out main.c + set +e + ./a.out + exit_code=$? + set -e + + expected=$1 + + if [[ $exit_code -ne $expected ]]; then + echo "invalid exit code: expected $expected, but got $exit_code" >&2 + exit 1 + fi +} + +function test_diff() { + cat > main.c + + "$ducc" -o a.out main.c + if [[ ! -f input ]]; then + touch input + fi + ./a.out "$@" < input > output + exit_code=$? + + if [[ $exit_code -ne 0 ]]; then + echo "invalid exit code: $exit_code" >&2 + exit 1 + fi + + diff -u expected output +} + +function test_compile_error() { + cat > main.c + + set +e + "$ducc" main.c > /dev/null 2> output + exit_code=$? + set -e + + if [[ $exit_code -eq 0 ]]; then + echo "expected to fail" >&2 + exit 1 + fi + + diff -u expected output +} + +function test_example() { + filename="../../../examples/$1.c" + + "$ducc" -o a.out "$filename" + if [[ ! -f input ]]; then + touch input + fi + ./a.out "$@" < input > output + exit_code=$? + + if [[ $exit_code -ne 0 ]]; then + echo "invalid exit code: $exit_code" >&2 + exit 1 + fi + + diff -u expected output +} |
