blob: ef7cd4f48257eee2fffcd84190036c1354526395 [file] [log] [blame]
Simon Marchi70e209b2018-08-03 19:40:19 +00001# Test that we can set choose a configuration/build directly in the initialize
2# request.
3
4# RUN: rm -rf %t.dir/* && mkdir -p %t.dir
5# RUN: mkdir %t.dir/build-1
Simon Marchi70e209b2018-08-03 19:40:19 +00006# 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
Simon Marchi70e209b2018-08-03 19:40:19 +00008
9# RUN: sed -e "s|INPUT_DIR|%/t.dir|g" %s > %t.test.1
10
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 "s|file://\([A-Z]\):/|file:///\1:/|g" %t.test.1 > %t.test
14
15# RUN: clangd -lit-test < %t.test | FileCheck -strict-whitespace %t.test
16
17{"jsonrpc":"2.0","id":0,"method":"initialize","params":{"initializationOptions":{"compilationDatabasePath":"INPUT_DIR/build-1"}}}
18---
Simon Marchiabeed662018-10-16 15:55:03 +000019{"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"}}}
Simon Marchi70e209b2018-08-03 19:40:19 +000020# CHECK: "method": "textDocument/publishDiagnostics",
21# CHECK-NEXT: "params": {
22# CHECK-NEXT: "diagnostics": [
23# CHECK-NEXT: {
24# CHECK-NEXT: "message": "MACRO is one",
25---
Simon Marchi70e209b2018-08-03 19:40:19 +000026{"jsonrpc":"2.0","id":10000,"method":"shutdown"}