mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 20:33:53 +01:00 
			
		
		
		
	Refactor BookmarkLocationControllerTest and related files to use coroutines
* Migrated `bookmarkDao!!.getAllBookmarksLocations()` to `bookmarkDao!!.getAllBookmarksLocationsPlace()` and added `runBlocking` * Added `runBlocking` for `loadBookmarkedLocations()` and `testInitNonEmpty()` * Added `runBlocking` for `getAllBookmarksLocations()` and update `updateMapMarkers` These changes improve the test structure by ensuring the database functions are executed within a coroutine context.
This commit is contained in:
		
							parent
							
								
									32f7b4c887
								
							
						
					
					
						commit
						5940f92f01
					
				
					 5 changed files with 83 additions and 291 deletions
				
			
		|  | @ -7,44 +7,59 @@ import androidx.room.OnConflictStrategy | ||||||
| import androidx.room.Query | import androidx.room.Query | ||||||
| import fr.free.nrw.commons.nearby.NearbyController | import fr.free.nrw.commons.nearby.NearbyController | ||||||
| import fr.free.nrw.commons.nearby.Place | import fr.free.nrw.commons.nearby.Place | ||||||
| import kotlinx.coroutines.flow.Flow |  | ||||||
| import kotlinx.coroutines.flow.flow |  | ||||||
| import kotlinx.coroutines.flow.map |  | ||||||
| 
 | 
 | ||||||
