Commit dca3410e authored by Marco Bubke's avatar Marco Bubke

UnitTest: Use the os temp dir instead of a hard coded "/tmp"

Change-Id: Ief32d3ca9aa0ccee25a1415f84552117c7323a31
Reviewed-by: Tim Jenssen's avatarTim Jenssen <tim.jenssen@qt.io>
parent 600b85de
......@@ -27,13 +27,15 @@
#include <refactoringcompilationdatabase.h>
#include <utils/smallstring.h>
#include <QDir>
using testing::Contains;
using testing::IsEmpty;
using testing::Not;
using testing::PrintToString;
using ClangBackEnd::RefactoringCompilationDatabase;
namespace {
MATCHER_P3(IsCompileCommand, directory, fileName, commandLine,
......@@ -51,48 +53,53 @@ MATCHER_P3(IsCompileCommand, directory, fileName, commandLine,
return true;
}
TEST(RefactoringCompilationDatabase, GetAllFilesContainsTranslationUnit)
class RefactoringCompilationDatabase : public ::testing::Test
{
RefactoringCompilationDatabase database;
database.addFile("/tmp", "data.cpp", {"cc", "data.cpp", "-DNO_DEBUG"});
protected:
void SetUp();
protected:
ClangBackEnd::RefactoringCompilationDatabase database;
Utils::SmallString temporaryDirectoryPath = QDir::toNativeSeparators(QDir::tempPath());
Utils::SmallString temporarySourceFilePath = QDir::toNativeSeparators(QDir::tempPath() + "/data.cpp");
};
TEST_F(RefactoringCompilationDatabase, GetAllFilesContainsTranslationUnit)
{
auto filePaths = database.getAllFiles();
ASSERT_THAT(filePaths, Contains("/tmp/data.cpp"));
ASSERT_THAT(filePaths, Contains(temporarySourceFilePath));
}
TEST(RefactoringCompilationDatabase, CompileCommandForFilePath)
TEST_F(RefactoringCompilationDatabase, CompileCommandForFilePath)
{
RefactoringCompilationDatabase database;
database.addFile("/tmp", "data.cpp", {"cc", "data.cpp", "-DNO_DEBUG"});
auto compileCommands = database.getAllCompileCommands();
ASSERT_THAT(compileCommands, Contains(IsCompileCommand("/tmp",
ASSERT_THAT(compileCommands, Contains(IsCompileCommand(temporaryDirectoryPath,
"data.cpp",
std::vector<std::string>{"cc", "data.cpp", "-DNO_DEBUG"})));
std::vector<std::string>{"cc", "data.cpp", "-DNO_DEBUG"})));
}
TEST(RefactoringCompilationDatabase, NoCompileCommandForFilePath)
TEST_F(RefactoringCompilationDatabase, NoCompileCommandForFilePath)
{
RefactoringCompilationDatabase database;
database.addFile("/tmp", "data.cpp", {"cc", "data.cpp", "-DNO_DEBUG"});
auto compileCommands = database.getAllCompileCommands();
ASSERT_THAT(compileCommands, Not(Contains(IsCompileCommand("/tmp",
ASSERT_THAT(compileCommands, Not(Contains(IsCompileCommand(temporaryDirectoryPath,
"data.cpp2",
std::vector<std::string>{"cc", "data.cpp", "-DNO_DEBUG"}))));
}
TEST(RefactoringCompilationDatabase, FilePaths)
TEST_F(RefactoringCompilationDatabase, FilePaths)
{
RefactoringCompilationDatabase database;
database.addFile("/tmp", "data.cpp", {"cc", "data.cpp", "-DNO_DEBUG"});
auto filePaths = database.getAllFiles();
ASSERT_THAT(filePaths, Contains("/tmp/data.cpp"));
ASSERT_THAT(filePaths, Contains(temporarySourceFilePath));
}
void RefactoringCompilationDatabase::SetUp()
{
database.addFile(temporaryDirectoryPath, "data.cpp", {"cc", "data.cpp", "-DNO_DEBUG"});
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment