aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-05-11 20:45:57 +0900
committernsfisis <nsfisis@gmail.com>2025-05-11 20:45:57 +0900
commit8057c2e8a3fc03f7771c5d09db0a2b3568dc57d2 (patch)
tree7ce89023494294f0e29da81092755b1a3b7bafe6 /tests
parent6529e5a11e6d1c6f2a3fc3c08d77d22aaeccfef6 (diff)
downloadducc-8057c2e8a3fc03f7771c5d09db0a2b3568dc57d2.tar.gz
ducc-8057c2e8a3fc03f7771c5d09db0a2b3568dc57d2.tar.zst
ducc-8057c2e8a3fc03f7771c5d09db0a2b3568dc57d2.zip
take source file name as cli arguments
Diffstat (limited to 'tests')
-rw-r--r--tests/050.sh29
-rw-r--r--tests/test_diff.sh2
-rw-r--r--tests/test_exit_code.sh2
-rw-r--r--tests/test_output.sh2
4 files changed, 32 insertions, 3 deletions
diff --git a/tests/050.sh b/tests/050.sh
new file mode 100644
index 0000000..295ac2d
--- /dev/null
+++ b/tests/050.sh
@@ -0,0 +1,29 @@
+set -e
+
+cat <<'EOF' > expected
+hello, world
+EOF
+
+cat <<'EOF' > main.c
+int printf();
+int main() {
+ printf("hello, world\n");
+ return 0;
+}
+EOF
+
+"$ducc" - < main.c > main.s
+if [[ $? -ne 0 ]]; then
+ cat main.s >&2
+ exit 1
+fi
+gcc -Wl,-z,noexecstack -o a.out main.s
+./a.out "$@" > output
+exit_code=$?
+
+if [[ $exit_code -ne 0 ]]; then
+ echo "invalid exit code: $exit_code" >&2
+ exit 1
+fi
+
+diff -u expected output
diff --git a/tests/test_diff.sh b/tests/test_diff.sh
index 8e938de..6520b42 100644
--- a/tests/test_diff.sh
+++ b/tests/test_diff.sh
@@ -1,6 +1,6 @@
cat > main.c
-"$ducc" < main.c > main.s
+"$ducc" main.c > main.s
if [[ $? -ne 0 ]]; then
cat main.s >&2
exit 1
diff --git a/tests/test_exit_code.sh b/tests/test_exit_code.sh
index 490de5b..44d1e06 100644
--- a/tests/test_exit_code.sh
+++ b/tests/test_exit_code.sh
@@ -1,6 +1,6 @@
cat > main.c
-"$ducc" < main.c > main.s
+"$ducc" main.c > main.s
if [[ $? -ne 0 ]]; then
cat main.s >&2
exit 1
diff --git a/tests/test_output.sh b/tests/test_output.sh
index 2f8b984..575e399 100644
--- a/tests/test_output.sh
+++ b/tests/test_output.sh
@@ -1,6 +1,6 @@
cat > main.c
-"$ducc" < main.c > main.s
+"$ducc" main.c > main.s
if [[ $? -ne 0 ]]; then
cat main.s >&2
exit 1