| // Test profiling functionality with single file |
| // RUN: rm -rf %t |
| // RUN: mkdir %t |
| // RUN: echo "[{\"directory\":\".\",\"command\":\"clang++ -c %/t/test.cpp\",\"file\":\"%/t/test.cpp\"}]" | sed -e 's/\\/\\\\/g' > %t/compile_commands.json |
| // RUN: echo "Checks: '-*,readability-function-size'" > %t/.clang-tidy |
| // RUN: cp "%s" "%t/test.cpp" |
| // RUN: cd "%t" |
| // RUN: %run_clang_tidy -enable-check-profile "test.cpp" 2>&1 | FileCheck %s --check-prefix=CHECK-SINGLE |
| |
| // CHECK-SINGLE: Running clang-tidy in {{[1-9][0-9]*}} threads for 1 files out of 1 in compilation database |
| // CHECK-SINGLE: ===-------------------------------------------------------------------------=== |
| // CHECK-SINGLE-NEXT: clang-tidy checks profiling |
| // CHECK-SINGLE-NEXT: ===-------------------------------------------------------------------------=== |
| // CHECK-SINGLE-NEXT: Total Execution Time: {{.*}} seconds ({{.*}} wall clock) |
| // CHECK-SINGLE-EMPTY: |
| // CHECK-SINGLE-NEXT: ---User Time--- --System Time-- --User+System-- ---Wall Time--- --- Name --- |
| // CHECK-SINGLE: {{[[:space:]]*[0-9]+\.[0-9]+.*%.*readability-function-size}} |
| // CHECK-SINGLE: {{[[:space:]]*[0-9]+\.[0-9]+.*100\.0%.*Total}} |
| |
| // Test profiling functionality with multiple files and multiple checks |
| // RUN: rm -rf %t-multi |
| // RUN: mkdir %t-multi |
| // RUN: echo "[{\"directory\":\".\",\"command\":\"clang++ -c %/t-multi/test1.cpp\",\"file\":\"%/t-multi/test1.cpp\"},{\"directory\":\".\",\"command\":\"clang++ -c %/t-multi/test2.cpp\",\"file\":\"%/t-multi/test2.cpp\"}]" | sed -e 's/\\/\\\\/g' > %t-multi/compile_commands.json |
| // RUN: echo "Checks: '-*,readability-function-size,misc-unused-using-decls,llvm-qualified-auto'" > %t-multi/.clang-tidy |
| // RUN: cp "%s" "%t-multi/test1.cpp" |
| // RUN: cp "%s" "%t-multi/test2.cpp" |
| // RUN: cd "%t-multi" |
| // RUN: %run_clang_tidy -enable-check-profile -j 2 "test1.cpp" "test2.cpp" 2>&1 | FileCheck %s --check-prefix=CHECK-MULTIPLE |
| |
| // CHECK-MULTIPLE: Running clang-tidy in 2 threads for 2 files out of 2 in compilation database |
| // CHECK-MULTIPLE: ===-------------------------------------------------------------------------=== |
| // CHECK-MULTIPLE-NEXT: clang-tidy checks profiling |
| // CHECK-MULTIPLE-NEXT: ===-------------------------------------------------------------------------=== |
| // CHECK-MULTIPLE-NEXT: Total Execution Time: {{.*}} seconds ({{.*}} wall clock) |
| // CHECK-MULTIPLE-EMPTY: |
| // CHECK-MULTIPLE-NEXT: ---User Time--- --System Time-- --User+System-- ---Wall Time--- --- Name --- |
| // CHECK-MULTIPLE-DAG: {{[[:space:]]*[0-9]+\.[0-9]+.*%.*readability-function-size}} |
| // CHECK-MULTIPLE-DAG: {{[[:space:]]*[0-9]+\.[0-9]+.*%.*misc-unused-using-decls}} |
| // CHECK-MULTIPLE-DAG: {{[[:space:]]*[0-9]+\.[0-9]+.*%.*llvm-qualified-auto}} |
| // CHECK-MULTIPLE: {{[[:space:]]*[0-9]+\.[0-9]+.*100\.0%.*Total}} |
| |
| // Test profiling functionality with no files (empty database) |
| // RUN: rm -rf %t-empty |
| // RUN: mkdir %t-empty |
| // RUN: echo "[]" > %t-empty/compile_commands.json |
| // RUN: echo "Checks: '-*'" > %t-empty/.clang-tidy |
| // RUN: cd "%t-empty" |
| // RUN: %run_clang_tidy -enable-check-profile -allow-no-checks 2>&1 | FileCheck %s --check-prefix=CHECK-EMPTY |
| |
| // CHECK-EMPTY: Running clang-tidy in {{[1-9][0-9]*}} threads for 0 files out of 0 in compilation database |
| // CHECK-EMPTY: No profiling data found. |
| |
| class A { |
| A() {} |
| ~A() {} |
| }; |