|  | /** | ||||||
|  |  * DAO for managing bookmark locations in the database. | ||||||
|  |  */ | ||||||
| @Dao | @Dao | ||||||
| abstract class BookmarkLocationsDao { | abstract class BookmarkLocationsDao { | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Adds or updates a bookmark location in the database. | ||||||
|  |      */ | ||||||
|     @Insert(onConflict = OnConflictStrategy.REPLACE) |     @Insert(onConflict = OnConflictStrategy.REPLACE) | ||||||
|     abstract suspend fun addBookmarkLocation(bookmarkLocation: BookmarksLocations) |     abstract suspend fun addBookmarkLocation(bookmarkLocation: BookmarksLocations) | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Fetches all bookmark locations from the database. | ||||||
|  |      */ | ||||||
|     @Query("SELECT * FROM bookmarks_locations") |     @Query("SELECT * FROM bookmarks_locations") | ||||||
|     abstract suspend fun getAllBookmarksLocations(): List<BookmarksLocations> |     abstract suspend fun getAllBookmarksLocations(): List<BookmarksLocations> | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Checks if a bookmark location exists by name. | ||||||
|  |      */ | ||||||
|     @Query("SELECT EXISTS (SELECT 1 FROM bookmarks_locations WHERE location_name = :name)") |     @Query("SELECT EXISTS (SELECT 1 FROM bookmarks_locations WHERE location_name = :name)") | ||||||
|     abstract suspend fun findBookmarkLocation(name: String): Boolean |     abstract suspend fun findBookmarkLocation(name: String): Boolean | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Deletes a bookmark location from the database. | ||||||
|  |      */ | ||||||
|     @Delete |     @Delete | ||||||
|     abstract suspend fun deleteBookmarkLocation(bookmarkLocation: BookmarksLocations) |     abstract suspend fun deleteBookmarkLocation(bookmarkLocation: BookmarksLocations) | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Adds or removes a bookmark location and updates markers. | ||||||
|  |      * @return `true` if added, `false` if removed. | ||||||
|  |      */ | ||||||
|     suspend fun updateBookmarkLocation(bookmarkLocation: Place): Boolean { |     suspend fun updateBookmarkLocation(bookmarkLocation: Place): Boolean { | ||||||
|         val bookmarkLocationExists = findBookmarkLocation(bookmarkLocation.name) |         val exists = findBookmarkLocation(bookmarkLocation.name) | ||||||
| 
 | 
 | ||||||
|         if(bookmarkLocationExists) { |         if (exists) { | ||||||
|             deleteBookmarkLocation( |             deleteBookmarkLocation(bookmarkLocation.toBookmarksLocations()) | ||||||
|                 bookmarkLocation.toBookmarksLocations() |  | ||||||
|             ) |  | ||||||
|             NearbyController.updateMarkerLabelListBookmark(bookmarkLocation, false) |             NearbyController.updateMarkerLabelListBookmark(bookmarkLocation, false) | ||||||
|         } else { |         } else { | ||||||
|             addBookmarkLocation( |             addBookmarkLocation(bookmarkLocation.toBookmarksLocations()) | ||||||
|                 bookmarkLocation.toBookmarksLocations() |  | ||||||
|             ) |  | ||||||
|             NearbyController.updateMarkerLabelListBookmark(bookmarkLocation, true) |             NearbyController.updateMarkerLabelListBookmark(bookmarkLocation, true) | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return !bookmarkLocationExists |         return !exists | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Fetches all bookmark locations as `Place` objects. | ||||||
|  |      */ | ||||||
|     suspend fun getAllBookmarksLocationsPlace(): List<Place> { |     suspend fun getAllBookmarksLocationsPlace(): List<Place> { | ||||||
|         return getAllBookmarksLocations().map { it.toPlace() } |         return getAllBookmarksLocations().map { it.toPlace() } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -7,6 +7,8 @@ import android.database.MatrixCursor | ||||||
| import android.database.sqlite.SQLiteDatabase | import android.database.sqlite.SQLiteDatabase | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.os.RemoteException | import android.os.RemoteException | ||||||
|  | import androidx.room.Room | ||||||
|  | import androidx.test.core.app.ApplicationProvider | ||||||
| import com.nhaarman.mockitokotlin2.any | import com.nhaarman.mockitokotlin2.any | ||||||
| import com.nhaarman.mockitokotlin2.anyOrNull | import com.nhaarman.mockitokotlin2.anyOrNull | ||||||
| import com.nhaarman.mockitokotlin2.argumentCaptor | import com.nhaarman.mockitokotlin2.argumentCaptor | ||||||
|  | @ -18,35 +20,20 @@ import com.nhaarman.mockitokotlin2.mock | ||||||
| import com.nhaarman.mockitokotlin2.verify | import com.nhaarman.mockitokotlin2.verify | ||||||
| import com.nhaarman.mockitokotlin2.whenever | import com.nhaarman.mockitokotlin2.whenever | ||||||
| import fr.free.nrw.commons.TestCommonsApplication | import fr.free.nrw.commons.TestCommonsApplication | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_CATEGORY | import fr.free.nrw.commons.db.AppDatabase | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_COMMONS_LINK |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_DESCRIPTION |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_EXISTS |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_IMAGE_URL |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_LABEL_ICON |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_LABEL_TEXT |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_LANGUAGE |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_LAT |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_LONG |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_NAME |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_PIC |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_WIKIDATA_LINK |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.COLUMN_WIKIPEDIA_LINK |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.CREATE_TABLE_STATEMENT |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.DROP_TABLE_STATEMENT |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.onCreate |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.onDelete |  | ||||||
| import fr.free.nrw.commons.bookmarks.locations.BookmarkLocationsDao.Table.onUpdate |  | ||||||
| import fr.free.nrw.commons.location.LatLng | import fr.free.nrw.commons.location.LatLng | ||||||
| import fr.free.nrw.commons.nearby.Label | import fr.free.nrw.commons.nearby.Label | ||||||
| import fr.free.nrw.commons.nearby.Place | import fr.free.nrw.commons.nearby.Place | ||||||
| import fr.free.nrw.commons.nearby.Sitelinks | import fr.free.nrw.commons.nearby.Sitelinks | ||||||
|  | import kotlinx.coroutines.runBlocking | ||||||
|  | import org.junit.After | ||||||
| import org.junit.Assert.assertEquals | import org.junit.Assert.assertEquals | ||||||
| import org.junit.Assert.assertFalse | import org.junit.Assert.assertFalse | ||||||
| import org.junit.Assert.assertTrue | import org.junit.Assert.assertTrue | ||||||
| import org.junit.Before | import org.junit.Before | ||||||
| import org.junit.Test | import org.junit.Test | ||||||
| import org.junit.runner.RunWith | import org.junit.runner.RunWith | ||||||
|  | import org.mockito.Mock | ||||||
| import org.mockito.Mockito.verifyNoInteractions | import org.mockito.Mockito.verifyNoInteractions | ||||||
| import org.robolectric.RobolectricTestRunner | import org.robolectric.RobolectricTestRunner | ||||||
| import org.robolectric.annotation.Config | import org.robolectric.annotation.Config | ||||||
|  | @ -54,28 +41,12 @@ import org.robolectric.annotation.Config | ||||||
| @RunWith(RobolectricTestRunner::class) | @RunWith(RobolectricTestRunner::class) | ||||||
| @Config(sdk = [21], application = TestCommonsApplication::class) | @Config(sdk = [21], application = TestCommonsApplication::class) | ||||||
| class BookMarkLocationDaoTest { | class BookMarkLocationDaoTest { | ||||||
|     private val columns = |  | ||||||
|         arrayOf( |  | ||||||
|             COLUMN_NAME, |  | ||||||
|             COLUMN_LANGUAGE, |  | ||||||
|             COLUMN_DESCRIPTION, |  | ||||||
|             COLUMN_CATEGORY, |  | ||||||
|             COLUMN_LABEL_TEXT, |  | ||||||
|             COLUMN_LABEL_ICON, |  | ||||||
|             COLUMN_IMAGE_URL, |  | ||||||
|             COLUMN_WIKIPEDIA_LINK, |  | ||||||
|             COLUMN_WIKIDATA_LINK, |  | ||||||
|             COLUMN_COMMONS_LINK, |  | ||||||
|             COLUMN_LAT, |  | ||||||
|             COLUMN_LONG, |  | ||||||
|             COLUMN_PIC, |  | ||||||
|             COLUMN_EXISTS, |  | ||||||
|         ) |  | ||||||
|     private val client: ContentProviderClient = mock() |  | ||||||
|     private val database: SQLiteDatabase = mock() |  | ||||||
|     private val captor = argumentCaptor<ContentValues>() |  | ||||||
| 
 | 
 | ||||||
|     private lateinit var testObject: BookmarkLocationsDao |     @Mock | ||||||
|  |     var bookmarkLocationsDao: BookmarkLocationsDao? = null | ||||||
|  | 
 | ||||||
|  |     private lateinit var database: AppDatabase | ||||||
|  | 
 | ||||||
|     private lateinit var examplePlaceBookmark: Place |     private lateinit var examplePlaceBookmark: Place | ||||||
|     private lateinit var exampleLabel: Label |     private lateinit var exampleLabel: Label | ||||||
|     private lateinit var exampleUri: Uri |     private lateinit var exampleUri: Uri | ||||||
|  | @ -88,10 +59,18 @@ class BookMarkLocationDaoTest { | ||||||
|         exampleUri = Uri.parse("wikimedia/uri") |         exampleUri = Uri.parse("wikimedia/uri") | ||||||
|         exampleLocation = LatLng(40.0, 51.4, 1f) |         exampleLocation = LatLng(40.0, 51.4, 1f) | ||||||
| 
 | 
 | ||||||
|         builder = Sitelinks.Builder() |         database = Room.inMemoryDatabaseBuilder( | ||||||
|         builder.setWikipediaLink("wikipediaLink") |             ApplicationProvider.getApplicationContext(), | ||||||
|         builder.setWikidataLink("wikidataLink") |             AppDatabase::class.java | ||||||
|         builder.setCommonsLink("commonsLink") |         ).allowMainThreadQueries().build() | ||||||
|  | 
 | ||||||
|  |         bookmarkLocationsDao = database.bookmarkLocationsDao() | ||||||
|  | 
 | ||||||
|  |         builder = Sitelinks.Builder().apply { | ||||||
|  |             setWikipediaLink("wikipediaLink") | ||||||
|  |             setWikidataLink("wikidataLink") | ||||||
|  |             setCommonsLink("commonsLink") | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         examplePlaceBookmark = |         examplePlaceBookmark = | ||||||
|             Place( |             Place( | ||||||
|  | @ -105,236 +84,25 @@ class BookMarkLocationDaoTest { | ||||||
|                 "picName", |                 "picName", | ||||||
|                 false, |                 false, | ||||||
|             ) |             ) | ||||||
|         testObject = BookmarkLocationsDao { client } |     } | ||||||
|  | 
 | ||||||
|  |     @After | ||||||
|  |     fun tearDown() { | ||||||
|  |         database.close() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     fun createTable() { |     fun insertAndRetrieveBookmark() = runBlocking { | ||||||
|         onCreate(database) |         // Insert a bookmark | ||||||
|         verify(database).execSQL(CREATE_TABLE_STATEMENT) |         bookmarkLocationsDao?.addBookmarkLocation(examplePlaceBookmark.toBookmarksLocations()) | ||||||
|  | 
 | ||||||
|  |         // Retrieve all bookmarks | ||||||
|  |         val bookmarks = bookmarkLocationsDao?.getAllBookmarksLocations() | ||||||
|  | 
 | ||||||
|  |         // Assert the bookmark exists | ||||||
|  |         assertEquals(1, bookmarks?.size) | ||||||
|  |         val retrievedBookmark = bookmarks?.first() | ||||||
|  |         assertEquals(examplePlaceBookmark.name, retrievedBookmark?.locationName) | ||||||
|  |         assertEquals(examplePlaceBookmark.language, retrievedBookmark?.locationLanguage) | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun deleteTable() { |  | ||||||
|         onDelete(database) |  | ||||||
|         inOrder(database) { |  | ||||||
|             verify(database).execSQL(DROP_TABLE_STATEMENT) |  | ||||||
|             verify(database).execSQL(CREATE_TABLE_STATEMENT) |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun createFromCursor() { |  | ||||||
|         createCursor(1).let { cursor -> |  | ||||||
|             cursor.moveToFirst() |  | ||||||
|             testObject.fromCursor(cursor).let { |  | ||||||
|                 assertEquals("en", it.language) |  | ||||||
|                 assertEquals("placeName", it.name) |  | ||||||
|                 assertEquals(Label.FOREST, it.label) |  | ||||||
|                 assertEquals("placeDescription", it.longDescription) |  | ||||||
|                 assertEquals(40.0, it.location.latitude, 0.001) |  | ||||||
|                 assertEquals(51.4, it.location.longitude, 0.001) |  | ||||||
|                 assertEquals("placeCategory", it.category) |  | ||||||
|                 assertEquals(builder.build().wikipediaLink, it.siteLinks.wikipediaLink) |  | ||||||
|                 assertEquals(builder.build().wikidataLink, it.siteLinks.wikidataLink) |  | ||||||
|                 assertEquals(builder.build().commonsLink, it.siteLinks.commonsLink) |  | ||||||
|                 assertEquals("picName", it.pic) |  | ||||||
|                 assertEquals(false, it.exists) |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun getAllLocationBookmarks() { |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenReturn(createCursor(14)) |  | ||||||
| 
 |  | ||||||
|         var result = testObject.getAllBookmarksLocations() |  | ||||||
| 
 |  | ||||||
|         assertEquals(14, result.size) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test(expected = RuntimeException::class) |  | ||||||
|     fun getAllLocationBookmarksTranslatesExceptions() { |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenThrow(RemoteException("")) |  | ||||||
|         testObject.getAllBookmarksLocations() |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun getAllLocationBookmarksReturnsEmptyList_emptyCursor() { |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenReturn(createCursor(0)) |  | ||||||
|         assertTrue(testObject.getAllBookmarksLocations().isEmpty()) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun getAllLocationBookmarksReturnsEmptyList_nullCursor() { |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenReturn(null) |  | ||||||
|         assertTrue(testObject.getAllBookmarksLocations().isEmpty()) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun cursorsAreClosedAfterGetAllLocationBookmarksQuery() { |  | ||||||
|         val mockCursor: Cursor = mock() |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenReturn(mockCursor) |  | ||||||
|         whenever(mockCursor.moveToFirst()).thenReturn(false) |  | ||||||
| 
 |  | ||||||
|         testObject.getAllBookmarksLocations() |  | ||||||
| 
 |  | ||||||
|         verify(mockCursor).close() |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun updateNewLocationBookmark() { |  | ||||||
|         whenever(client.insert(any(), any())).thenReturn(Uri.EMPTY) |  | ||||||
|         whenever(client.query(any(), any(), any(), any(), anyOrNull())).thenReturn(null) |  | ||||||
| 
 |  | ||||||
|         assertTrue(testObject.updateBookmarkLocation(examplePlaceBookmark)) |  | ||||||
|         verify(client).insert(eq(BookmarkLocationsContentProvider.BASE_URI), captor.capture()) |  | ||||||
|         captor.firstValue.let { cv -> |  | ||||||
|             assertEquals(13, cv.size()) |  | ||||||
|             assertEquals(examplePlaceBookmark.name, cv.getAsString(COLUMN_NAME)) |  | ||||||
|             assertEquals(examplePlaceBookmark.language, cv.getAsString(COLUMN_LANGUAGE)) |  | ||||||
|             assertEquals(examplePlaceBookmark.longDescription, cv.getAsString(COLUMN_DESCRIPTION)) |  | ||||||
|             assertEquals(examplePlaceBookmark.label.text, cv.getAsString(COLUMN_LABEL_TEXT)) |  | ||||||
|             assertEquals(examplePlaceBookmark.category, cv.getAsString(COLUMN_CATEGORY)) |  | ||||||
|             assertEquals(examplePlaceBookmark.location.latitude, cv.getAsDouble(COLUMN_LAT), 0.001) |  | ||||||
|             assertEquals(examplePlaceBookmark.location.longitude, cv.getAsDouble(COLUMN_LONG), 0.001) |  | ||||||
|             assertEquals(examplePlaceBookmark.siteLinks.wikipediaLink.toString(), cv.getAsString(COLUMN_WIKIPEDIA_LINK)) |  | ||||||
|             assertEquals(examplePlaceBookmark.siteLinks.wikidataLink.toString(), cv.getAsString(COLUMN_WIKIDATA_LINK)) |  | ||||||
|             assertEquals(examplePlaceBookmark.siteLinks.commonsLink.toString(), cv.getAsString(COLUMN_COMMONS_LINK)) |  | ||||||
|             assertEquals(examplePlaceBookmark.pic, cv.getAsString(COLUMN_PIC)) |  | ||||||
|             assertEquals(examplePlaceBookmark.exists.toString(), cv.getAsString(COLUMN_EXISTS)) |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun updateExistingLocationBookmark() { |  | ||||||
|         whenever(client.delete(isA(), isNull(), isNull())).thenReturn(1) |  | ||||||
|         whenever(client.query(any(), any(), any(), any(), anyOrNull())).thenReturn(createCursor(1)) |  | ||||||
| 
 |  | ||||||
|         assertFalse(testObject.updateBookmarkLocation(examplePlaceBookmark)) |  | ||||||
|         verify(client).delete(eq(BookmarkLocationsContentProvider.uriForName(examplePlaceBookmark.name)), isNull(), isNull()) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun findExistingLocationBookmark() { |  | ||||||
|         whenever(client.query(any(), any(), any(), any(), anyOrNull())).thenReturn(createCursor(1)) |  | ||||||
|         assertTrue(testObject.findBookmarkLocation(examplePlaceBookmark)) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test(expected = RuntimeException::class) |  | ||||||
|     fun findLocationBookmarkTranslatesExceptions() { |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenThrow(RemoteException("")) |  | ||||||
|         testObject.findBookmarkLocation(examplePlaceBookmark) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun findNotExistingLocationBookmarkReturnsNull_emptyCursor() { |  | ||||||
|         whenever(client.query(any(), any(), any(), any(), anyOrNull())).thenReturn(createCursor(0)) |  | ||||||
|         assertFalse(testObject.findBookmarkLocation(examplePlaceBookmark)) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun findNotExistingLocationBookmarkReturnsNull_nullCursor() { |  | ||||||
|         whenever(client.query(any(), any(), any(), any(), anyOrNull())).thenReturn(null) |  | ||||||
|         assertFalse(testObject.findBookmarkLocation(examplePlaceBookmark)) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun cursorsAreClosedAfterFindLocationBookmarkQuery() { |  | ||||||
|         val mockCursor: Cursor = mock() |  | ||||||
|         whenever(client.query(any(), any(), anyOrNull(), any(), anyOrNull())).thenReturn(mockCursor) |  | ||||||
|         whenever(mockCursor.moveToFirst()).thenReturn(false) |  | ||||||
| 
 |  | ||||||
|         testObject.findBookmarkLocation(examplePlaceBookmark) |  | ||||||
| 
 |  | ||||||
|         verify(mockCursor).close() |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v1_to_v2() { |  | ||||||
|         onUpdate(database, 1, 2) |  | ||||||
|         // Table didn't exist before v5 |  | ||||||
|         verifyNoInteractions(database) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v2_to_v3() { |  | ||||||
|         onUpdate(database, 2, 3) |  | ||||||
|         // Table didn't exist before v5 |  | ||||||
|         verifyNoInteractions(database) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v3_to_v4() { |  | ||||||
|         onUpdate(database, 3, 4) |  | ||||||
|         // Table didnt exist before v5 |  | ||||||
|         verifyNoInteractions(database) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v4_to_v5() { |  | ||||||
|         onUpdate(database, 4, 5) |  | ||||||
|         // Table didnt change in version 5 |  | ||||||
|         verifyNoInteractions(database) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v5_to_v6() { |  | ||||||
|         onUpdate(database, 5, 6) |  | ||||||
|         // Table didnt change in version 6 |  | ||||||
|         verifyNoInteractions(database) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v6_to_v7() { |  | ||||||
|         onUpdate(database, 6, 7) |  | ||||||
|         // Table didnt change in version 7 |  | ||||||
|         verifyNoInteractions(database) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v7_to_v8() { |  | ||||||
|         onUpdate(database, 7, 8) |  | ||||||
|         verify(database).execSQL(CREATE_TABLE_STATEMENT) |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v12_to_v13() { |  | ||||||
|         onUpdate(database, 12, 13) |  | ||||||
|         verify(database).execSQL("ALTER TABLE bookmarksLocations ADD COLUMN location_destroyed STRING;") |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v13_to_v14() { |  | ||||||
|         onUpdate(database, 13, 14) |  | ||||||
|         verify(database).execSQL("ALTER TABLE bookmarksLocations ADD COLUMN location_language STRING;") |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     fun migrateTableVersionFrom_v14_to_v15() { |  | ||||||
|         onUpdate(database, 14, 15) |  | ||||||
|         verify(database).execSQL("ALTER TABLE bookmarksLocations ADD COLUMN location_exists STRING;") |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private fun createCursor(rows: Int): Cursor = |  | ||||||
|         MatrixCursor(columns, rows).apply { |  | ||||||
|             repeat(rows) { |  | ||||||
|                 newRow().apply { |  | ||||||
|                     add("placeName") |  | ||||||
|                     add("en") |  | ||||||
|                     add("placeDescription") |  | ||||||
|                     add("placeCategory") |  | ||||||
|                     add(Label.FOREST.text) |  | ||||||
|                     add(Label.FOREST.icon) |  | ||||||
|                     add("placeImage") |  | ||||||
|                     add("wikipediaLink") |  | ||||||
|                     add("wikidataLink") |  | ||||||
|                     add("commonsLink") |  | ||||||
|                     add(40.0) |  | ||||||
|                     add(51.4) |  | ||||||
|                     add("picName") |  | ||||||
|                     add(false) |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,6 +2,7 @@ package fr.free.nrw.commons.bookmarks.locations | ||||||
| 
 | 
 | ||||||
| import com.nhaarman.mockitokotlin2.whenever | import com.nhaarman.mockitokotlin2.whenever | ||||||
| import fr.free.nrw.commons.nearby.Place | import fr.free.nrw.commons.nearby.Place | ||||||
|  | import kotlinx.coroutines.runBlocking | ||||||
| import org.junit.Assert | import org.junit.Assert | ||||||
| import org.junit.Before | import org.junit.Before | ||||||
| import org.junit.Test | import org.junit.Test | ||||||
|  | @ -19,9 +20,11 @@ class BookmarkLocationControllerTest { | ||||||
| 
 | 
 | ||||||
|     @Before |     @Before | ||||||
|     fun setup() { |     fun setup() { | ||||||
|         MockitoAnnotations.initMocks(this) |         MockitoAnnotations.openMocks(this) | ||||||
|         whenever(bookmarkDao!!.getAllBookmarksLocations()) |         runBlocking { | ||||||
|             .thenReturn(mockBookmarkList) |             whenever(bookmarkDao!!.getAllBookmarksLocationsPlace()) | ||||||
|  |                 .thenReturn(mockBookmarkList) | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | @ -66,7 +69,7 @@ class BookmarkLocationControllerTest { | ||||||
|      * Test case where all bookmark locations are fetched and media is found against it |      * Test case where all bookmark locations are fetched and media is found against it | ||||||
|      */ |      */ | ||||||
|     @Test |     @Test | ||||||
|     fun loadBookmarkedLocations() { |     fun loadBookmarkedLocations()  = runBlocking { | ||||||
|         val bookmarkedLocations = |         val bookmarkedLocations = | ||||||
|             bookmarkLocationsController.loadFavoritesLocations() |             bookmarkLocationsController.loadFavoritesLocations() | ||||||
|         Assert.assertEquals(2, bookmarkedLocations.size.toLong()) |         Assert.assertEquals(2, bookmarkedLocations.size.toLong()) | ||||||
|  |  | ||||||
|  | @ -22,6 +22,7 @@ import fr.free.nrw.commons.nearby.Place | ||||||
| import fr.free.nrw.commons.nearby.fragments.CommonPlaceClickActions | import fr.free.nrw.commons.nearby.fragments.CommonPlaceClickActions | ||||||
| import fr.free.nrw.commons.nearby.fragments.PlaceAdapter | import fr.free.nrw.commons.nearby.fragments.PlaceAdapter | ||||||
| import fr.free.nrw.commons.profile.ProfileActivity | import fr.free.nrw.commons.profile.ProfileActivity | ||||||
|  | import kotlinx.coroutines.runBlocking | ||||||
| import org.junit.Assert | import org.junit.Assert | ||||||
| import org.junit.Before | import org.junit.Before | ||||||
| import org.junit.Test | import org.junit.Test | ||||||
|  | @ -129,7 +130,9 @@ class BookmarkLocationFragmentUnitTests { | ||||||
|      */ |      */ | ||||||
|     @Test |     @Test | ||||||
|     fun testInitNonEmpty() { |     fun testInitNonEmpty() { | ||||||
|         whenever(controller.loadFavoritesLocations()).thenReturn(mockBookmarkList) |         runBlocking { | ||||||
|  |             whenever(controller.loadFavoritesLocations()).thenReturn(mockBookmarkList) | ||||||
|  |         } | ||||||
|         val method: Method = |         val method: Method = | ||||||
|             BookmarkLocationsFragment::class.java.getDeclaredMethod("initList") |             BookmarkLocationsFragment::class.java.getDeclaredMethod("initList") | ||||||
|         method.isAccessible = true |         method.isAccessible = true | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ import fr.free.nrw.commons.location.LatLng | ||||||
| import fr.free.nrw.commons.location.LocationServiceManager.LocationChangeType | import fr.free.nrw.commons.location.LocationServiceManager.LocationChangeType | ||||||
| import fr.free.nrw.commons.nearby.contract.NearbyParentFragmentContract | import fr.free.nrw.commons.nearby.contract.NearbyParentFragmentContract | ||||||
| import fr.free.nrw.commons.nearby.presenter.NearbyParentFragmentPresenter | import fr.free.nrw.commons.nearby.presenter.NearbyParentFragmentPresenter | ||||||
|  | import kotlinx.coroutines.runBlocking | ||||||
| import org.junit.Assert.assertFalse | import org.junit.Assert.assertFalse | ||||||
| import org.junit.Assert.assertTrue | import org.junit.Assert.assertTrue | ||||||
| import org.junit.Before | import org.junit.Before | ||||||
|  | @ -463,7 +464,9 @@ class NearbyParentFragmentPresenterTest { | ||||||
|         nearbyPlacesInfo.searchLatLng = latestLocation |         nearbyPlacesInfo.searchLatLng = latestLocation | ||||||
|         nearbyPlacesInfo.placeList = emptyList<Place>() |         nearbyPlacesInfo.placeList = emptyList<Place>() | ||||||
| 
 | 
 | ||||||
|         whenever(bookmarkLocationsDao.getAllBookmarksLocations()).thenReturn(Collections.emptyList()) |         runBlocking { | ||||||
|  |             whenever(bookmarkLocationsDao.getAllBookmarksLocations()).thenReturn(Collections.emptyList()) | ||||||
|  |         } | ||||||
|         nearbyPresenter.updateMapMarkers(nearbyPlacesInfo.placeList, latestLocation, null) |         nearbyPresenter.updateMapMarkers(nearbyPlacesInfo.placeList, latestLocation, null) | ||||||
|         Mockito.verify(nearbyParentFragmentView).setProgressBarVisibility(false) |         Mockito.verify(nearbyParentFragmentView).setProgressBarVisibility(false) | ||||||
|     } |     } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Saifuddin
						Saifuddin