File: ASTSignalsTests.cpp

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 1,998,492 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (75 lines) | stat: -rw-r--r-- 2,339 bytes parent folder | download | duplicates (12)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//===-- ASTSignalsTests.cpp -------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

#include "ASTSignals.h"
#include "TestIndex.h"
#include "TestTU.h"
#include "llvm/ADT/StringRef.h"
#include "gmock/gmock.h"
#include "gtest/gtest.h"

namespace clang {
namespace clangd {
namespace {

using ::testing::_;
using ::testing::Pair;
using ::testing::UnorderedElementsAre;

TEST(ASTSignals, Derive) {
  TestTU TU = TestTU::withCode(R"cpp(
  namespace ns1 {
  namespace ns2 {
  namespace {
  int func() {
    tar::X a;
    a.Y = 1;
    return ADD(tar::kConst, a.Y, tar::foo()) + fooInNS2() + tar::foo();
  }
  } // namespace
  } // namespace ns2
  } // namespace ns1
  )cpp");

  TU.HeaderCode = R"cpp(
  #define ADD(x, y, z) (x + y + z)
  namespace tar {  // A related namespace.
  int kConst = 5;
  int foo();
  void bar();  // Unused symbols are not recorded.
  class X {
    public: int Y;
  };
  } // namespace tar
  namespace ns1::ns2 { int fooInNS2(); }}
  )cpp";
  ASTSignals Signals = ASTSignals::derive(TU.build());
  std::vector<std::pair<StringRef, int>> NS;
  for (const auto &P : Signals.RelatedNamespaces)
    NS.emplace_back(P.getKey(), P.getValue());
  EXPECT_THAT(NS, UnorderedElementsAre(Pair("ns1::", 1), Pair("ns1::ns2::", 1),
                                       Pair("tar::", /*foo, kConst, X*/ 3)));

  std::vector<std::pair<SymbolID, int>> Sym;
  for (const auto &P : Signals.ReferencedSymbols)
    Sym.emplace_back(P.getFirst(), P.getSecond());
  EXPECT_THAT(
      Sym,
      UnorderedElementsAre(
          Pair(ns("tar").ID, 4), Pair(ns("ns1").ID, 1),
          Pair(ns("ns1::ns2").ID, 1), Pair(_ /*int func();*/, 1),
          Pair(cls("tar::X").ID, 1), Pair(var("tar::kConst").ID, 1),
          Pair(func("tar::foo").ID, 2), Pair(func("ns1::ns2::fooInNS2").ID, 1),
          Pair(sym("Y", index::SymbolKind::Variable, "@N@tar@S@X@FI@\\0").ID,
               2),
          Pair(_ /*a*/, 3)));
  EXPECT_EQ(Signals.InsertionDirective, Symbol::IncludeDirective::Include);
}
} // namespace
} // namespace clangd
} // namespace clang