2018-02-20 12:43:05 +01:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
|
|
|
** Copyright (C) 2017 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 "mocksqlitedatabase.h"
|
|
|
|
|
|
|
|
#include <precompiledheaderstorage.h>
|
|
|
|
#include <refactoringdatabaseinitializer.h>
|
|
|
|
#include <sqlitedatabase.h>
|
2018-12-04 19:03:48 +01:00
|
|
|
#include <sqlitereadstatement.h>
|
2018-02-20 12:43:05 +01:00
|
|
|
#include <sqlitewritestatement.h>
|
2018-03-28 16:25:01 +02:00
|
|
|
#include <sqlitetransaction.h>
|
2018-02-20 12:43:05 +01:00
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
2018-09-11 17:02:45 +02:00
|
|
|
using Storage = ClangBackEnd::PrecompiledHeaderStorage<NiceMock<MockSqliteDatabase>>;
|
2018-02-20 12:43:05 +01:00
|
|
|
|
|
|
|
class PrecompiledHeaderStorage : public testing::Test
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
NiceMock<MockSqliteDatabase> database;
|
|
|
|
Storage storage{database};
|
2019-03-13 15:09:30 +01:00
|
|
|
MockSqliteWriteStatement &insertProjectPrecompiledHeaderStatement = storage.insertProjectPrecompiledHeaderStatement;
|
|
|
|
MockSqliteWriteStatement &deleteProjectPrecompiledHeaderStatement = storage.deleteProjectPrecompiledHeaderStatement;
|
2019-07-24 16:23:08 +02:00
|
|
|
MockSqliteWriteStatement &deleteProjectPrecompiledHeaderPathAndSetBuildTimeStatement
|
|
|
|
= storage.deleteProjectPrecompiledHeaderPathAndSetBuildTimeStatement;
|
2019-03-13 15:09:30 +01:00
|
|
|
MockSqliteWriteStatement &insertSystemPrecompiledHeaderStatement = storage.insertSystemPrecompiledHeaderStatement;
|
|
|
|
MockSqliteWriteStatement &deleteSystemPrecompiledHeaderStatement = storage.deleteSystemPrecompiledHeaderStatement;
|
|
|
|
MockSqliteReadStatement &fetchSystemPrecompiledHeaderPathStatement = storage.fetchSystemPrecompiledHeaderPathStatement;
|
2019-04-10 19:24:36 +02:00
|
|
|
MockSqliteReadStatement &fetchPrecompiledHeaderStatement = storage.fetchPrecompiledHeaderStatement;
|
|
|
|
MockSqliteReadStatement &fetchPrecompiledHeadersStatement = storage.fetchPrecompiledHeadersStatement;
|
2019-07-25 15:01:25 +02:00
|
|
|
MockSqliteReadStatement &fetchTimeStampsStatement = storage.fetchTimeStampsStatement;
|
2018-02-20 12:43:05 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, UseTransaction)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
Storage storage{database};
|
|
|
|
}
|
|
|
|
|
2018-12-04 19:03:48 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, InsertProjectPrecompiledHeader)
|
2018-02-20 12:43:05 +01:00
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
2018-03-28 16:25:01 +02:00
|
|
|
EXPECT_CALL(database, immediateBegin());
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(insertProjectPrecompiledHeaderStatement,
|
2019-03-13 15:09:30 +01:00
|
|
|
write(TypedEq<int>(1),
|
2018-03-28 16:25:01 +02:00
|
|
|
TypedEq<Utils::SmallStringView>("/path/to/pch"),
|
|
|
|
TypedEq<long long>(22)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.insertProjectPrecompiledHeader(1, "/path/to/pch", 22);
|
2018-03-28 16:25:01 +02:00
|
|
|
}
|
|
|
|
|
2018-12-04 19:03:48 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, InsertProjectPrecompiledHeaderStatementIsBusy)
|
2018-03-28 16:25:01 +02:00
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin()).WillOnce(Throw(Sqlite::StatementIsBusy("busy")));
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(insertProjectPrecompiledHeaderStatement,
|
2019-03-13 15:09:30 +01:00
|
|
|
write(TypedEq<int>(1),
|
2018-02-20 12:43:05 +01:00
|
|
|
TypedEq<Utils::SmallStringView>("/path/to/pch"),
|
|
|
|
TypedEq<long long>(22)));
|
2018-03-28 16:25:01 +02:00
|
|
|
EXPECT_CALL(database, commit());
|
2018-02-20 12:43:05 +01:00
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.insertProjectPrecompiledHeader(1, "/path/to/pch", 22);
|
2018-02-20 12:43:05 +01:00
|
|
|
}
|
|
|
|
|
2018-12-04 19:03:48 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, DeleteProjectPrecompiledHeader)
|
2018-02-20 12:43:05 +01:00
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
2018-03-28 16:25:01 +02:00
|
|
|
EXPECT_CALL(database, immediateBegin());
|
2019-07-24 16:23:08 +02:00
|
|
|
EXPECT_CALL(deleteProjectPrecompiledHeaderPathAndSetBuildTimeStatement,
|
|
|
|
write(TypedEq<int>(1), TypedEq<long long>(13)));
|
2018-03-28 16:25:01 +02:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-07-24 16:23:08 +02:00
|
|
|
storage.deleteProjectPrecompiledHeader(1, 13);
|
2018-03-28 16:25:01 +02:00
|
|
|
}
|
|
|
|
|
2018-12-04 19:03:48 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, DeleteProjectPrecompiledHeaderStatementIsBusy)
|
2018-03-28 16:25:01 +02:00
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin()).WillOnce(Throw(Sqlite::StatementIsBusy("busy")));
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
2019-07-24 16:23:08 +02:00
|
|
|
EXPECT_CALL(deleteProjectPrecompiledHeaderPathAndSetBuildTimeStatement,
|
|
|
|
write(TypedEq<int>(1), TypedEq<long long>(13)));
|
2018-03-28 16:25:01 +02:00
|
|
|
EXPECT_CALL(database, commit());
|
2018-02-20 12:43:05 +01:00
|
|
|
|
2019-07-24 16:23:08 +02:00
|
|
|
storage.deleteProjectPrecompiledHeader(1, 13);
|
2018-02-20 12:43:05 +01:00
|
|
|
}
|
|
|
|
|
2019-03-19 17:00:03 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, DeleteProjectPrecompiledHeaders)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
|
|
|
EXPECT_CALL(deleteProjectPrecompiledHeaderStatement, write(TypedEq<int>(1)));
|
|
|
|
EXPECT_CALL(deleteProjectPrecompiledHeaderStatement, write(TypedEq<int>(2)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.deleteProjectPrecompiledHeaders({1, 2});
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, DeleteProjectPrecompiledHeadersStatementIsBusy)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin()).WillOnce(Throw(Sqlite::StatementIsBusy("busy")));
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
|
|
|
EXPECT_CALL(deleteProjectPrecompiledHeaderStatement, write(TypedEq<int>(1)));
|
|
|
|
EXPECT_CALL(deleteProjectPrecompiledHeaderStatement, write(TypedEq<int>(2)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.deleteProjectPrecompiledHeaders({1, 2});
|
|
|
|
}
|
|
|
|
|
2018-12-17 12:06:57 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, InsertSystemPrecompiledHeaders)
|
2018-02-20 12:43:05 +01:00
|
|
|
{
|
2018-12-04 19:03:48 +01:00
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
|
|
|
EXPECT_CALL(insertSystemPrecompiledHeaderStatement,
|
2019-03-13 15:09:30 +01:00
|
|
|
write(TypedEq<int>(1),
|
2018-12-04 19:03:48 +01:00
|
|
|
TypedEq<Utils::SmallStringView>("/path/to/pch"),
|
|
|
|
TypedEq<long long>(22)));
|
2018-12-17 12:06:57 +01:00
|
|
|
EXPECT_CALL(insertSystemPrecompiledHeaderStatement,
|
2019-03-13 15:09:30 +01:00
|
|
|
write(TypedEq<int>(2),
|
2018-12-17 12:06:57 +01:00
|
|
|
TypedEq<Utils::SmallStringView>("/path/to/pch"),
|
|
|
|
TypedEq<long long>(22)));
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.insertSystemPrecompiledHeaders({1, 2}, "/path/to/pch", 22);
|
2018-02-20 12:43:05 +01:00
|
|
|
}
|
|
|
|
|
2018-12-17 12:06:57 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, InsertSystemPrecompiledHeadersStatementIsBusy)
|
2018-02-20 12:43:05 +01:00
|
|
|
{
|
2018-12-04 19:03:48 +01:00
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin()).WillOnce(Throw(Sqlite::StatementIsBusy("busy")));
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
|
|
|
EXPECT_CALL(insertSystemPrecompiledHeaderStatement,
|
2019-03-13 15:09:30 +01:00
|
|
|
write(TypedEq<int>(1),
|
2018-12-04 19:03:48 +01:00
|
|
|
TypedEq<Utils::SmallStringView>("/path/to/pch"),
|
|
|
|
TypedEq<long long>(22)));
|
2018-12-17 12:06:57 +01:00
|
|
|
EXPECT_CALL(insertSystemPrecompiledHeaderStatement,
|
2019-03-13 15:09:30 +01:00
|
|
|
write(TypedEq<int>(2),
|
2018-12-17 12:06:57 +01:00
|
|
|
TypedEq<Utils::SmallStringView>("/path/to/pch"),
|
|
|
|
TypedEq<long long>(22)));
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.insertSystemPrecompiledHeaders({1, 2}, "/path/to/pch", 22);
|
2018-12-04 19:03:48 +01:00
|
|
|
}
|
|
|
|
|
2018-12-17 12:06:57 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, DeleteSystemPrecompiledHeaders)
|
2018-12-04 19:03:48 +01:00
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
2019-03-13 15:09:30 +01:00
|
|
|
EXPECT_CALL(deleteSystemPrecompiledHeaderStatement, write(TypedEq<int>(1)));
|
|
|
|
EXPECT_CALL(deleteSystemPrecompiledHeaderStatement, write(TypedEq<int>(2)));
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.deleteSystemPrecompiledHeaders({1, 2});
|
2018-02-20 12:43:05 +01:00
|
|
|
}
|
|
|
|
|
2018-12-17 12:06:57 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, DeleteSystemPrecompiledHeadersStatementIsBusy)
|
2018-02-20 12:43:05 +01:00
|
|
|
{
|
2018-12-04 19:03:48 +01:00
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, immediateBegin()).WillOnce(Throw(Sqlite::StatementIsBusy("busy")));
|
|
|
|
EXPECT_CALL(database, immediateBegin());
|
2019-03-13 15:09:30 +01:00
|
|
|
EXPECT_CALL(deleteSystemPrecompiledHeaderStatement, write(TypedEq<int>(1)));
|
|
|
|
EXPECT_CALL(deleteSystemPrecompiledHeaderStatement, write(TypedEq<int>(2)));
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.deleteSystemPrecompiledHeaders({1, 2});
|
2018-02-20 12:43:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, CompilePrecompiledHeaderStatements)
|
|
|
|
{
|
|
|
|
Sqlite::Database database{":memory:", Sqlite::JournalMode::Memory};
|
|
|
|
ClangBackEnd::RefactoringDatabaseInitializer<Sqlite::Database> initializer{database};
|
|
|
|
|
2018-09-11 17:02:45 +02:00
|
|
|
ASSERT_NO_THROW(ClangBackEnd::PrecompiledHeaderStorage<>{database});
|
2018-02-20 12:43:05 +01:00
|
|
|
}
|
|
|
|
|
2018-12-04 19:03:48 +01:00
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchSystemPrecompiledHeaderCalls)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
2019-03-13 15:09:30 +01:00
|
|
|
EXPECT_CALL(fetchSystemPrecompiledHeaderPathStatement, valueReturnFilePath(TypedEq<int>(1)));
|
2018-12-04 19:03:48 +01:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
storage.fetchSystemPrecompiledHeaderPath(1);
|
2018-12-04 19:03:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchSystemPrecompiledHeader)
|
|
|
|
{
|
2019-03-13 15:09:30 +01:00
|
|
|
EXPECT_CALL(fetchSystemPrecompiledHeaderPathStatement, valueReturnFilePath(TypedEq<int>(1)))
|
2018-12-17 12:06:57 +01:00
|
|
|
.WillOnce(Return(ClangBackEnd::FilePath{"/path/to/pch"}));
|
2018-12-04 19:03:48 +01:00
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
auto path = storage.fetchSystemPrecompiledHeaderPath(1);
|
2018-12-04 19:03:48 +01:00
|
|
|
|
|
|
|
ASSERT_THAT(path, "/path/to/pch");
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchSystemPrecompiledHeaderReturnsEmptyPath)
|
|
|
|
{
|
2019-03-13 15:09:30 +01:00
|
|
|
EXPECT_CALL(fetchSystemPrecompiledHeaderPathStatement, valueReturnFilePath(TypedEq<int>(1)))
|
2018-12-17 12:06:57 +01:00
|
|
|
.WillOnce(Return(ClangBackEnd::FilePath{}));
|
2018-12-04 19:03:48 +01:00
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
auto path = storage.fetchSystemPrecompiledHeaderPath(1);
|
2018-12-04 19:03:48 +01:00
|
|
|
|
|
|
|
ASSERT_THAT(path, IsEmpty());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchSystemPrecompiledHeaderReturnsNullOptional)
|
|
|
|
{
|
2019-03-13 15:09:30 +01:00
|
|
|
EXPECT_CALL(fetchSystemPrecompiledHeaderPathStatement, valueReturnFilePath(TypedEq<int>(1)))
|
2018-12-17 12:06:57 +01:00
|
|
|
.WillOnce(Return(Utils::optional<ClangBackEnd::FilePath>{}));
|
2018-12-04 19:03:48 +01:00
|
|
|
|
2019-03-13 15:09:30 +01:00
|
|
|
auto path = storage.fetchSystemPrecompiledHeaderPath(1);
|
2018-12-04 19:03:48 +01:00
|
|
|
|
|
|
|
ASSERT_THAT(path, IsEmpty());
|
|
|
|
}
|
2019-02-22 16:44:40 +01:00
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchPrecompiledHeaderCallsValueInStatement)
|
|
|
|
{
|
2019-04-10 18:21:22 +02:00
|
|
|
EXPECT_CALL(database, deferredBegin());
|
2019-04-10 19:24:36 +02:00
|
|
|
EXPECT_CALL(fetchPrecompiledHeaderStatement, valueReturnFilePath(Eq(25)));
|
2019-04-10 18:21:22 +02:00
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.fetchPrecompiledHeader(25);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchPrecompiledHeaderIsBusy)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
2019-04-10 19:24:36 +02:00
|
|
|
EXPECT_CALL(fetchPrecompiledHeaderStatement, valueReturnFilePath(Eq(25)))
|
2019-04-10 18:21:22 +02:00
|
|
|
.WillOnce(Throw(Sqlite::StatementIsBusy{""}));
|
|
|
|
EXPECT_CALL(database, rollback());
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
2019-04-10 19:24:36 +02:00
|
|
|
EXPECT_CALL(fetchPrecompiledHeaderStatement, valueReturnFilePath(Eq(25)));
|
2019-04-10 18:21:22 +02:00
|
|
|
EXPECT_CALL(database, commit());
|
2019-02-22 16:44:40 +01:00
|
|
|
|
|
|
|
storage.fetchPrecompiledHeader(25);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchPrecompiledHeader)
|
|
|
|
{
|
2019-04-10 17:44:34 +02:00
|
|
|
ClangBackEnd::FilePath pchFilePath{"/path/to/pch"};
|
2019-04-10 19:24:36 +02:00
|
|
|
ON_CALL(fetchPrecompiledHeaderStatement, valueReturnFilePath(Eq(25)))
|
|
|
|
.WillByDefault(Return(pchFilePath));
|
2019-02-22 16:44:40 +01:00
|
|
|
|
2019-04-10 17:44:34 +02:00
|
|
|
auto path = storage.fetchPrecompiledHeader(25);
|
2019-02-22 16:44:40 +01:00
|
|
|
|
2019-04-10 17:44:34 +02:00
|
|
|
ASSERT_THAT(path, Eq(pchFilePath));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchEmptyPrecompiledHeader)
|
|
|
|
{
|
|
|
|
auto path = storage.fetchPrecompiledHeader(25);
|
|
|
|
|
|
|
|
ASSERT_THAT(path, IsEmpty());
|
2019-02-22 16:44:40 +01:00
|
|
|
}
|
2019-04-10 19:24:36 +02:00
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchPrecompiledHeaderCalls)
|
|
|
|
{
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
|
|
|
EXPECT_CALL(fetchPrecompiledHeadersStatement, valueReturnPchPaths(Eq(25)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.fetchPrecompiledHeaders(25);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchPrecompiledHeadersIsBusy)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
|
|
|
EXPECT_CALL(fetchPrecompiledHeadersStatement, valueReturnPchPaths(Eq(25)))
|
|
|
|
.WillOnce(Throw(Sqlite::StatementIsBusy{""}));
|
|
|
|
EXPECT_CALL(database, rollback());
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
|
|
|
EXPECT_CALL(fetchPrecompiledHeadersStatement, valueReturnPchPaths(Eq(25)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.fetchPrecompiledHeaders(25);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchPrecompiledHeaders)
|
|
|
|
{
|
|
|
|
ClangBackEnd::PchPaths pchFilePaths{"/project/pch", "/system/pch"};
|
|
|
|
ON_CALL(fetchPrecompiledHeadersStatement, valueReturnPchPaths(Eq(25)))
|
|
|
|
.WillByDefault(Return(pchFilePaths));
|
|
|
|
|
|
|
|
auto paths = storage.fetchPrecompiledHeaders(25);
|
|
|
|
|
|
|
|
ASSERT_THAT(paths, Eq(pchFilePaths));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchEmptyPrecompiledHeaders)
|
|
|
|
{
|
|
|
|
auto paths = storage.fetchPrecompiledHeaders(25);
|
|
|
|
|
|
|
|
ASSERT_THAT(paths,
|
|
|
|
AllOf(Field(&ClangBackEnd::PchPaths::projectPchPath, IsEmpty()),
|
|
|
|
Field(&ClangBackEnd::PchPaths::systemPchPath, IsEmpty())));
|
|
|
|
}
|
|
|
|
|
2019-07-25 15:01:25 +02:00
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchTimeStamps)
|
|
|
|
{
|
|
|
|
ClangBackEnd::PrecompiledHeaderTimeStamps precompiledHeaderTimeStamps{22, 33};
|
|
|
|
ON_CALL(fetchTimeStampsStatement, valuesReturnPrecompiledHeaderTimeStamps(Eq(23)))
|
|
|
|
.WillByDefault(Return(precompiledHeaderTimeStamps));
|
|
|
|
|
|
|
|
auto timeStamps = storage.fetchTimeStamps(23);
|
|
|
|
|
|
|
|
ASSERT_THAT(timeStamps,
|
|
|
|
AllOf(Field(&ClangBackEnd::PrecompiledHeaderTimeStamps::project, Eq(22)),
|
|
|
|
Field(&ClangBackEnd::PrecompiledHeaderTimeStamps::system, Eq(33))));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, NoFetchTimeStamps)
|
|
|
|
{
|
|
|
|
auto timeStamps = storage.fetchTimeStamps(23);
|
|
|
|
|
|
|
|
ASSERT_THAT(timeStamps,
|
|
|
|
AllOf(Field(&ClangBackEnd::PrecompiledHeaderTimeStamps::project, Eq(-1)),
|
|
|
|
Field(&ClangBackEnd::PrecompiledHeaderTimeStamps::system, Eq(-1))));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchTimeStampsCalls)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
|
|
|
EXPECT_CALL(fetchTimeStampsStatement, valuesReturnPrecompiledHeaderTimeStamps(Eq(23)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.fetchTimeStamps(23);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorage, FetchTimeStampsBusy)
|
|
|
|
{
|
|
|
|
InSequence s;
|
|
|
|
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
|
|
|
EXPECT_CALL(fetchTimeStampsStatement, valuesReturnPrecompiledHeaderTimeStamps(Eq(23)))
|
|
|
|
.WillOnce(Throw(Sqlite::StatementIsBusy{""}));
|
|
|
|
EXPECT_CALL(database, rollback());
|
|
|
|
EXPECT_CALL(database, deferredBegin());
|
|
|
|
EXPECT_CALL(fetchTimeStampsStatement, valuesReturnPrecompiledHeaderTimeStamps(Eq(23)));
|
|
|
|
EXPECT_CALL(database, commit());
|
|
|
|
|
|
|
|
storage.fetchTimeStamps(23);
|
|
|
|
}
|
|
|
|
|
|
|
|
class PrecompiledHeaderStorageSlowTest : public testing::Test
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
Sqlite::Database database{":memory:", Sqlite::JournalMode::Memory};
|
|
|
|
ClangBackEnd::RefactoringDatabaseInitializer<Sqlite::Database> initializer{database};
|
|
|
|
ClangBackEnd::PrecompiledHeaderStorage<> storage{database};
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(PrecompiledHeaderStorageSlowTest, NoFetchTimeStamps)
|
|
|
|
{
|
|
|
|
storage.insertProjectPrecompiledHeader(23, {}, 22);
|
|
|
|
storage.insertSystemPrecompiledHeaders({23}, {}, 33);
|
|
|
|
|
|
|
|
auto timeStamps = storage.fetchTimeStamps(23);
|
|
|
|
|
|
|
|
ASSERT_THAT(timeStamps,
|
|
|
|
AllOf(Field(&ClangBackEnd::PrecompiledHeaderTimeStamps::project, Eq(22)),
|
|
|
|
Field(&ClangBackEnd::PrecompiledHeaderTimeStamps::system, Eq(33))));
|
|
|
|
}
|
|
|
|
|
2019-04-10 18:21:22 +02:00
|
|
|
} // namespace
|