| 
									
										
										
										
											2020-05-12 12:54:18 +02:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | ** | 
					
						
							|  |  |  | ** Copyright (C) 2020 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 <lastchangedrowid.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LastChangedRowId : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     NiceMock<MockSqliteDatabase> mockSqliteDatabase; | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, SetUpdateHookInContructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, ResetUpdateHookInDestructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, resetUpdateHook()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, GetMinusOneAsRowIdIfNoCallbackWasCalled) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, CallbackSetsLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, CallbackChecksDatabaseName) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-05-12 17:05:33 +02:00
										 |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 12:54:18 +02:00
										 |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 17:05:33 +02:00
										 |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							| 
									
										
										
										
											2020-05-12 12:54:18 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, CallbackChecksTableName) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-05-12 17:05:33 +02:00
										 |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 12:54:18 +02:00
										 |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 17:05:33 +02:00
										 |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							| 
									
										
										
										
											2020-05-12 12:54:18 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, LastCallSetsRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Insert, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Delete, "main", "foo", 66); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 66); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, TakeLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowId, TakeLastRowIdResetsRowIdToMinusOne) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 17:05:33 +02:00
										 |  |  | class LastChangedRowIdWithTwoTables : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     NiceMock<MockSqliteDatabase> mockSqliteDatabase; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo", "bar"}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, SetUpdateHookInContructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, ResetUpdateHookInDestructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, resetUpdateHook()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, GetMinusOneAsRowIdIfNoCallbackWasCalled) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, CallbackSetsLastRowIdFirstTable) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, CallbackSetsLastRowIdSecondTable) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 66); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 66); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, CallbackChecksDatabaseName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, CallbackChecksTableName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "zoo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, LastCallSetsRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Delete, "main", "bar", 66); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 66); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithTwoTables, TakeLastRowIdResetsRowIdToMinusOne) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LastChangedRowIdWithThreeTables : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     NiceMock<MockSqliteDatabase> mockSqliteDatabase; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo", "bar", "too"}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, SetUpdateHookInContructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, ResetUpdateHookInDestructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, resetUpdateHook()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, GetMinusOneAsRowIdIfNoCallbackWasCalled) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdFirstTable) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdSecondTable) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, CallbackSetsLastRowIdThirdTable) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "too", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, CallbackChecksDatabaseName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, CallbackChecksTableName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "zoo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, LastCallSetsRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42); | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Insert, "main", "too", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Delete, "main", "too", 66); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 66); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithThreeTables, TakeLastRowIdResetsRowIdToMinusOne) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-16 14:53:58 +02:00
										 |  |  | class LastChangedRowIdWithNoDatabaseAndTable : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     NiceMock<MockSqliteDatabase> mockSqliteDatabase; | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, SetUpdateHookInContructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, ResetUpdateHookInDestructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, resetUpdateHook()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, GetMinusOneAsRowIdIfNoCallbackWasCalled) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackSetsLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackDoNotChecksDatabaseName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, CallbackDoNotChecksTableName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, LastCallSetsRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Insert, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Delete, "main", "foo", 66); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 66); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoDatabaseAndTable, TakeLastRowIdResetsRowIdToMinusOne) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LastChangedRowIdWithNoTable : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     NiceMock<MockSqliteDatabase> mockSqliteDatabase; | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, SetUpdateHookInContructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, setUpdateHook(_)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Sqlite::LastChangedRowId lastRowId{mockSqliteDatabase, "main", "foo"}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, ResetUpdateHookInDestructor) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, resetUpdateHook()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, GetMinusOneAsRowIdIfNoCallbackWasCalled) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, -1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, CallbackSetsLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, CallbackChecksDatabaseName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "temp", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 33); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, CallbackDoNotChecksTableName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "bar", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, LastCallSetsRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Insert, "main", "foo", 33); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Delete, "main", "foo", 66); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(lastRowId.lastRowId, 66); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, TakeLastRowId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, 42); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(LastChangedRowIdWithNoTable, TakeLastRowIdResetsRowIdToMinusOne) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     lastRowId.callback(Sqlite::ChangeType::Update, "main", "foo", 42); | 
					
						
							|  |  |  |     lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     auto id = lastRowId.takeLastRowId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(id, -1); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-05-12 12:54:18 +02:00
										 |  |  | } // namespace
 |