]> granicus.if.org Git - llvm/commitdiff
llvm-symbolizer: Extract individual test cases now that it's easier to use directly...
authorDavid Blaikie <dblaikie@gmail.com>
Thu, 24 Jan 2019 01:19:17 +0000 (01:19 +0000)
committerDavid Blaikie <dblaikie@gmail.com>
Thu, 24 Jan 2019 01:19:17 +0000 (01:19 +0000)
Pulling out the split-dwarf tests by way of example of how I think
llvm-symbolizer should be tested going forward. Open to
debate/discussion, though.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@352004 91177308-0d34-0410-b5e6-96231b3b80d8

25 files changed:
test/DebugInfo/llvm-symbolizer.test
test/tools/llvm-symbolizer/Inputs/dwo-test [moved from test/DebugInfo/Inputs/llvm-symbolizer-dwo-test with 100% similarity]
test/tools/llvm-symbolizer/Inputs/fission-ranges.cc [moved from test/DebugInfo/Inputs/fission-ranges.cc with 100% similarity]
test/tools/llvm-symbolizer/Inputs/fission-ranges.elf-x86_64 [moved from test/DebugInfo/Inputs/fission-ranges.elf-x86_64 with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-addr-object-relocation.cpp [moved from test/DebugInfo/Inputs/split-dwarf-addr-object-relocation.cpp with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-addr-object-relocation.dwo [moved from test/DebugInfo/Inputs/split-dwarf-addr-object-relocation.dwo with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-addr-object-relocation.o [moved from test/DebugInfo/Inputs/split-dwarf-addr-object-relocation.o with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-dwp.cpp [moved from test/DebugInfo/Inputs/split-dwarf-dwp.cpp with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-dwp.o [moved from test/DebugInfo/Inputs/split-dwarf-dwp.o with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-dwp.o.dwp [moved from test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-multiple-cu.cpp [moved from test/DebugInfo/Inputs/split-dwarf-multiple-cu.cpp with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-multiple-cu.dwo [moved from test/DebugInfo/Inputs/split-dwarf-multiple-cu.dwo with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-multiple-cu.o [moved from test/DebugInfo/Inputs/split-dwarf-multiple-cu.o with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-test [moved from test/DebugInfo/Inputs/split-dwarf-test with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-test-nogmlt [moved from test/DebugInfo/Inputs/split-dwarf-test-nogmlt with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-test.cc [moved from test/DebugInfo/Inputs/split-dwarf-test.cc with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-test.cpp [moved from test/DebugInfo/Inputs/split-dwarf-test.cpp with 100% similarity]
test/tools/llvm-symbolizer/Inputs/split-dwarf-test.dwo [moved from test/DebugInfo/Inputs/split-dwarf-test.dwo with 100% similarity]
test/tools/llvm-symbolizer/dwo.test [new file with mode: 0644]
test/tools/llvm-symbolizer/fission-ranges.test [new file with mode: 0644]
test/tools/llvm-symbolizer/split-debug.test
test/tools/llvm-symbolizer/split-dwarf-addr-object-relocation.test [new file with mode: 0644]
test/tools/llvm-symbolizer/split-dwarf-dwp.test [new file with mode: 0644]
test/tools/llvm-symbolizer/split-dwarf-multiple-cu.test [new file with mode: 0644]
test/tools/llvm-symbolizer/split-dwarf.test [new file with mode: 0644]

index 33d83c45cf5c531ea8b1db839e48350b0b5e358f..4c8e7ec9f0c6fee5dcf4a837b30ceab9a48c96af 100644 (file)
@@ -19,46 +19,14 @@ RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x62d" >> %t.input
 RUN: echo "%p/Inputs/macho-universal 0x1f84" >> %t.input
 RUN: echo "%p/Inputs/macho-universal:i386 0x1f67" >> %t.input
 RUN: echo "%p/Inputs/macho-universal:x86_64 0x100000f05" >> %t.input
-RUN: echo "%p/Inputs/llvm-symbolizer-dwo-test 0x400514" >> %t.input
 RUN: echo "%p/Inputs/llvm-symbolizer-local-mem-func-gcc.elf-x86-64 0x61a" >> %t.input
-RUN: echo "%p/Inputs/fission-ranges.elf-x86_64 0x720" >> %t.input
 RUN: echo "%p/Inputs/arange-overlap.elf-x86_64 0x714" >> %t.input
-RUN: cp %p/Inputs/split-dwarf-test.dwo %t
-RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
-RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
 RUN: echo "%p/Inputs/cross-cu-inlining.x86_64-macho.o 0x17" >> %t.input
-RUN: cp %p/Inputs/split-dwarf-multiple-cu.dwo %t
-RUN: echo "%p/Inputs/split-dwarf-multiple-cu.o 0x4" >> %t.input
-RUN: cp %p/Inputs/split-dwarf-addr-object-relocation.dwo %t
-RUN: echo "%p/Inputs/split-dwarf-addr-object-relocation.o 0x14" >> %t.input
-RUN: cp %p/Inputs/split-dwarf-dwp.o %t
-RUN: cp %p/Inputs/split-dwarf-dwp.o.dwp %t
-RUN: echo "%t/split-dwarf-dwp.o 0x4" >> %t.input
 
 RUN: cd %t
 RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
 RUN:    --default-arch=i386 < %t.input | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s
 
-Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file
-
-RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x400504" >> %t.input
-RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4004f4" >> %t.input
-RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
-RUN:    --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s
-
-Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable
-
-RUN: rm %t/split-dwarf-test.dwo
-RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
-RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
-RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
-RUN:    --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s
-
-RUN: cp %p/Inputs/split-dwarf-dwp.o %t/split-dwarf-dwp-different-name.o
-RUN: echo "%t/split-dwarf-dwp-different-name.o 0x54" > %t.input
-RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
-RUN:    --default-arch=i386 --dwp=%p/Inputs/split-dwarf-dwp.o.dwp < %t.input | FileCheck --check-prefix=DWP %s
-
 CHECK:       main
 CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
 
@@ -125,28 +93,13 @@ CHECK:      main
 CHECK:      _Z3inci
 CHECK:      _Z3inci
 
-CHECK: main
-CHECK-NEXT: llvm-symbolizer-dwo-test.cc:11
-
 CHECK-NOT: local_mem_func
 CHECK: _ZZ2f1vEN3foo14local_mem_funcEv
 CHECK-NEXT: {{.*}}local-mem-func.cpp:3:0
 
-CHECK: main
-CHECK-NEXT: {{.*}}fission-ranges.cc:6
-
 CHECK: _ZN1S3bazEv
 CHECK-NEXT: {{.*}}arange-overlap.cc:6
 
-DWO: _Z2f2v
-NODWO: {{^f2$}}
-SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
-SPLIT-NEXT: main
-SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
-
-SPLIT: _Z2f1v
-SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
-
 ; func has been inlined into main by LTO. Check that the symbolizer is able
 ; to resolve the cross-cu reference and retrieve func's name
 CHECK: func
@@ -154,21 +107,6 @@ CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:16:3
 CHECK-NEXT: main
 CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:11:0
 
-CHECK:      f2
-CHECK-NEXT: split-dwarf-multiple-cu.cpp:3:3
-CHECK-NEXT: f3
-CHECK-NEXT: split-dwarf-multiple-cu.cpp:6:0
-
-CHECK:      f2
-CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:3:3
-CHECK-NEXT: f3
-CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0
-
-DWP:      f2
-DWP-NEXT: split-dwarf-dwp.cpp:3:3
-DWP-NEXT: main
-DWP-NEXT: split-dwarf-dwp.cpp:10:0
-
 RUN: echo "unexisting-file 0x1234" > %t.input2
 RUN: llvm-symbolizer < %t.input2 2>&1 | FileCheck %s --check-prefix=MISSING-FILE
 
diff --git a/test/tools/llvm-symbolizer/dwo.test b/test/tools/llvm-symbolizer/dwo.test
new file mode 100644 (file)
index 0000000..c2c72f5
--- /dev/null
@@ -0,0 +1,4 @@
+RUN: llvm-symbolizer --obj=%p/Inputs/dwo-test 0x400514 | FileCheck %s
+
+CHECK: main
+CHECK-NEXT: llvm-symbolizer-dwo-test.cc:11
diff --git a/test/tools/llvm-symbolizer/fission-ranges.test b/test/tools/llvm-symbolizer/fission-ranges.test
new file mode 100644 (file)
index 0000000..4d35ed4
--- /dev/null
@@ -0,0 +1,4 @@
+RUN: llvm-symbolizer --obj=%p/Inputs/fission-ranges.elf-x86_64 0x720 | FileCheck %s
+
+CHECK: main
+CHECK-NEXT: {{.*}}fission-ranges.cc:6
index 7474cd6e6f248cd7731e91df7f9b027127417406..8904683228df66acfc20ebc395b867c2a94a808a 100644 (file)
@@ -20,7 +20,7 @@
 RUN: mkdir -p %t/.debug
 RUN: llvm-objcopy --keep-section=.debug_info %p/Inputs/addr.exe %t/.debug/addr
 RUN: llvm-objcopy --strip-debug --add-gnu-debuglink=%t/.debug/addr %p/Inputs/addr.exe %t/addr.exe
-RUN: llvm-symbolizer -print-address -obj=%t/addr.exe < %p/Inputs/addr.inp | FileCheck %s
+RUN: llvm-symbolizer -print-address -obj=%t/addr.exe 0x40054d | FileCheck %s
 
 #CHECK: 0x40054d
 #CHECK: {{[/\]+}}tmp{{[/\]+}}x.c:14:0
diff --git a/test/tools/llvm-symbolizer/split-dwarf-addr-object-relocation.test b/test/tools/llvm-symbolizer/split-dwarf-addr-object-relocation.test
new file mode 100644 (file)
index 0000000..d98756d
--- /dev/null
@@ -0,0 +1,11 @@
+RUN: rm -rf %t
+RUN: mkdir -p %t
+RUN: cp %p/Inputs/split-dwarf-addr-object-relocation.dwo %t
+
+RUN: cd %t
+RUN: llvm-symbolizer --obj=%p/Inputs/split-dwarf-addr-object-relocation.o 0x14 | FileCheck %s
+
+CHECK:      f2
+CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:3:3
+CHECK-NEXT: f3
+CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0
diff --git a/test/tools/llvm-symbolizer/split-dwarf-dwp.test b/test/tools/llvm-symbolizer/split-dwarf-dwp.test
new file mode 100644 (file)
index 0000000..71ecca4
--- /dev/null
@@ -0,0 +1,12 @@
+RUN: rm -rf %t
+RUN: mkdir -p %t
+
+RUN: cp %p/Inputs/split-dwarf-dwp.o %t/split-dwarf-dwp-different-name.o
+
+RUN: llvm-symbolizer --dwp=%p/Inputs/split-dwarf-dwp.o.dwp \
+RUN:     --obj=%t/split-dwarf-dwp-different-name.o 0x54 | FileCheck %s
+
+CHECK:      f2
+CHECK-NEXT: split-dwarf-dwp.cpp:3:3
+CHECK-NEXT: main
+CHECK-NEXT: split-dwarf-dwp.cpp:10:0
diff --git a/test/tools/llvm-symbolizer/split-dwarf-multiple-cu.test b/test/tools/llvm-symbolizer/split-dwarf-multiple-cu.test
new file mode 100644 (file)
index 0000000..465816f
--- /dev/null
@@ -0,0 +1,12 @@
+RUN: rm -rf %t
+RUN: mkdir -p %t
+RUN: cp %p/Inputs/split-dwarf-multiple-cu.dwo %t
+
+RUN: cd %t
+RUN: llvm-symbolizer --obj=%p/Inputs/split-dwarf-multiple-cu.o 0x4 | FileCheck %s
+
+CHECK:      f2
+CHECK-NEXT: split-dwarf-multiple-cu.cpp:3:3
+CHECK-NEXT: f3
+CHECK-NEXT: split-dwarf-multiple-cu.cpp:6:0
+
diff --git a/test/tools/llvm-symbolizer/split-dwarf.test b/test/tools/llvm-symbolizer/split-dwarf.test
new file mode 100644 (file)
index 0000000..e8185ce
--- /dev/null
@@ -0,0 +1,32 @@
+RUN: rm -rf %t
+RUN: mkdir -p %t
+
+RUN: cp %p/Inputs/split-dwarf-test.dwo %t
+
+RUN: cd %t
+RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
+RUN:    --obj=%p/Inputs/split-dwarf-test 0x400504 0x4004f4 | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s
+
+Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file
+
+RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x400504" >> %t.input
+RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4004f4" >> %t.input
+RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
+RUN:    --default-arch=i386 --obj=%p/Inputs/split-dwarf-test-nogmlt 0x400504 0x4004f4 | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s
+
+Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable
+
+RUN: rm %t/split-dwarf-test.dwo
+RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
+RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
+RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
+RUN:    --default-arch=i386 --obj=%p/Inputs/split-dwarf-test 0x400504 0x4004f4 | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s
+
+DWO: _Z2f2v
+NODWO: {{^f2$}}
+SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
+SPLIT-NEXT: main
+SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
+
+SPLIT: _Z2f1v
+SPLIT-NEXT: {{.*}}split-dwarf-test.cpp