Add coverage tests (defaulted constructors/destructor)
authorXinliang David Li <davidxl@google.com>
Sun, 7 Feb 2016 16:31:13 +0000 (16:31 +0000)
committerXinliang David Li <davidxl@google.com>
Sun, 7 Feb 2016 16:31:13 +0000 (16:31 +0000)
llvm-svn: 260041

compiler-rt/test/profile/Linux/coverage_ctors.cpp [new file with mode: 0644]
compiler-rt/test/profile/Linux/coverage_dtor.cpp [new file with mode: 0644]

diff --git a/compiler-rt/test/profile/Linux/coverage_ctors.cpp b/compiler-rt/test/profile/Linux/coverage_ctors.cpp
new file mode 100644 (file)
index 0000000..336cf14
--- /dev/null
@@ -0,0 +1,33 @@
+// RUN: %clang_profgen -x c++  -std=c++11 -fuse-ld=gold -fcoverage-mapping -o %t %s
+// RUN: env LLVM_PROFILE_FILE=%t.profraw %run %t
+// RUN: llvm-profdata merge -o %t.profdata %t.profraw
+// RUN: llvm-cov show %t -instr-profile %t.profdata -filename-equivalence 2>&1 | FileCheck %s
+
+struct Base {
+  int B;
+  Base() : B(2) {}
+  Base(const struct Base &b2) {
+    if (b2.B == 0) {
+      B = b2.B + 1;
+    } else
+      B = b2.B;
+  }
+};
+
+struct Derived : public Base {
+  Derived(const Derived &) = default; // CHECK:  2| [[@LINE]]|  Derived
+  Derived() = default;                // CHECK:  1| [[@LINE]]|  Derived
+  int I;
+  int J;
+  int getI() { return I; }
+};
+
+Derived dd;
+int g;
+int main() {
+  Derived dd2(dd);
+  Derived dd3(dd);
+
+  g = dd2.getI() + dd3.getI();
+  return 0;
+}
diff --git a/compiler-rt/test/profile/Linux/coverage_dtor.cpp b/compiler-rt/test/profile/Linux/coverage_dtor.cpp
new file mode 100644 (file)
index 0000000..b24bfb8
--- /dev/null
@@ -0,0 +1,26 @@
+// RUN: %clang -x c++ -fno-exceptions  -std=c++11 -fuse-ld=gold -fprofile-instr-generate -fcoverage-mapping -o %t %s
+// RUN: env LLVM_PROFILE_FILE=%t.profraw %run %t
+// RUN: llvm-profdata merge -o %t.profdata %t.profraw
+// RUN: llvm-cov show %t -instr-profile %t.profdata -filename-equivalence 2>&1 | FileCheck %s
+
+struct Base {
+  int B;
+  Base(int B_) : B(B_) {}
+  ~Base() {}
+};
+
+struct Derived : public Base {
+  Derived(int K) : Base(K), I(K), J(K) {}
+  ~Derived() = default; // CHECK:  2| [[@LINE]]|  ~Derived
+  int I;
+  int J;
+  int getI() { return I; }
+};
+
+int g;
+int main() {
+  Derived dd(10);
+  Derived dd2(120);
+  g = dd2.getI() + dd.getI();
+  return 0;
+}