Files
qt-creator/tests/unit/unittest/cursor-test.cpp
Christian Kandeler ed292f3f9b clangbackend: Categorize non-const pointer arguments as output arguments
Fixes: QTCREATORBUG-24550
Change-Id: Iac4f3b133a632d7272bfe4253f8a0740e51b0952
Reviewed-by: Christian Stenger <christian.stenger@qt.io>
2020-10-21 08:08:29 +00:00

942 lines
24 KiB
C++

/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
****************************************************************************/
#include "googletest.h"
#include "clangcompareoperators.h"
#include "unittest-utility-functions.h"
#include <clangdocument.h>
#include <clangdocuments.h>
#include <clangstring.h>
#include <cursor.h>
#include <sourcelocation.h>
#include <sourcerange.h>
#include <clangtranslationunit.h>
#include <unsavedfiles.h>
using ClangBackEnd::Cursor;
using ClangBackEnd::Document;
using ClangBackEnd::TranslationUnit;
using ClangBackEnd::UnsavedFiles;
using ClangBackEnd::Documents;
using ClangBackEnd::ClangString;
using ClangBackEnd::SourceRange;
using testing::IsNull;
using testing::NotNull;
using testing::Gt;
using testing::Contains;
using testing::EndsWith;
using testing::AllOf;
using testing::Not;
using testing::IsEmpty;
using testing::StrEq;
using testing::Eq;
namespace {
struct Data {
ClangBackEnd::UnsavedFiles unsavedFiles;
ClangBackEnd::Documents documents{unsavedFiles};
Utf8String filePath{Utf8StringLiteral(TESTDATA_DIR"/cursor.cpp")};
Document document{filePath,
UnitTest::addPlatformArguments({Utf8StringLiteral("-std=c++11")}),
{},
documents};
TranslationUnit translationUnit{filePath,
filePath,
document.translationUnit().cxIndex(),
document.translationUnit().cxTranslationUnit()};
};
class Cursor : public ::testing::Test
{
public:
static void SetUpTestCase();
static void TearDownTestCase();
protected:
static Data *d;
const Document &document = d->document;
const TranslationUnit &translationUnit = d->translationUnit;
};
TEST_F(Cursor, CreateNullCursor)
{
::Cursor cursor;
ASSERT_TRUE(cursor.isNull());
}
TEST_F(Cursor, CompareNullCursors)
{
::Cursor cursor;
::Cursor cursor2;
ASSERT_THAT(cursor, cursor2);
}
TEST_F(Cursor, IsNotValid)
{
::Cursor cursor;
ASSERT_FALSE(cursor.isValid());
}
TEST_F(Cursor, IsValid)
{
auto cursor = translationUnit.cursor();
ASSERT_TRUE(cursor.isValid());
}
TEST_F(Cursor, IsTranslationUnit)
{
auto cursor = translationUnit.cursor();
ASSERT_TRUE(cursor.isTranslationUnit());
}
TEST_F(Cursor, NullCursorIsNotTranslationUnit)
{
::Cursor cursor;
ASSERT_FALSE(cursor.isTranslationUnit());
}
TEST_F(Cursor, UnifiedSymbolResolution)
{
::Cursor cursor;
ASSERT_FALSE(cursor.unifiedSymbolResolution().hasContent());
}
TEST_F(Cursor, GetCursorAtLocation)
{
auto cursor = translationUnit.cursorAt(3, 6);
ASSERT_THAT(cursor.unifiedSymbolResolution(), Eq("c:@F@function#I#"));
}
TEST_F(Cursor, GetCursoSourceLocation)
{
auto cursor = translationUnit.cursorAt(3, 6);
ASSERT_THAT(cursor.sourceLocation(), translationUnit.sourceLocationAt(3, 6));
}
TEST_F(Cursor, GetCursoSourceRange)
{
auto cursor = translationUnit.cursorAt(3, 6);
ASSERT_THAT(cursor.sourceRange(), SourceRange(translationUnit.sourceLocationAt(3, 1),
translationUnit.sourceLocationAt(6, 2)));
}
TEST_F(Cursor, Mangling)
{
auto cursor = translationUnit.cursorAt(3, 6);
ASSERT_TRUE(cursor.mangling().hasContent());
}
TEST_F(Cursor, Spelling)
{
auto cursor = translationUnit.cursorAt(3, 6);
ASSERT_THAT(cursor.spelling().cString(), StrEq("function"));
}
TEST_F(Cursor, DisplayName)
{
auto cursor = translationUnit.cursorAt(3, 6);
ASSERT_THAT(cursor.displayName(), Eq("function(int)"));
}
TEST_F(Cursor, BriefComment)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_THAT(cursor.briefComment(), Eq("A brief comment"));
}
TEST_F(Cursor, RawComment)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_THAT(cursor.rawComment(), Eq("/**\n * A brief comment\n */"));
}
TEST_F(Cursor, CommentRange)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_THAT(cursor.commentRange(),
SourceRange(translationUnit.sourceLocationAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 7, 1),
translationUnit.sourceLocationAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 9, 4)));
}
TEST_F(Cursor, IsDefinition)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_TRUE(cursor.isDefinition());
}
TEST_F(Cursor, ForwardDeclarationIsNotDefinition)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 6, 7);
ASSERT_FALSE(cursor.isDefinition());
}
TEST_F(Cursor, GetDefinitionOfFowardDeclaration)
{
auto forwardDeclarationcursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 6, 7);
auto definitionCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_THAT(forwardDeclarationcursor.definition(), definitionCursor);
}
TEST_F(Cursor, CallToMethodeIsNotDynamic)
{
auto cursor = translationUnit.cursorAt(18, 5);
ASSERT_FALSE(cursor.isDynamicCall());
}
TEST_F(Cursor, CallToAbstractVirtualMethodeIsDynamic)
{
auto cursor = translationUnit.cursorAt(19, 5);
ASSERT_TRUE(cursor.isDynamicCall());
}
TEST_F(Cursor, CanonicalCursor)
{
auto forwardDeclarationcursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 6, 7);
auto definitionCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_THAT(definitionCursor.canonical(), forwardDeclarationcursor);
}
TEST_F(Cursor, ReferencedCursor)
{
auto functionCallCursor = translationUnit.cursorAt(18, 5);
auto functionCursor = translationUnit.cursorAt(16, 17);
ASSERT_THAT(functionCallCursor.referenced(), functionCursor);
}
TEST_F(Cursor, IsVirtual)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 15, 17);
ASSERT_TRUE(cursor.isVirtualMethod());
}
TEST_F(Cursor, IsNotPureVirtualOnlyVirtual)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 15, 17);
ASSERT_FALSE(cursor.isPureVirtualMethod());
}
TEST_F(Cursor, IsPureVirtual)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 16, 17);
ASSERT_TRUE(cursor.isPureVirtualMethod());
}
TEST_F(Cursor, ConstantMethod)
{
auto cursor = translationUnit.cursorAt(31, 18);
ASSERT_TRUE(cursor.isConstantMethod());
}
TEST_F(Cursor, IsStaticMethod)
{
auto cursor = translationUnit.cursorAt(36, 18);
ASSERT_TRUE(cursor.isStaticMethod());
}
TEST_F(Cursor, TypeSpelling)
{
auto cursor = translationUnit.cursorAt(43, 5);
ASSERT_THAT(cursor.type().utf8Spelling(), Utf8StringLiteral("lint"));
}
TEST_F(Cursor, CanonicalTypeSpelling)
{
auto cursor = translationUnit.cursorAt(43, 5);
ASSERT_THAT(cursor.type().canonical().utf8Spelling(), Utf8StringLiteral("long long"));
}
TEST_F(Cursor, CanonicalTypeCStringSpelling)
{
auto cursor = translationUnit.cursorAt(43, 5);
auto spelling = cursor.type().canonical().spelling();
ASSERT_THAT(spelling.cString(), StrEq("long long"));
}
TEST_F(Cursor, CanonicalTypeIsNotType)
{
auto cursor = translationUnit.cursorAt(43, 5);
ASSERT_THAT(cursor.type().canonical(), Not(cursor.type()));
}
TEST_F(Cursor, TypeDeclartionIsAlias)
{
auto declarationCursor = translationUnit.cursorAt(41, 5);
auto lintCursor = translationUnit.cursorAt(39, 11);
ASSERT_THAT(declarationCursor.type().declaration().type(), lintCursor.type());
}
TEST_F(Cursor, TypeIsConstantWithoutAliasLookup)
{
auto cursor = translationUnit.cursorAt(45, 16);
ASSERT_TRUE(cursor.type().isConstant());
}
TEST_F(Cursor, ClassIsCompoundType)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
ASSERT_TRUE(cursor.isCompoundType());
}
TEST_F(Cursor, StructIsCompoundType)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
ASSERT_TRUE(cursor.isCompoundType());
}
TEST_F(Cursor, UnionIsCompoundType)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 33, 7);
ASSERT_TRUE(cursor.isCompoundType());
}
TEST_F(Cursor, IsDeclaration)
{
auto cursor = translationUnit.cursorAt(41, 10);
ASSERT_TRUE(cursor.isDeclaration());
}
TEST_F(Cursor, SemanticParent)
{
auto cursor = translationUnit.cursorAt(43, 6);
auto expectedSemanticParent = translationUnit.cursorAt(36, 18);
auto semanticParent = cursor.semanticParent();
ASSERT_THAT(semanticParent, expectedSemanticParent);
}
TEST_F(Cursor, IsLocalVariableInMethod)
{
auto cursor = translationUnit.cursorAt(20, 9);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, IsLocalVariableInStaticFunction)
{
auto cursor = translationUnit.cursorAt(43, 5);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, IsLocalVariableInTemplateFunction)
{
auto cursor = translationUnit.cursorAt(52, 7);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, IsLocalVariableInConversionOperator)
{
auto cursor = translationUnit.cursorAt(57, 9);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, IsLocalVariableInOperator)
{
auto cursor = translationUnit.cursorAt(62, 9);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, IsLocalVariableInConstructor)
{
auto cursor = translationUnit.cursorAt(13, 9);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, IsLocalVariableInDestructor)
{
auto cursor = translationUnit.cursorAt(69, 9);
ASSERT_TRUE(cursor.isLocalVariable());
}
TEST_F(Cursor, FindFunctionCaller)
{
auto functionCursor = translationUnit.cursorAt(92, 24);
auto structCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
ASSERT_THAT(functionCursor.functionBaseDeclaration(), structCursor);
}
TEST_F(Cursor, FindFunctionCallerPointer)
{
auto functionCursor = translationUnit.cursorAt(79, 25);
auto structCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
ASSERT_THAT(functionCursor.functionBaseDeclaration(), structCursor);
}
TEST_F(Cursor, FindFunctionCallerThis)
{
auto functionCursor = translationUnit.cursorAt(106, 5);
auto structCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 38, 8);
ASSERT_THAT(functionCursor.functionBaseDeclaration(), structCursor);
}
TEST_F(Cursor, NonPointerTypeForValue)
{
auto variableCursor = translationUnit.cursorAt(101, 10);
auto variablePointerCursor = translationUnit.cursorAt(100, 11);
ASSERT_THAT(variableCursor.nonPointerTupe(), variablePointerCursor.nonPointerTupe());
}
TEST_F(Cursor, HasFinalAttributeInFunction)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 30, 18);
ASSERT_TRUE(cursor.hasFinalFunctionAttribute());
}
TEST_F(Cursor, HasNotFinalAttributeInFunction)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 15, 17);
ASSERT_FALSE(cursor.hasFinalFunctionAttribute());
}
TEST_F(Cursor, HasFinalAttributeInClass)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
ASSERT_TRUE(cursor.hasFinalClassAttribute());
}
TEST_F(Cursor, HasNotFinaAttributeInClass)
{
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 38, 8);
ASSERT_FALSE(cursor.hasFinalClassAttribute());
}
TEST_F(Cursor, HasOutputValues)
{
auto callExpressionCursor = translationUnit.cursorAt(117, 19);
auto outputArgumentExpectedSourceLocation = translationUnit.cursorAt(117, 20).cxSourceRange();
auto outputArgumentLocations = callExpressionCursor.outputArgumentRanges();
ASSERT_THAT(outputArgumentLocations.size(), 2);
ASSERT_THAT(outputArgumentLocations[0], outputArgumentExpectedSourceLocation);
}
TEST_F(Cursor, HasOnlyInputValues)
{
auto callExpressionCursor = translationUnit.cursorAt(118, 18);
auto outputArgumentLocations = callExpressionCursor.outputArgumentRanges();
ASSERT_THAT(outputArgumentLocations, IsEmpty());
}
TEST_F(Cursor, ArgumentCountIsZero)
{
auto cursor = translationUnit.cursorAt(121, 23);
auto count = cursor.type().argumentCount();
ASSERT_THAT(count, 0);
}
TEST_F(Cursor, ArgumentCountIsTwo)
{
auto cursor = translationUnit.cursorAt(122, 22);
auto count = cursor.type().argumentCount();
ASSERT_THAT(count, 2);
}
TEST_F(Cursor, ArgumentOneIsValue)
{
auto callExpressionCursor = translationUnit.cursorAt(122, 22);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isConstant());
ASSERT_THAT(argument.kind(), CXType_Int);
}
TEST_F(Cursor, ArgumentTwoIsLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(122, 22);
auto argument = callExpressionCursor.type().argument(1);
ASSERT_THAT(argument.kind(), CXType_LValueReference);
}
TEST_F(Cursor, ArgumentTwoIsConstantReference)
{
auto callExpressionCursor = translationUnit.cursorAt(122, 22);
auto argumentPointee = callExpressionCursor.type().argument(1);
ASSERT_TRUE(argumentPointee.isConstantReference());
}
TEST_F(Cursor, CursorArgumentCount)
{
auto cursor = translationUnit.cursorAt(117, 19);
ASSERT_THAT(cursor.kind(), CXCursor_CallExpr);
ASSERT_THAT(cursor.argumentCount(), 4);
}
TEST_F(Cursor, CursorArgumentInputValue)
{
auto callExpressionCursor = translationUnit.cursorAt(117, 19);
auto declarationReferenceExpressionCursor = translationUnit.cursorAt(117, 20);
ASSERT_THAT(callExpressionCursor.argument(0), declarationReferenceExpressionCursor);
}
TEST_F(Cursor, IsConstantLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isConstantReference());
}
TEST_F(Cursor, LValueReferenceIsNotConstantLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isConstantReference());
}
TEST_F(Cursor, ValueIsNotConstantLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isConstantReference());
}
TEST_F(Cursor, PointerToConstantNotConstantLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isConstantReference());
}
TEST_F(Cursor, IsLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isLValueReference());
}
TEST_F(Cursor, ConstantLValueReferenceIsLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isLValueReference());
}
TEST_F(Cursor, ValueIsNotLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isLValueReference());
}
TEST_F(Cursor, PointerIsNotLValueReference)
{
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isLValueReference());
}
TEST_F(Cursor, PointerToConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isPointerToConstant());
}
TEST_F(Cursor, ValueIsNotPointerToConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isPointerToConstant());
}
TEST_F(Cursor, PointerNotPointerToConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(127, 13);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isPointerToConstant());
}
TEST_F(Cursor, ConstantLValueReferenceIsNotPointerToConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isPointerToConstant());
}
TEST_F(Cursor, IsConstantPointer)
{
auto callExpressionCursor = translationUnit.cursorAt(128, 21);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isConstantPointer());
}
TEST_F(Cursor, PointerToConstantIsNotConstantPointer)
{
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isConstantPointer());
}
TEST_F(Cursor, ConstValueIsNotConstantPointer)
{
auto callExpressionCursor = translationUnit.cursorAt(129, 23);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isConstantPointer());
}
TEST_F(Cursor, PointerToConstantIsReferencingConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isReferencingConstant());
}
TEST_F(Cursor, ConstantReferenceIsReferencingConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isReferencingConstant());
}
TEST_F(Cursor, LValueReferenceIsNotReferencingConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isReferencingConstant());
}
TEST_F(Cursor, ValueIsNotReferencingConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isReferencingConstant());
}
TEST_F(Cursor, PointerIsNotRefencingConstant)
{
auto callExpressionCursor = translationUnit.cursorAt(127, 13);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isReferencingConstant());
}
TEST_F(Cursor, PointerIsOutputArgument)
{
auto callExpressionCursor = translationUnit.cursorAt(127, 13);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isOutputArgument());
}
TEST_F(Cursor, ConstantReferenceIsNotOutputArgument)
{
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isOutputArgument());
}
TEST_F(Cursor, PointerToConstantIsNotOutputArgument)
{
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isOutputArgument()) << argument.isConstant() << argument.pointeeType().isConstant();
}
TEST_F(Cursor, ConstantPointerIsOutputArgument)
{
auto callExpressionCursor = translationUnit.cursorAt(128, 21);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isOutputArgument());
}
TEST_F(Cursor, ReferenceIsOutputArgument)
{
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_TRUE(argument.isOutputArgument());
}
TEST_F(Cursor, ConstReferenceIsNotOutputArgument)
{
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
auto argument = callExpressionCursor.type().argument(0);
ASSERT_FALSE(argument.isOutputArgument());
}
TEST_F(Cursor, ResultType)
{
auto methodCursor = translationUnit.cursorAt(31, 18);
Utf8String resultType = methodCursor.type().resultType().spelling();
ASSERT_THAT(resultType, Utf8String("bool", 4));
}
TEST_F(Cursor, PrivateMethodAccessSpecifier)
{
auto methodCursor = translationUnit.cursorAt(16, 17);
auto accessSpecifier = methodCursor.accessSpecifier();
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Private);
}
TEST_F(Cursor, PublicMethodAccessSpecifier)
{
auto methodCursor = translationUnit.cursorAt(79, 25);
auto accessSpecifier = methodCursor.accessSpecifier();
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Public);
}
TEST_F(Cursor, ProtectedMethodAccessSpecifier)
{
auto methodCursor = translationUnit.cursorAt(131, 22);
auto accessSpecifier = methodCursor.accessSpecifier();
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Protected);
}
TEST_F(Cursor, PrivateFieldAccessSpecifier)
{
auto fieldCursor = translationUnit.cursorAt(21, 12);
auto accessSpecifier = fieldCursor.accessSpecifier();
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Private);
}
TEST_F(Cursor, InvalidAccessSpecifier)
{
auto localVarCursor = translationUnit.cursorAt(62, 9);
auto accessSpecifier = localVarCursor.accessSpecifier();
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Invalid);
}
TEST_F(Cursor, NoStorageClass)
{
auto localVarCursor = translationUnit.cursorAt(62, 9);
auto storageClass = localVarCursor.storageClass();
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::None);
}
TEST_F(Cursor, ExternVarStorageClass)
{
auto externalVarCursor = translationUnit.cursorAt(133, 12);
auto storageClass = externalVarCursor.storageClass();
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::Extern);
}
TEST_F(Cursor, StaticMethodStorageClass)
{
auto methodCursor = translationUnit.cursorAt(135, 13);
auto storageClass = methodCursor.storageClass();
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::Static);
}
TEST_F(Cursor, InvalidStorageClass)
{
auto functionTemplateCursor = translationUnit.cursorAt(137, 28);
auto storageClass = functionTemplateCursor.storageClass();
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::Invalid);
}
TEST_F(Cursor, IsAnonymousNamespace)
{
auto anonymousCursor = translationUnit.cursorAt(140, 1);
bool anonymous = anonymousCursor.isAnonymous();
ASSERT_THAT(anonymous, true);
}
TEST_F(Cursor, IsNotAnonymousNamespace)
{
auto anonymousCursor = translationUnit.cursorAt(139, 1);
bool anonymous = anonymousCursor.isAnonymous();
ASSERT_THAT(anonymous, false);
}
TEST_F(Cursor, AnonymousNamespaceDisplayName)
{
auto anonymousCursor = translationUnit.cursorAt(140, 1);
auto name = anonymousCursor.displayName();
ASSERT_THAT(name, Utf8String("(anonymous)"));
}
TEST_F(Cursor, AnonymousEnumDisplayName)
{
auto anonymousCursor = translationUnit.cursorAt(144, 1);
auto name = anonymousCursor.displayName();
ASSERT_THAT(name, Utf8String("(anonymous)"));
}
Data *Cursor::d;
void Cursor::SetUpTestCase()
{
d = new Data;
d->document.parse();
}
void Cursor::TearDownTestCase()
{
delete d;
d = nullptr;
}
}