2019-07-17 16:31:51 +08:00
|
|
|
#include "ClangTidy.h"
|
|
|
|
#include "ClangTidyTest.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace tidy {
|
|
|
|
namespace test {
|
|
|
|
|
|
|
|
class TestCheck : public ClangTidyCheck {
|
|
|
|
public:
|
|
|
|
TestCheck(StringRef Name, ClangTidyContext *Context)
|
|
|
|
: ClangTidyCheck(Name, Context) {}
|
2020-06-29 16:44:11 +08:00
|
|
|
void registerMatchers(ast_matchers::MatchFinder *Finder) override {
|
|
|
|
Finder->addMatcher(ast_matchers::varDecl().bind("var"), this);
|
2019-07-17 16:31:51 +08:00
|
|
|
}
|
2020-06-29 16:44:11 +08:00
|
|
|
void check(const ast_matchers::MatchFinder::MatchResult &Result) override {
|
2019-07-17 16:31:51 +08:00
|
|
|
const auto *Var = Result.Nodes.getNodeAs<VarDecl>("var");
|
|
|
|
// Add diagnostics in the wrong order.
|
|
|
|
diag(Var->getLocation(), "variable");
|
|
|
|
diag(Var->getTypeSpecStartLoc(), "type specifier");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST(ClangTidyDiagnosticConsumer, SortsErrors) {
|
|
|
|
std::vector<ClangTidyError> Errors;
|
|
|
|
runCheckOnCode<TestCheck>("int a;", &Errors);
|
2020-06-29 16:44:11 +08:00
|
|
|
EXPECT_EQ(2ul, Errors.size());
|
2019-07-17 16:31:51 +08:00
|
|
|
EXPECT_EQ("type specifier", Errors[0].Message.Message);
|
|
|
|
EXPECT_EQ("variable", Errors[1].Message.Message);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace test
|
|
|
|
} // namespace tidy
|
|
|
|
} // namespace clang
|