summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorŁukasz Paczos <lukas.paczos@gmail.com>2019-04-04 11:03:12 +0200
committerŁukasz Paczos <lukas.paczos@gmail.com>2019-04-04 11:03:12 +0200
commit2be3d2baa42bb4adb9e4fd2f78f6edd0c4c9606d (patch)
tree52714b128a708331a8feb3c8bde4197865f64ae6
parent340603aec04a93d4871fb6c279872586831a000b (diff)
downloadqtlocation-mapboxgl-upstream/lp-missing-tests-14171.tar.gz
[android] add unit tests for #13947upstream/lp-missing-tests-14171
-rw-r--r--platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/storage/FileSource.java2
-rw-r--r--platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceMapTest.kt59
-rw-r--r--platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceStandaloneTest.kt63
-rw-r--r--platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTest.java40
-rw-r--r--platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTestUtils.kt49
5 files changed, 172 insertions, 41 deletions
diff --git a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/storage/FileSource.java b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/storage/FileSource.java
index 5c70d23899..51dee50f76 100644
--- a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/storage/FileSource.java
+++ b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/storage/FileSource.java
@@ -231,7 +231,7 @@ public class FileSource {
* @param context the context to derive the files directory path from
* @return the files directory path
*/
- @Nullable
+ @NonNull
public static String getResourcesCachePath(@NonNull Context context) {
resourcesCachePathLoaderLock.lock();
try {
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceMapTest.kt b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceMapTest.kt
new file mode 100644
index 0000000000..97fe9139cc
--- /dev/null
+++ b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceMapTest.kt
@@ -0,0 +1,59 @@
+package com.mapbox.mapboxsdk.testapp.storage
+
+import android.support.test.annotation.UiThreadTest
+import android.support.test.rule.ActivityTestRule
+import android.support.test.runner.AndroidJUnit4
+import com.mapbox.mapboxsdk.storage.FileSource
+import com.mapbox.mapboxsdk.testapp.activity.espresso.EspressoTestActivity
+import junit.framework.Assert
+import org.junit.After
+import org.junit.Before
+import org.junit.Rule
+import org.junit.Test
+import org.junit.rules.TestName
+import org.junit.runner.RunWith
+import java.util.concurrent.CountDownLatch
+
+@RunWith(AndroidJUnit4::class)
+open class FileSourceMapTest {
+
+ private lateinit var fileSourceTestUtils: FileSourceTestUtils
+
+ @get:Rule
+ val rule = ActivityTestRule(EspressoTestActivity::class.java)
+
+ @get:Rule
+ val testName = TestName()
+
+ @Before
+ @UiThreadTest
+ fun setup() {
+ fileSourceTestUtils = FileSourceTestUtils(rule.activity)
+ fileSourceTestUtils.setup()
+ }
+
+ @Test
+ fun changeResourcesPathWhileMapVisible() {
+ val latch = CountDownLatch(1)
+ rule.activity.runOnUiThread {
+ FileSource.setResourcesCachePath(rule.activity, fileSourceTestUtils.testPath, object : FileSource.ResourcesCachePathChangeCallback {
+ override fun onSuccess(path: String?) {
+ Assert.fail("Requested resources change while the map is running should fail")
+ }
+
+ override fun onError(message: String?) {
+ Assert.assertEquals("Cannot set path, file source is activated."
+ + " Make sure that the map or a resources download is not running.", message)
+ latch.countDown()
+ }
+ })
+ }
+ latch.await()
+ }
+
+ @After
+ @UiThreadTest
+ fun cleanup() {
+ fileSourceTestUtils.cleanup()
+ }
+} \ No newline at end of file
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceStandaloneTest.kt b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceStandaloneTest.kt
new file mode 100644
index 0000000000..5228fb4118
--- /dev/null
+++ b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceStandaloneTest.kt
@@ -0,0 +1,63 @@
+package com.mapbox.mapboxsdk.testapp.storage
+
+import android.support.test.annotation.UiThreadTest
+import android.support.test.rule.ActivityTestRule
+import android.support.test.runner.AndroidJUnit4
+import com.mapbox.mapboxsdk.storage.FileSource
+import com.mapbox.mapboxsdk.testapp.activity.FeatureOverviewActivity
+import org.junit.*
+import org.junit.rules.TestName
+import org.junit.runner.RunWith
+
+@RunWith(AndroidJUnit4::class)
+class FileSourceStandaloneTest {
+
+ private lateinit var fileSourceTestUtils: FileSourceTestUtils
+ private lateinit var fileSource: FileSource
+
+ @get:Rule
+ val rule = ActivityTestRule(FeatureOverviewActivity::class.java)
+
+ @get:Rule
+ val testName = TestName()
+
+ @Before
+ @UiThreadTest
+ fun setup() {
+ fileSource = FileSource.getInstance(rule.activity)
+ fileSourceTestUtils = FileSourceTestUtils(rule.activity)
+ fileSourceTestUtils.setup()
+ }
+
+ @Test
+ @UiThreadTest
+ fun testDefault() {
+ Assert.assertFalse("FileSource should not be active", fileSource.isActivated)
+ }
+
+ @Test
+ @UiThreadTest
+ fun testActivateDeactivate() {
+ Assert.assertFalse("1) FileSource should not be active", fileSource.isActivated)
+ fileSource.activate()
+ Assert.assertTrue("2) FileSource should be active", fileSource.isActivated)
+ fileSource.deactivate()
+ Assert.assertFalse("3) FileSource should not be active", fileSource.isActivated)
+ }
+
+ @Test
+ fun pathChangeTest() {
+ Assert.assertFalse("FileSource should not be active", fileSource.isActivated)
+ Assert.assertEquals(fileSourceTestUtils.originalPath, FileSource.getResourcesCachePath(rule.activity))
+ fileSourceTestUtils.changePath(fileSourceTestUtils.testPath)
+ Assert.assertEquals(fileSourceTestUtils.testPath, FileSource.getResourcesCachePath(rule.activity))
+ fileSourceTestUtils.changePath(fileSourceTestUtils.originalPath)
+ Assert.assertEquals(fileSourceTestUtils.originalPath, FileSource.getResourcesCachePath(rule.activity))
+ }
+
+ @After
+ @UiThreadTest
+ fun cleanup() {
+ fileSourceTestUtils.cleanup()
+ }
+} \ No newline at end of file
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTest.java b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTest.java
deleted file mode 100644
index bf7d7491f3..0000000000
--- a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTest.java
+++ /dev/null
@@ -1,40 +0,0 @@
-package com.mapbox.mapboxsdk.testapp.storage;
-
-import android.support.test.InstrumentationRegistry;
-import android.support.test.annotation.UiThreadTest;
-import android.support.test.runner.AndroidJUnit4;
-import com.mapbox.mapboxsdk.storage.FileSource;
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-
-import static junit.framework.TestCase.assertFalse;
-import static junit.framework.TestCase.assertTrue;
-
-@RunWith(AndroidJUnit4.class)
-public class FileSourceTest {
-
- private FileSource fileSource;
-
- @Before
- @UiThreadTest
- public void setUp() {
- fileSource = FileSource.getInstance(InstrumentationRegistry.getContext());
- }
-
- @Test
- @UiThreadTest
- public void testDefault() {
- assertFalse("FileSource should not be active", fileSource.isActivated());
- }
-
- @Test
- @UiThreadTest
- public void testActivateDeactivate() {
- assertFalse("1) FileSource should not be active", fileSource.isActivated());
- fileSource.activate();
- assertTrue("2) FileSource should be active", fileSource.isActivated());
- fileSource.deactivate();
- assertFalse("3) FileSource should not be active", fileSource.isActivated());
- }
-} \ No newline at end of file
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTestUtils.kt b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTestUtils.kt
new file mode 100644
index 0000000000..73267037df
--- /dev/null
+++ b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/testapp/storage/FileSourceTestUtils.kt
@@ -0,0 +1,49 @@
+package com.mapbox.mapboxsdk.testapp.storage
+
+import android.app.Activity
+import android.support.annotation.WorkerThread
+import com.mapbox.mapboxsdk.storage.FileSource
+import junit.framework.Assert
+import java.io.File
+import java.util.concurrent.CountDownLatch
+
+class FileSourceTestUtils(private val activity: Activity) {
+ val originalPath = FileSource.getResourcesCachePath(activity)
+ val testPath = "$originalPath/test"
+
+ fun setup() {
+ val testFile = File(testPath)
+ testFile.mkdirs()
+ }
+
+ fun cleanup() {
+ val currentPath = FileSource.getResourcesCachePath(activity)
+ if (currentPath != originalPath) {
+ Thread().run { changePath(originalPath) }
+ }
+ val testFile = File(testPath)
+ if (testFile.exists()) {
+ testFile.deleteRecursively()
+ }
+ }
+
+ @WorkerThread
+ fun changePath(path: String) {
+ val latch = CountDownLatch(1)
+ activity.runOnUiThread {
+ FileSource.setResourcesCachePath(
+ activity,
+ path,
+ object : FileSource.ResourcesCachePathChangeCallback {
+ override fun onSuccess(path: String?) {
+ latch.countDown()
+ }
+
+ override fun onError(message: String?) {
+ Assert.fail("Resource path change failed - path: $path, message: $message")
+ }
+ })
+ }
+ latch.await()
+ }
+} \ No newline at end of file