diff --git a/sdk/src/androidTest/java/co/omise/android/ui/AuthorizingPaymentActivityTest.kt b/sdk/src/androidTest/java/co/omise/android/ui/AuthorizingPaymentActivityTest.kt index 3227808f9..23a8dd861 100644 --- a/sdk/src/androidTest/java/co/omise/android/ui/AuthorizingPaymentActivityTest.kt +++ b/sdk/src/androidTest/java/co/omise/android/ui/AuthorizingPaymentActivityTest.kt @@ -4,6 +4,8 @@ import android.app.Activity import android.app.Instrumentation import android.content.Intent import android.net.Uri +import androidx.arch.core.executor.testing.CountingTaskExecutorRule +import androidx.arch.core.executor.testing.InstantTaskExecutorRule import androidx.lifecycle.MutableLiveData import androidx.lifecycle.ViewModel import androidx.lifecycle.ViewModelProvider @@ -44,6 +46,8 @@ import co.omise.android.utils.interceptActivityLifecycle import co.omise.android.utils.loadHtml import co.omise.android.utils.loadUrl import co.omise.android.utils.withUrl +import com.netcetera.threeds.sdk.api.transaction.Transaction +import com.netcetera.threeds.sdk.api.ui.ProgressView import org.hamcrest.CoreMatchers.allOf import org.hamcrest.CoreMatchers.containsString import org.junit.Assert.assertEquals @@ -52,9 +56,13 @@ import org.junit.Before import org.junit.Rule import org.junit.Test import org.junit.runner.RunWith +import org.mockito.Mockito.any import org.mockito.Mockito.mock +import org.mockito.Mockito.never +import org.mockito.Mockito.verify import org.mockito.kotlin.doNothing import org.mockito.kotlin.whenever +import java.util.concurrent.TimeUnit @LargeTest @@ -63,6 +71,9 @@ class AuthorizingPaymentActivityTest { @get:Rule val intentRule = IntentsRule() + @get:Rule + val countingTaskExecutorRule = CountingTaskExecutorRule() + private val authorizeUrl = "https://www.omise.co/pay" private val returnUrl = "http://www.example.com" private val deepLinkAuthorizeUrl = "bankapp://omise.co/authorize?return_uri=sampleapp://omise.co/authorize_return?result=success" @@ -72,6 +83,8 @@ class AuthorizingPaymentActivityTest { putExtra(EXTRA_EXPECTED_RETURN_URLSTRING_PATTERNS, arrayOf(returnUrl)) } + private val transaction: Transaction = mock() + private val progressView: ProgressView = mock() private val mockViewModel: AuthorizingPaymentViewModel = mock() private val viewModelFactory = object : ViewModelProvider.Factory { override fun create(modelClass: Class): T { @@ -92,6 +105,8 @@ class AuthorizingPaymentActivityTest { whenever(mockViewModel.isLoading).thenReturn(isLoading) whenever(mockViewModel.error).thenReturn(error) whenever(mockViewModel.transactionStatus).thenReturn(transactionStatus) + whenever(mockViewModel.getTransaction()).thenReturn(transaction) + whenever(transaction.getProgressView(any())).thenReturn(progressView) doNothing().whenever(mockViewModel).cleanup() interceptActivityLifecycle { activity, _ -> @@ -306,4 +321,26 @@ class AuthorizingPaymentActivityTest { ) ) } + + @Test + fun progressView_whenLoadingIsTrueThenShowProgressView() { + ActivityScenario.launchActivityForResult(intent) + + isLoading.postValue(true) + countingTaskExecutorRule.drainTasks(3, TimeUnit.SECONDS) + + verify(progressView).showProgress() + } + + @Test + fun progressView_whenLoadingIsFalseThenDoNothing() { + ActivityScenario.launchActivityForResult(intent) + + isLoading.postValue(false) + countingTaskExecutorRule.drainTasks(3, TimeUnit.SECONDS) + + // Closing the transaction will also hide the progress view. So we don't need to call hideProgress() here. + verify(progressView, never()).showProgress() + verify(progressView, never()).hideProgress() + } } diff --git a/sdk/src/main/java/co/omise/android/ui/AuthorizingPaymentActivity.kt b/sdk/src/main/java/co/omise/android/ui/AuthorizingPaymentActivity.kt index b9bec2767..f999b1428 100644 --- a/sdk/src/main/java/co/omise/android/ui/AuthorizingPaymentActivity.kt +++ b/sdk/src/main/java/co/omise/android/ui/AuthorizingPaymentActivity.kt @@ -85,10 +85,10 @@ class AuthorizingPaymentActivity : AppCompatActivity() { } viewModel.isLoading.observe(this) { + // Closing transaction will also hide the progress view. + // So, we only show the progress view. if (it) { viewModel.getTransaction().getProgressView(this).showProgress() - } else { - viewModel.getTransaction().getProgressView(this).hideProgress() } }