[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / clang-tools-extra / clangd / test / compile-commands-path-in-initialize.test
blob8c7ea26ca94dd0da720aa4760772d7e264fd6483
1 # Test that we can set choose a configuration/build directly in the initialize
2 # request.
4 # RUN: rm -rf %t.dir/* && mkdir -p %t.dir
5 # RUN: mkdir %t.dir/build-1
6 # RUN: echo '[{"directory": "%/t.dir", "command": "c++ the-file.cpp", "file": "the-file.cpp"}]' > %t.dir/compile_commands.json
7 # RUN: echo '[{"directory": "%/t.dir/build-1", "command": "c++ -DMACRO=1 the-file.cpp", "file": "../the-file.cpp"}]' > %t.dir/build-1/compile_commands.json
9 # RUN: sed -e "s|INPUT_DIR|%/t.dir|g" %s > %t.test.1
11 # On Windows, we need the URI in didOpen to look like "uri":"file:///C:/..."
12 # (with the extra slash in the front), so we add it here.
13 # RUN: sed -E -e 's|"file://([A-Z]):/|"file:///\1:/|g' %t.test.1 > %t.test
15 # RUN: clangd -lit-test < %t.test | FileCheck -strict-whitespace %t.test
17 {"jsonrpc":"2.0","id":0,"method":"initialize","params":{"initializationOptions":{"compilationDatabasePath":"INPUT_DIR/build-1"}}}
18 ---
19 {"jsonrpc":"2.0","method":"textDocument/didOpen","params":{"textDocument":{"uri":"file://INPUT_DIR/the-file.cpp","languageId":"cpp","version":1,"text":"#if !defined(MACRO)\n#pragma message (\"MACRO is not defined\")\n#elif MACRO == 1\n#pragma message (\"MACRO is one\")\n#else\n#pragma message (\"woops\")\n#endif\nint main() {}\n"}}}
20 # CHECK:   "method": "textDocument/publishDiagnostics",
21 # CHECK-NEXT:   "params": {
22 # CHECK-NEXT:     "diagnostics": [
23 # CHECK-NEXT:       {
24 # CHECK-NEXT:         "code": "-W#pragma-messages",
25 # CHECK-NEXT:         "message": "MACRO is one",
26 ---
27 {"jsonrpc":"2.0","id":10000,"method":"shutdown"}
28 ---
29 {"jsonrpc":"2.0","method":"exit"}