Files
qt-creator/tests/unit/unittest/unsavedfilestest.cpp

155 lines
5.4 KiB
C++
Raw Normal View History

/****************************************************************************
**
** 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 "gtest/gtest.h"
#include "gmock/gmock-matchers.h"
#include "gmock/gmock.h"
#include "gtest-qt-printing.h"
#include <unsavedfiles.h>
#include <filecontainer.h>
#include <QVector>
using ClangBackEnd::UnsavedFiles;
using ClangBackEnd::FileContainer;
using ::testing::IsNull;
using ::testing::NotNull;
using ::testing::Gt;
namespace {
bool operator==(const ClangBackEnd::FileContainer &fileContainer, const CXUnsavedFile &cxUnsavedFile)
{
return fileContainer.filePath() == Utf8String::fromUtf8(cxUnsavedFile.Filename)
&& fileContainer.unsavedFileContent() == Utf8String(cxUnsavedFile.Contents, cxUnsavedFile.Length);
}
bool fileContainersContainsItemMatchingToCxUnsavedFile(const QVector<FileContainer> &fileContainers, const CXUnsavedFile &cxUnsavedFile)
{
for (const FileContainer &fileContainer : fileContainers)
if (fileContainer == cxUnsavedFile)
return true;
return false;
}
MATCHER_P(HasUnsavedFiles, fileContainers, "")
{
ClangBackEnd::UnsavedFiles unsavedFiles = arg;
if (unsavedFiles.count() != uint(fileContainers.size())) {
*result_listener << "unsaved count is " << unsavedFiles.count() << " and not " << fileContainers.size();
return false;
}
for (const CXUnsavedFile &cxUnsavedFile : unsavedFiles.cxUnsavedFileVector()) {
if (!fileContainersContainsItemMatchingToCxUnsavedFile(fileContainers, cxUnsavedFile))
return false;
}
return true;
}
class UnsavedFiles : public ::testing::Test
{
protected:
void TearDown() override;
protected:
::UnsavedFiles unsavedFiles;
Utf8String filePath{Utf8StringLiteral("file.cpp")};
Utf8String projectPartId{Utf8StringLiteral("projectPartId")};
Utf8String unsavedContent1{Utf8StringLiteral("foo")};
Utf8String unsavedContent2{Utf8StringLiteral("bar")};
};
void UnsavedFiles::TearDown()
{
unsavedFiles.clear();
}
TEST_F(UnsavedFiles, DoNothingForUpdateIfFileHasNoUnsavedContent)
{
QVector<FileContainer> fileContainers({FileContainer(filePath, projectPartId)});
unsavedFiles.createOrUpdate(fileContainers);
ASSERT_THAT(unsavedFiles, HasUnsavedFiles(QVector<FileContainer>()));
}
TEST_F(UnsavedFiles, AddUnsavedFileForUpdateWithUnsavedContent)
{
QVector<FileContainer> fileContainers({FileContainer(filePath, projectPartId),
FileContainer(filePath, projectPartId, unsavedContent1, true)});
unsavedFiles.createOrUpdate(fileContainers);
ASSERT_THAT(unsavedFiles, HasUnsavedFiles(QVector<FileContainer>({FileContainer(filePath, projectPartId, unsavedContent1, true)})));
}
TEST_F(UnsavedFiles, RemoveUnsavedFileForUpdateWithUnsavedContent)
{
QVector<FileContainer> fileContainers({FileContainer(filePath, projectPartId, unsavedContent1, true),
FileContainer(filePath, projectPartId)});
unsavedFiles.createOrUpdate(fileContainers);
ASSERT_THAT(unsavedFiles, HasUnsavedFiles(QVector<FileContainer>()));
}
TEST_F(UnsavedFiles, ExchangeUnsavedFileForUpdateWithUnsavedContent)
{
QVector<FileContainer> fileContainers({FileContainer(filePath, projectPartId, unsavedContent1, true),
FileContainer(filePath, projectPartId, unsavedContent2, true)});
unsavedFiles.createOrUpdate(fileContainers);
ASSERT_THAT(unsavedFiles, HasUnsavedFiles(QVector<FileContainer>({FileContainer(filePath, projectPartId, unsavedContent2, true)})));
}
TEST_F(UnsavedFiles, TimeStampIsUpdatedAsUnsavedFilesChanged)
{
QVector<FileContainer> fileContainers({FileContainer(filePath, projectPartId, unsavedContent1, true),
FileContainer(filePath, projectPartId, unsavedContent2, true)});
auto lastChangeTimePoint = unsavedFiles.lastChangeTimePoint();
unsavedFiles.createOrUpdate(fileContainers);
ASSERT_THAT(unsavedFiles.lastChangeTimePoint(), Gt(lastChangeTimePoint));
}
TEST_F(UnsavedFiles, RemoveUnsavedFiles)
{
QVector<FileContainer> fileContainers({FileContainer(filePath, projectPartId, unsavedContent1, true)});
unsavedFiles.createOrUpdate(fileContainers);
unsavedFiles.remove(fileContainers);
ASSERT_THAT(unsavedFiles, HasUnsavedFiles(QVector<FileContainer>()));
}
}