forked from qt-creator/qt-creator
		
	With C++ 17 it is possible to deduce the template argument from the contructor parameter(CTAD). We then do not call anymore a virtual function but a normal function. Change-Id: I61c3ce22322c66b256afab278e768014401b08cc Reviewed-by: Tim Jenssen <tim.jenssen@qt.io> Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
		
			
				
	
	
		
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /****************************************************************************
 | |
| **
 | |
| ** 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.
 | |
| **
 | |
| ****************************************************************************/
 | |
| 
 | |
| #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();
 | |
| };
 |