Files
qt-creator/tests/unit/unittest/mocksqlitestatement.h
Kai Köhne 56baf8c058 Remove GPL-3.0+ from license identifiers
Since we also license under GPL-3.0 WITH Qt-GPL-exception-1.0,
this applies only to a hypothetical newer version of GPL, that doesn't
exist yet. If such a version emerges, we can still decide to relicense...

While at it, replace (deprecated) GPL-3.0 with more explicit GPL-3.0-only

Change was done by running

  find . -type f -exec perl -pi -e "s/LicenseRef-Qt-Commercial OR GPL-3.0\+ OR GPL-3.0 WITH Qt-GPL-exception-1.0/LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0/g" {} \;

Change-Id: I5097e6ce8d10233993ee30d7e25120e2659eb10b
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
2023-01-06 11:15:13 +00:00

107 lines
2.9 KiB
C++

// Copyright (C) 2017 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#pragma once
#include "googletest.h"
#include "sqlitedatabasemock.h"
#include <sqlitebasestatement.h>
class BaseMockSqliteStatement
{
public:
using Database = SqliteDatabaseMock;
BaseMockSqliteStatement() = default;
BaseMockSqliteStatement(SqliteDatabaseMock &databaseMock)
: m_databaseMock{&databaseMock}
{}
MOCK_METHOD0(next, bool());
MOCK_METHOD0(step, void ());
MOCK_METHOD0(reset, void ());
MOCK_CONST_METHOD1(fetchIntValue, int (int));
MOCK_CONST_METHOD1(fetchLongValue, long (int));
MOCK_CONST_METHOD1(fetchLongLongValue, long long (int));
MOCK_CONST_METHOD1(fetchDoubleValue, double (int));
MOCK_CONST_METHOD1(fetchSmallStringValue, Utils::SmallString(int));
MOCK_CONST_METHOD1(fetchSmallStringViewValue, Utils::SmallStringView(int));
MOCK_CONST_METHOD1(fetchPathStringValue, Utils::PathString (int));
MOCK_CONST_METHOD1(fetchValueView, Sqlite::ValueView(int));
template<typename Type>
Type fetchValue(int column) const;
MOCK_METHOD2(bind, void (int, int));
MOCK_METHOD2(bind, void (int, long long));
MOCK_METHOD2(bind, void (int, double));
MOCK_METHOD2(bind, void (int, Utils::SmallStringView));
MOCK_METHOD2(bind, void (int, long));
MOCK_METHOD1(prepare, void(Utils::SmallStringView sqlStatement));
MOCK_METHOD1(checkColumnCount, void(int));
MOCK_METHOD1(checkBindingParameterCount, void(int));
MOCK_CONST_METHOD0(isReadOnlyStatement, bool());
SqliteDatabaseMock &database() { return *m_databaseMock; }
private:
SqliteDatabaseMock *m_databaseMock = nullptr;
};
template<>
int BaseMockSqliteStatement::fetchValue<int>(int column) const
{
return fetchIntValue(column);
}
template<>
long BaseMockSqliteStatement::fetchValue<long>(int column) const
{
return fetchLongValue(column);
}
template<>
long long BaseMockSqliteStatement::fetchValue<long long>(int column) const
{
return fetchLongLongValue(column);
}
template<>
double BaseMockSqliteStatement::fetchValue<double>(int column) const
{
return fetchDoubleValue(column);
}
template<>
Utils::SmallString BaseMockSqliteStatement::fetchValue<Utils::SmallString>(int column) const
{
return fetchSmallStringValue(column);
}
template<>
Utils::PathString BaseMockSqliteStatement::fetchValue<Utils::PathString>(int column) const
{
return fetchPathStringValue(column);
}
template<int ResultCount = 1, int BindParameterCount = 0>
class MockSqliteStatement
: public Sqlite::StatementImplementation<BaseMockSqliteStatement, ResultCount, BindParameterCount>
{
using Base = Sqlite::StatementImplementation<BaseMockSqliteStatement, ResultCount, BindParameterCount>;
public:
explicit MockSqliteStatement(SqliteDatabaseMock &databaseMock)
: Base{databaseMock}
{}
protected:
void checkIsWritableStatement();
};