[clangd] Ensure we test for compatibility of serialized index format
authorKadir Cetinkaya <kadircet@google.com>
Wed, 11 Nov 2020 10:08:14 +0000 (11:08 +0100)
committerKadir Cetinkaya <kadircet@google.com>
Fri, 13 Nov 2020 16:06:23 +0000 (17:06 +0100)
Differential Revision: https://reviews.llvm.org/D91330

clang-tools-extra/clangd/test/index-serialization/Inputs/sample.cpp [new file with mode: 0644]
clang-tools-extra/clangd/test/index-serialization/Inputs/sample.h [new file with mode: 0644]
clang-tools-extra/clangd/test/index-serialization/Inputs/sample.idx [new file with mode: 0644]
clang-tools-extra/clangd/test/index-serialization/version-is-correct.test [new file with mode: 0644]
clang-tools-extra/clangd/test/lit.cfg.py
clang-tools-extra/clangd/test/lit.site.cfg.py.in

diff --git a/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.cpp b/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.cpp
new file mode 100644 (file)
index 0000000..7fe4e80
--- /dev/null
@@ -0,0 +1,5 @@
+// Include a file to ensure we have multiple sources.
+#include "sample.h"
+
+// This introduces a symbol, a reference and a relation.
+struct Bar : public Foo {};
diff --git a/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.h b/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.h
new file mode 100644 (file)
index 0000000..7cf73b9
--- /dev/null
@@ -0,0 +1,4 @@
+#pragma once
+
+// Introduce a symbol.
+struct Foo {};
diff --git a/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.idx b/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.idx
new file mode 100644 (file)
index 0000000..5ecb294
Binary files /dev/null and b/clang-tools-extra/clangd/test/index-serialization/Inputs/sample.idx differ
diff --git a/clang-tools-extra/clangd/test/index-serialization/version-is-correct.test b/clang-tools-extra/clangd/test/index-serialization/version-is-correct.test
new file mode 100644 (file)
index 0000000..b4227d2
--- /dev/null
@@ -0,0 +1,14 @@
+# REQUIRES: zlib
+This test tries to parse a checked-in binary index.
+If this test fails it means there has been a backward incompatilbe change to
+serialization format.
+Please bump the version number in
+clang-tools-extra/clangd/index/Serialization.cpp and regenarate sample.idx with
+
+  clangd-indexer \
+    clang-tools-extra/clangd/test/index-serialization/Inputs/sample.cpp > \
+    clang-tools-extra/clangd/test/index-serialization/Inputs/sample.idx
+
+Also if you've introduced new slabs/chunks to serialized index, make sure
+indexing sample.cpp would yield non-trivial values for those.
+# RUN: dexp %/S/Inputs/sample.idx -c="find B" | grep Bar || not grep -v '^#' %s
index a8a38a7..2680eb4 100644 (file)
@@ -30,3 +30,6 @@ if config.clangd_build_xpc:
 
 if config.clangd_enable_remote:
   config.available_features.add('clangd-remote-index')
+
+if config.have_zlib:
+  config.available_features.add('zlib')
index 750e5c5..efcc770 100644 (file)
@@ -25,6 +25,7 @@ config.clangd_source_dir = "@CMAKE_CURRENT_SOURCE_DIR@/.."
 config.clangd_binary_dir = "@CMAKE_CURRENT_BINARY_DIR@/.."
 config.clangd_build_xpc = @CLANGD_BUILD_XPC@
 config.clangd_enable_remote = @CLANGD_ENABLE_REMOTE@
+config.have_zlib = @LLVM_ENABLE_ZLIB@
 
 # Delegate logic to lit.cfg.py.
 lit_config.load_config(config, "@CMAKE_CURRENT_SOURCE_DIR@/lit.cfg.py")