summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortobrun <tobrun.van.nuland@gmail.com>2019-03-19 15:34:28 +0100
committerTobrun <tobrun@mapbox.com>2019-03-20 09:16:36 +0100
commit11cacb3f8c67edb5962c8785900095846a2a11bf (patch)
tree7b1499f7738ee8e43377df6cfda21d24a779af09
parent174c8fa7e4927ebf28a3d0e07c995d3e3d69de76 (diff)
downloadqtlocation-mapboxgl-11cacb3f8c67edb5962c8785900095846a2a11bf.tar.gz
[android] - refactor idling resource from test
-rw-r--r--platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/offline/OfflineManagerTest.kt102
1 files changed, 42 insertions, 60 deletions
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/offline/OfflineManagerTest.kt b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/offline/OfflineManagerTest.kt
index 144d67feee..017c0f1f04 100644
--- a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/offline/OfflineManagerTest.kt
+++ b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/offline/OfflineManagerTest.kt
@@ -1,59 +1,39 @@
package com.mapbox.mapboxsdk.testapp.offline
import android.content.Context
-import android.support.test.espresso.Espresso
-import android.support.test.espresso.IdlingRegistry
-import android.support.test.espresso.UiController
-import android.support.test.espresso.idling.CountingIdlingResource
+import android.support.test.rule.ActivityTestRule
import android.support.test.runner.AndroidJUnit4
-import com.mapbox.mapboxsdk.maps.MapboxMap
import com.mapbox.mapboxsdk.offline.OfflineManager
import com.mapbox.mapboxsdk.offline.OfflineRegion
import com.mapbox.mapboxsdk.storage.FileSource
-import com.mapbox.mapboxsdk.testapp.action.MapboxMapAction.invoke
-import com.mapbox.mapboxsdk.testapp.activity.EspressoTest
+import com.mapbox.mapboxsdk.testapp.activity.FeatureOverviewActivity
import com.mapbox.mapboxsdk.testapp.utils.FileUtils
+import org.junit.Rule
import org.junit.Test
import org.junit.runner.RunWith
import java.io.IOException
+import java.util.concurrent.CountDownLatch
@RunWith(AndroidJUnit4::class)
-class OfflineManagerTest : EspressoTest() {
+class OfflineManagerTest {
companion object {
private const val TEST_DB_FILE_NAME = "offline_test.db"
}
- private val context: Context by lazy { rule.activity }
-
- private lateinit var offlineIdlingResource: CountingIdlingResource
+ @Rule
+ @JvmField
+ var rule = ActivityTestRule(FeatureOverviewActivity::class.java)
- override fun beforeTest() {
- super.beforeTest()
- offlineIdlingResource = CountingIdlingResource("idling_resource")
- IdlingRegistry.getInstance().register(offlineIdlingResource)
- }
+ private val context: Context by lazy { rule.activity }
+ private val latch: CountDownLatch = CountDownLatch(1)
@Test
fun offlineMergeListDeleteTest() {
- validateTestSetup()
-
- invoke(mapboxMap) { _: UiController, _: MapboxMap ->
- offlineIdlingResource.increment()
+ rule.runOnUiThread {
FileUtils.CopyFileFromAssetsTask(rule.activity, object : FileUtils.OnFileCopiedFromAssetsListener {
override fun onFileCopiedFromAssets() {
- OfflineManager.getInstance(context).mergeOfflineRegions(
- FileSource.getResourcesCachePath(rule.activity) + "/" + TEST_DB_FILE_NAME,
- object : OfflineManager.MergeOfflineRegionsCallback {
- override fun onMerge(offlineRegions: Array<out OfflineRegion>?) {
- assert(offlineRegions?.size == 1)
- offlineIdlingResource.decrement()
- }
-
- override fun onError(error: String?) {
- throw RuntimeException("Unable to merge external offline database. $error")
- }
- })
+ mergeRegion()
}
override fun onError() {
@@ -61,43 +41,45 @@ class OfflineManagerTest : EspressoTest() {
}
}).execute(TEST_DB_FILE_NAME, FileSource.getResourcesCachePath(rule.activity))
}
+ latch.await()
+ }
- invoke(mapboxMap) { _: UiController, _: MapboxMap ->
- offlineIdlingResource.increment()
- OfflineManager.getInstance(context).listOfflineRegions(object : OfflineManager.ListOfflineRegionsCallback {
- override fun onList(offlineRegions: Array<out OfflineRegion>?) {
+ private fun mergeRegion() {
+ OfflineManager.getInstance(context).mergeOfflineRegions(
+ FileSource.getResourcesCachePath(rule.activity) + "/" + TEST_DB_FILE_NAME,
+ object : OfflineManager.MergeOfflineRegionsCallback {
+ override fun onMerge(offlineRegions: Array<out OfflineRegion>?) {
assert(offlineRegions?.size == 1)
- if (offlineRegions != null) {
- for (region in offlineRegions) {
- offlineIdlingResource.increment()
- region.delete(object : OfflineRegion.OfflineRegionDeleteCallback {
- override fun onDelete() {
- offlineIdlingResource.decrement()
- }
-
- override fun onError(error: String?) {
- throw RuntimeException("Unable to delete region with ID: ${region.id}. $error")
- }
- })
- }
- } else {
- throw RuntimeException("Unable to find merged region.")
- }
- offlineIdlingResource.decrement()
+ listRegion()
}
override fun onError(error: String?) {
- throw RuntimeException("Unable to obtain offline regions list. $error")
+ throw RuntimeException("Unable to merge external offline database. $error")
}
})
- }
+ }
- // waiting for offline idling resource
- Espresso.onIdle()
+ private fun listRegion() {
+ OfflineManager.getInstance(context).listOfflineRegions(object : OfflineManager.ListOfflineRegionsCallback {
+ override fun onList(offlineRegions: Array<out OfflineRegion>?) {
+ assert(offlineRegions?.size == 1)
+ deleteRegion(offlineRegions!![0])
+ }
+ override fun onError(error: String?) {
+ throw RuntimeException("Unable to merge external offline database. $error")
+ }
+ })
}
- override fun afterTest() {
- super.afterTest()
- IdlingRegistry.getInstance().unregister(offlineIdlingResource)
+ private fun deleteRegion(offlineRegion: OfflineRegion) {
+ offlineRegion.delete(object : OfflineRegion.OfflineRegionDeleteCallback {
+ override fun onDelete() {
+ latch.countDown()
+ }
+
+ override fun onError(error: String?) {
+ throw RuntimeException("Unable to delete region")
+ }
+ })
}
} \ No newline at end of file