| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | ** | 
					
						
							|  |  |  | ** Copyright (C) 2018 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"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-20 16:46:22 +02:00
										 |  |  | #include "mocksqlitedatabase.h"
 | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  | #include "mocktaskscheduler.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | #include <symbolindexertaskqueue.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using ClangBackEnd::FilePathId; | 
					
						
							| 
									
										
										
										
											2018-08-22 21:13:05 +02:00
										 |  |  | using ClangBackEnd::SymbolsCollectorInterface; | 
					
						
							|  |  |  | using ClangBackEnd::SymbolIndexerTask; | 
					
						
							|  |  |  | using ClangBackEnd::SymbolStorageInterface; | 
					
						
							| 
									
										
										
										
											2018-12-04 19:03:48 +01:00
										 |  |  | using ClangBackEnd::SlotUsage; | 
					
						
							| 
									
										
										
										
											2018-08-22 21:13:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | using Callable = ClangBackEnd::SymbolIndexerTask::Callable; | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | MATCHER_P2(IsTask, filePathId, projectPartId, | 
					
						
							|  |  |  |           std::string(negation ? "is't" : "is") | 
					
						
							| 
									
										
										
										
											2018-08-22 21:13:05 +02:00
										 |  |  |           + PrintToString(SymbolIndexerTask(filePathId, projectPartId, Callable{}))) | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     const SymbolIndexerTask &task = arg; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return task.filePathId == filePathId && task.projectPartId == projectPartId; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class SymbolIndexerTaskQueue : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							| 
									
										
										
										
											2018-09-27 17:52:44 +02:00
										 |  |  |     NiceMock<MockFunction<void(int, int)>> mockSetProgressCallback; | 
					
						
							|  |  |  |     ClangBackEnd::ProgressCounter progressCounter{mockSetProgressCallback.AsStdFunction()}; | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     NiceMock<MockTaskScheduler<Callable>> mockTaskScheduler; | 
					
						
							| 
									
										
										
										
											2019-05-20 16:46:22 +02:00
										 |  |  |     NiceMock<MockSqliteDatabase> mockSqliteDatabase; | 
					
						
							|  |  |  |     ClangBackEnd::SymbolIndexerTaskQueue queue{mockTaskScheduler, progressCounter, mockSqliteDatabase}; | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, AddTasks) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{2, 1, Callable{}}, | 
					
						
							|  |  |  |                             {4, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(queue.tasks(), | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |                 ElementsAre(IsTask(1, 1), | 
					
						
							|  |  |  |                             IsTask(2, 1), | 
					
						
							|  |  |  |                             IsTask(3, 1), | 
					
						
							|  |  |  |                             IsTask(4, 1), | 
					
						
							|  |  |  |                             IsTask(5, 1))); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-27 17:52:44 +02:00
										 |  |  | TEST_F(SymbolIndexerTaskQueue, AddTasksCallsProgressCounter) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-19 21:38:40 +02:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-09-27 17:52:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EXPECT_CALL(mockSetProgressCallback, Call(0, 4)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-19 21:38:40 +02:00
										 |  |  |     queue.addOrUpdateTasks({{2, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-09-27 17:52:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | TEST_F(SymbolIndexerTaskQueue, ReplaceTask) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{2, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(queue.tasks(), | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |                 ElementsAre(IsTask(1, 1), | 
					
						
							|  |  |  |                             IsTask(2, 1), | 
					
						
							|  |  |  |                             IsTask(3, 1), | 
					
						
							|  |  |  |                             IsTask(5, 1))); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, AddTaskWithDifferentProjectId) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{2, 2, Callable{}}, | 
					
						
							|  |  |  |                             {3, 2, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(queue.tasks(), | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |                 ElementsAre(IsTask(1, 1), | 
					
						
							|  |  |  |                             IsTask(2, 2), | 
					
						
							|  |  |  |                             IsTask(3, 1), | 
					
						
							|  |  |  |                             IsTask(3, 2), | 
					
						
							|  |  |  |                             IsTask(5, 1))); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, RemoveTaskByProjectParts) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							|  |  |  |     queue.addOrUpdateTasks({{2, 2, Callable{}}, | 
					
						
							|  |  |  |                             {3, 2, Callable{}}}); | 
					
						
							|  |  |  |     queue.addOrUpdateTasks({{2, 3, Callable{}}, | 
					
						
							|  |  |  |                             {3, 3, Callable{}}}); | 
					
						
							|  |  |  |     queue.addOrUpdateTasks({{2, 4, Callable{}}, | 
					
						
							|  |  |  |                             {3, 4, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-30 16:18:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     queue.removeTasks({2, 3}); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(queue.tasks(), | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |                 ElementsAre(IsTask(1, 1), | 
					
						
							|  |  |  |                             IsTask(2, 4), | 
					
						
							|  |  |  |                             IsTask(3, 1), | 
					
						
							|  |  |  |                             IsTask(3, 4), | 
					
						
							|  |  |  |                             IsTask(5, 1))); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-27 17:52:44 +02:00
										 |  |  | TEST_F(SymbolIndexerTaskQueue, RemoveTasksCallsProgressCounter) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-19 21:38:40 +02:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							|  |  |  |     queue.addOrUpdateTasks({{2, 2, Callable{}}, | 
					
						
							|  |  |  |                             {3, 2, Callable{}}}); | 
					
						
							|  |  |  |     queue.addOrUpdateTasks({{2, 3, Callable{}}, | 
					
						
							|  |  |  |                             {3, 3, Callable{}}}); | 
					
						
							|  |  |  |     queue.addOrUpdateTasks({{2, 4, Callable{}}, | 
					
						
							|  |  |  |                             {3, 4, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-09-27 17:52:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EXPECT_CALL(mockSetProgressCallback, Call(0, 5)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     queue.removeTasks({2, 3}); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | TEST_F(SymbolIndexerTaskQueue, ProcessTasksCallsFreeSlotsAndAddTasksInScheduler) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     InSequence s; | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:03:48 +01:00
										 |  |  |     EXPECT_CALL(mockTaskScheduler, slotUsage()).WillRepeatedly(Return(SlotUsage{2, 0})); | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     EXPECT_CALL(mockTaskScheduler, addTasks(SizeIs(2))); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     queue.processEntries(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, ProcessTasksCallsFreeSlotsAndAddTasksWithNoTaskInSchedulerIfTaskAreEmpty) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     InSequence s; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:03:48 +01:00
										 |  |  |     EXPECT_CALL(mockTaskScheduler, slotUsage()).WillRepeatedly(Return(SlotUsage{2, 0})); | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     EXPECT_CALL(mockTaskScheduler, addTasks(IsEmpty())); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     queue.processEntries(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, ProcessTasksCallsFreeSlotsAndMoveAllTasksInSchedulerIfMoreSlotsAreFree) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     InSequence s; | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:03:48 +01:00
										 |  |  |     EXPECT_CALL(mockTaskScheduler, slotUsage()).WillRepeatedly(Return(SlotUsage{4, 0})); | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     EXPECT_CALL(mockTaskScheduler, addTasks(SizeIs(3))); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     queue.processEntries(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, ProcessTasksRemovesProcessedTasks) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     queue.addOrUpdateTasks({{1, 1, Callable{}}, | 
					
						
							|  |  |  |                             {3, 1, Callable{}}, | 
					
						
							|  |  |  |                             {5, 1, Callable{}}}); | 
					
						
							| 
									
										
										
										
											2018-12-04 19:03:48 +01:00
										 |  |  |     ON_CALL(mockTaskScheduler, slotUsage()).WillByDefault(Return(SlotUsage{2, 0})); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 17:02:45 +02:00
										 |  |  |     queue.processEntries(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:08:37 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ASSERT_THAT(queue.tasks(), SizeIs(1)); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-05-20 16:46:22 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, | 
					
						
							|  |  |  |        ProcessTasksWritesBackTheDatabaseLogIfTheQueueIsEmptyAndTheIndexerHasNothingToDo) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     InSequence s; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EXPECT_CALL(mockTaskScheduler, slotUsage()).WillRepeatedly(Return(SlotUsage{2, 0})); | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, walCheckpointFull()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     queue.processEntries(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, ProcessTasksDoesNotWritesBackTheDatabaseLogIfTheIndexerHasSomethingToDo) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     InSequence s; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EXPECT_CALL(mockTaskScheduler, slotUsage()).WillRepeatedly(Return(SlotUsage{1, 1})); | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, walCheckpointFull()).Times(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     queue.processEntries(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(SymbolIndexerTaskQueue, HandleExeptionInWalCheckPoint) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     InSequence s; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EXPECT_CALL(mockTaskScheduler, slotUsage()).WillRepeatedly(Return(SlotUsage{2, 0})); | 
					
						
							|  |  |  |     EXPECT_CALL(mockSqliteDatabase, walCheckpointFull()).WillOnce(Throw(Sqlite::DatabaseIsBusy{""})); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     queue.processEntries(); | 
					
						
							| 
									
										
										
										
											2018-08-22 17:20:08 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2019-05-20 16:46:22 +02:00
										 |  |  | } // namespace
 |