| 
									
										
										
										
											2017-09-21 11:43:59 +02: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 "mockmutex.h"
 | 
					
						
							|  |  |  | #include "mocksqlitedatabase.h"
 | 
					
						
							|  |  |  | #include "mocksqlitereadstatement.h"
 | 
					
						
							|  |  |  | #include "mocksqlitewritestatement.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <filepathstoragesqlitestatementfactory.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-20 12:43:05 +01:00
										 |  |  | using StatementFactory = ClangBackEnd::FilePathStorageSqliteStatementFactory<NiceMock<MockSqliteDatabase>>; | 
					
						
							| 
									
										
										
										
											2017-09-21 11:43:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | class FilePathStorageSqliteStatementFactory : public testing::Test | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | protected: | 
					
						
							| 
									
										
										
										
											2018-01-22 14:21:01 +01:00
										 |  |  |     NiceMock<MockSqliteDatabase> mockDatabase; | 
					
						
							| 
									
										
										
										
											2017-09-21 11:43:59 +02:00
										 |  |  |     StatementFactory factory{mockDatabase}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, SelectDirectoryIdFromDirectoriesByDirectoryPath) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.selectDirectoryIdFromDirectoriesByDirectoryPath.sqlStatement, | 
					
						
							|  |  |  |                 Eq("SELECT directoryId FROM directories WHERE directoryPath = ?")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, SelectDirectoryPathFromDirectoriesByDirectoryId) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.selectDirectoryPathFromDirectoriesByDirectoryId.sqlStatement, | 
					
						
							|  |  |  |                 Eq("SELECT directoryPath FROM directories WHERE directoryId = ?")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, SelectSourceIdFromSourcesByDirectoryIdAndSourceName) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.selectSourceIdFromSourcesByDirectoryIdAndSourceName.sqlStatement, | 
					
						
							|  |  |  |                 Eq("SELECT sourceId FROM sources WHERE directoryId = ? AND sourceName = ?")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, SelectSourceNameFromSourcesByDirectoryIdAndSourceId) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-06 19:02:00 +01:00
										 |  |  |     ASSERT_THAT(factory.selectSourceNameAndDirectoryIdFromSourcesBySourceId.sqlStatement, | 
					
						
							|  |  |  |                 Eq("SELECT sourceName, directoryId FROM sources WHERE sourceId = ?")); | 
					
						
							| 
									
										
										
										
											2017-09-21 11:43:59 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, SelectAllDirectories) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.selectAllDirectories.sqlStatement, | 
					
						
							|  |  |  |                 Eq("SELECT directoryId, directoryPath FROM directories")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, InsertIntoDirectories) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.insertIntoDirectories.sqlStatement, | 
					
						
							|  |  |  |                 Eq("INSERT INTO directories(directoryPath) VALUES (?)")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, InsertIntoSources) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.insertIntoSources.sqlStatement, | 
					
						
							|  |  |  |                 Eq("INSERT INTO sources(directoryId, sourceName) VALUES (?,?)")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST_F(FilePathStorageSqliteStatementFactory, SelectAllSources) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ASSERT_THAT(factory.selectAllSources.sqlStatement, | 
					
						
							|  |  |  |                 Eq("SELECT sourceId, sourceName FROM sources")); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |