aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/test_include_errors.sh
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-09-03 19:03:48 +0900
committernsfisis <nsfisis@gmail.com>2025-09-10 23:51:52 +0900
commit9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487 (patch)
tree5fc0c3e0c3cd7159119d0560b5061b3545216f35 /tests/test_include_errors.sh
parentb447618c33683b947c1fb26f1e7cd9033e20e5cb (diff)
downloadducc-9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487.tar.gz
ducc-9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487.tar.zst
ducc-9a2fbf6f4854b1f2cfd5979b91d5b3d7e183d487.zip
test: merge test scripts
Diffstat (limited to 'tests/test_include_errors.sh')
-rw-r--r--tests/test_include_errors.sh52
1 files changed, 52 insertions, 0 deletions
diff --git a/tests/test_include_errors.sh b/tests/test_include_errors.sh
new file mode 100644
index 0000000..3ac546f
--- /dev/null
+++ b/tests/test_include_errors.sh
@@ -0,0 +1,52 @@
+cat <<'EOF' > expected
+main.c:1: cannot open include file: "nonexistent.h"
+EOF
+
+test_compile_error <<'EOF'
+#include "nonexistent.h"
+
+int main() {
+ return 0;
+}
+EOF
+
+cat <<'EOF' > expected
+include depth limit exceeded
+EOF
+
+# Create circular include files
+cat <<'EOF' > a.h
+#include "b.h"
+int a() { return 1; }
+EOF
+
+cat <<'EOF' > b.h
+#include "a.h"
+int b() { return 2; }
+EOF
+
+test_compile_error <<'EOF'
+#include "a.h"
+
+int main() {
+ a() + b();
+ return 0;
+}
+EOF
+
+cat <<'EOF' > expected
+main.c:1: cannot open include file: "hoge.h"
+EOF
+
+test_compile_error <<'EOF'
+#include "hoge.h"
+EOF
+
+cat <<'EOF' > expected
+main.c:1: cannot resolve include file name: <hoge.h>
+EOF
+
+test_compile_error <<'EOF'
+#include <hoge.h>
+EOF
+