Adding unit tests for other sessions list view model
This commit is contained in:
parent
a968ac08c3
commit
5bcf2ac51e
@ -84,7 +84,6 @@ class OtherSessionsViewModel @AssistedInject constructor(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO update unit tests
|
|
||||||
override fun handle(action: OtherSessionsAction) {
|
override fun handle(action: OtherSessionsAction) {
|
||||||
when (action) {
|
when (action) {
|
||||||
is OtherSessionsAction.PasswordAuthDone -> handlePasswordAuthDone(action)
|
is OtherSessionsAction.PasswordAuthDone -> handlePasswordAuthDone(action)
|
||||||
|
@ -19,32 +19,43 @@ package im.vector.app.features.settings.devices.v2.othersessions
|
|||||||
import android.os.SystemClock
|
import android.os.SystemClock
|
||||||
import com.airbnb.mvrx.Success
|
import com.airbnb.mvrx.Success
|
||||||
import com.airbnb.mvrx.test.MavericksTestRule
|
import com.airbnb.mvrx.test.MavericksTestRule
|
||||||
|
import im.vector.app.R
|
||||||
import im.vector.app.features.settings.devices.v2.DeviceFullInfo
|
import im.vector.app.features.settings.devices.v2.DeviceFullInfo
|
||||||
import im.vector.app.features.settings.devices.v2.GetDeviceFullInfoListUseCase
|
import im.vector.app.features.settings.devices.v2.GetDeviceFullInfoListUseCase
|
||||||
import im.vector.app.features.settings.devices.v2.RefreshDevicesUseCase
|
import im.vector.app.features.settings.devices.v2.RefreshDevicesUseCase
|
||||||
import im.vector.app.features.settings.devices.v2.filter.DeviceManagerFilterType
|
import im.vector.app.features.settings.devices.v2.filter.DeviceManagerFilterType
|
||||||
import im.vector.app.features.settings.devices.v2.signout.InterceptSignoutFlowResponseUseCase
|
import im.vector.app.features.settings.devices.v2.signout.InterceptSignoutFlowResponseUseCase
|
||||||
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionsUseCase
|
|
||||||
import im.vector.app.test.fakes.FakeActiveSessionHolder
|
import im.vector.app.test.fakes.FakeActiveSessionHolder
|
||||||
import im.vector.app.test.fakes.FakePendingAuthHandler
|
import im.vector.app.test.fakes.FakePendingAuthHandler
|
||||||
|
import im.vector.app.test.fakes.FakeSignoutSessionsUseCase
|
||||||
import im.vector.app.test.fakes.FakeStringProvider
|
import im.vector.app.test.fakes.FakeStringProvider
|
||||||
import im.vector.app.test.fakes.FakeVerificationService
|
import im.vector.app.test.fakes.FakeVerificationService
|
||||||
import im.vector.app.test.fixtures.aDeviceFullInfo
|
import im.vector.app.test.fixtures.aDeviceFullInfo
|
||||||
import im.vector.app.test.test
|
import im.vector.app.test.test
|
||||||
import im.vector.app.test.testDispatcher
|
import im.vector.app.test.testDispatcher
|
||||||
import io.mockk.every
|
import io.mockk.every
|
||||||
|
import io.mockk.justRun
|
||||||
import io.mockk.mockk
|
import io.mockk.mockk
|
||||||
import io.mockk.mockkStatic
|
import io.mockk.mockkStatic
|
||||||
import io.mockk.unmockkAll
|
import io.mockk.unmockkAll
|
||||||
|
import io.mockk.verify
|
||||||
import io.mockk.verifyAll
|
import io.mockk.verifyAll
|
||||||
import kotlinx.coroutines.flow.flowOf
|
import kotlinx.coroutines.flow.flowOf
|
||||||
|
import org.amshove.kluent.shouldBeEqualTo
|
||||||
import org.junit.After
|
import org.junit.After
|
||||||
import org.junit.Before
|
import org.junit.Before
|
||||||
import org.junit.Rule
|
import org.junit.Rule
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
|
import org.matrix.android.sdk.api.failure.Failure
|
||||||
|
import org.matrix.android.sdk.api.session.uia.DefaultBaseAuth
|
||||||
|
import javax.net.ssl.HttpsURLConnection
|
||||||
|
|
||||||
private const val A_TITLE_RES_ID = 1
|
private const val A_TITLE_RES_ID = 1
|
||||||
private const val A_DEVICE_ID = "device-id"
|
private const val A_DEVICE_ID_1 = "device-id-1"
|
||||||
|
private const val A_DEVICE_ID_2 = "device-id-2"
|
||||||
|
private const val A_PASSWORD = "password"
|
||||||
|
private const val AUTH_ERROR_MESSAGE = "auth-error-message"
|
||||||
|
private const val AN_ERROR_MESSAGE = "error-message"
|
||||||
|
|
||||||
class OtherSessionsViewModelTest {
|
class OtherSessionsViewModelTest {
|
||||||
|
|
||||||
@ -60,18 +71,18 @@ class OtherSessionsViewModelTest {
|
|||||||
private val fakeActiveSessionHolder = FakeActiveSessionHolder()
|
private val fakeActiveSessionHolder = FakeActiveSessionHolder()
|
||||||
private val fakeStringProvider = FakeStringProvider()
|
private val fakeStringProvider = FakeStringProvider()
|
||||||
private val fakeGetDeviceFullInfoListUseCase = mockk<GetDeviceFullInfoListUseCase>()
|
private val fakeGetDeviceFullInfoListUseCase = mockk<GetDeviceFullInfoListUseCase>()
|
||||||
private val fakeRefreshDevicesUseCaseUseCase = mockk<RefreshDevicesUseCase>()
|
private val fakeRefreshDevicesUseCaseUseCase = mockk<RefreshDevicesUseCase>(relaxed = true)
|
||||||
private val fakeSignoutSessionsUseCase = mockk<SignoutSessionsUseCase>()
|
private val fakeSignoutSessionsUseCase = FakeSignoutSessionsUseCase()
|
||||||
private val fakeInterceptSignoutFlowResponseUseCase = mockk<InterceptSignoutFlowResponseUseCase>()
|
private val fakeInterceptSignoutFlowResponseUseCase = mockk<InterceptSignoutFlowResponseUseCase>()
|
||||||
private val fakePendingAuthHandler = FakePendingAuthHandler()
|
private val fakePendingAuthHandler = FakePendingAuthHandler()
|
||||||
|
|
||||||
private fun createViewModel(args: OtherSessionsArgs = defaultArgs) =
|
private fun createViewModel(viewState: OtherSessionsViewState = OtherSessionsViewState(defaultArgs)) =
|
||||||
OtherSessionsViewModel(
|
OtherSessionsViewModel(
|
||||||
initialState = OtherSessionsViewState(args),
|
initialState = viewState,
|
||||||
stringProvider = fakeStringProvider.instance,
|
stringProvider = fakeStringProvider.instance,
|
||||||
activeSessionHolder = fakeActiveSessionHolder.instance,
|
activeSessionHolder = fakeActiveSessionHolder.instance,
|
||||||
getDeviceFullInfoListUseCase = fakeGetDeviceFullInfoListUseCase,
|
getDeviceFullInfoListUseCase = fakeGetDeviceFullInfoListUseCase,
|
||||||
signoutSessionsUseCase = fakeSignoutSessionsUseCase,
|
signoutSessionsUseCase = fakeSignoutSessionsUseCase.instance,
|
||||||
interceptSignoutFlowResponseUseCase = fakeInterceptSignoutFlowResponseUseCase,
|
interceptSignoutFlowResponseUseCase = fakeInterceptSignoutFlowResponseUseCase,
|
||||||
pendingAuthHandler = fakePendingAuthHandler.instance,
|
pendingAuthHandler = fakePendingAuthHandler.instance,
|
||||||
refreshDevicesUseCase = fakeRefreshDevicesUseCaseUseCase,
|
refreshDevicesUseCase = fakeRefreshDevicesUseCaseUseCase,
|
||||||
@ -101,6 +112,39 @@ class OtherSessionsViewModelTest {
|
|||||||
unmockkAll()
|
unmockkAll()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given the viewModel when initializing it then verification listener is added`() {
|
||||||
|
// Given
|
||||||
|
val fakeVerificationService = givenVerificationService()
|
||||||
|
val devices = mockk<List<DeviceFullInfo>>()
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
|
||||||
|
// Then
|
||||||
|
verify {
|
||||||
|
fakeVerificationService.addListener(viewModel)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given the viewModel when clearing it then verification listener is removed`() {
|
||||||
|
// Given
|
||||||
|
val fakeVerificationService = givenVerificationService()
|
||||||
|
val devices = mockk<List<DeviceFullInfo>>()
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
viewModel.onCleared()
|
||||||
|
|
||||||
|
// Then
|
||||||
|
verify {
|
||||||
|
fakeVerificationService.removeListener(viewModel)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun `given the viewModel has been initialized then viewState is updated with devices list`() {
|
fun `given the viewModel has been initialized then viewState is updated with devices list`() {
|
||||||
// Given
|
// Given
|
||||||
@ -156,7 +200,7 @@ class OtherSessionsViewModelTest {
|
|||||||
@Test
|
@Test
|
||||||
fun `given enable select mode action when handling the action then viewState is updated with correct info`() {
|
fun `given enable select mode action when handling the action then viewState is updated with correct info`() {
|
||||||
// Given
|
// Given
|
||||||
val deviceFullInfo = aDeviceFullInfo(A_DEVICE_ID, isSelected = false)
|
val deviceFullInfo = aDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo)
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo)
|
||||||
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
val expectedState = OtherSessionsViewState(
|
val expectedState = OtherSessionsViewState(
|
||||||
@ -169,7 +213,7 @@ class OtherSessionsViewModelTest {
|
|||||||
// When
|
// When
|
||||||
val viewModel = createViewModel()
|
val viewModel = createViewModel()
|
||||||
val viewModelTest = viewModel.test()
|
val viewModelTest = viewModel.test()
|
||||||
viewModel.handle(OtherSessionsAction.EnableSelectMode(A_DEVICE_ID))
|
viewModel.handle(OtherSessionsAction.EnableSelectMode(A_DEVICE_ID_1))
|
||||||
|
|
||||||
// Then
|
// Then
|
||||||
viewModelTest
|
viewModelTest
|
||||||
@ -180,8 +224,8 @@ class OtherSessionsViewModelTest {
|
|||||||
@Test
|
@Test
|
||||||
fun `given disable select mode action when handling the action then viewState is updated with correct info`() {
|
fun `given disable select mode action when handling the action then viewState is updated with correct info`() {
|
||||||
// Given
|
// Given
|
||||||
val deviceFullInfo1 = aDeviceFullInfo(A_DEVICE_ID, isSelected = true)
|
val deviceFullInfo1 = aDeviceFullInfo(A_DEVICE_ID_1, isSelected = true)
|
||||||
val deviceFullInfo2 = aDeviceFullInfo(A_DEVICE_ID, isSelected = true)
|
val deviceFullInfo2 = aDeviceFullInfo(A_DEVICE_ID_1, isSelected = true)
|
||||||
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
val expectedState = OtherSessionsViewState(
|
val expectedState = OtherSessionsViewState(
|
||||||
@ -205,7 +249,7 @@ class OtherSessionsViewModelTest {
|
|||||||
@Test
|
@Test
|
||||||
fun `given toggle selection for device action when handling the action then viewState is updated with correct info`() {
|
fun `given toggle selection for device action when handling the action then viewState is updated with correct info`() {
|
||||||
// Given
|
// Given
|
||||||
val deviceFullInfo = aDeviceFullInfo(A_DEVICE_ID, isSelected = false)
|
val deviceFullInfo = aDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo)
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo)
|
||||||
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
val expectedState = OtherSessionsViewState(
|
val expectedState = OtherSessionsViewState(
|
||||||
@ -218,7 +262,7 @@ class OtherSessionsViewModelTest {
|
|||||||
// When
|
// When
|
||||||
val viewModel = createViewModel()
|
val viewModel = createViewModel()
|
||||||
val viewModelTest = viewModel.test()
|
val viewModelTest = viewModel.test()
|
||||||
viewModel.handle(OtherSessionsAction.ToggleSelectionForDevice(A_DEVICE_ID))
|
viewModel.handle(OtherSessionsAction.ToggleSelectionForDevice(A_DEVICE_ID_1))
|
||||||
|
|
||||||
// Then
|
// Then
|
||||||
viewModelTest
|
viewModelTest
|
||||||
@ -229,8 +273,8 @@ class OtherSessionsViewModelTest {
|
|||||||
@Test
|
@Test
|
||||||
fun `given select all action when handling the action then viewState is updated with correct info`() {
|
fun `given select all action when handling the action then viewState is updated with correct info`() {
|
||||||
// Given
|
// Given
|
||||||
val deviceFullInfo1 = aDeviceFullInfo(A_DEVICE_ID, isSelected = false)
|
val deviceFullInfo1 = aDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
val deviceFullInfo2 = aDeviceFullInfo(A_DEVICE_ID, isSelected = true)
|
val deviceFullInfo2 = aDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
val expectedState = OtherSessionsViewState(
|
val expectedState = OtherSessionsViewState(
|
||||||
@ -254,8 +298,8 @@ class OtherSessionsViewModelTest {
|
|||||||
@Test
|
@Test
|
||||||
fun `given deselect all action when handling the action then viewState is updated with correct info`() {
|
fun `given deselect all action when handling the action then viewState is updated with correct info`() {
|
||||||
// Given
|
// Given
|
||||||
val deviceFullInfo1 = aDeviceFullInfo(A_DEVICE_ID, isSelected = false)
|
val deviceFullInfo1 = aDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
val deviceFullInfo2 = aDeviceFullInfo(A_DEVICE_ID, isSelected = true)
|
val deviceFullInfo2 = aDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
val expectedState = OtherSessionsViewState(
|
val expectedState = OtherSessionsViewState(
|
||||||
@ -276,6 +320,223 @@ class OtherSessionsViewModelTest {
|
|||||||
.finish()
|
.finish()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given no reAuth is needed and in selectMode when handling multiSignout action then signout process is performed`() {
|
||||||
|
// Given
|
||||||
|
val isSelectModeEnabled = true
|
||||||
|
val deviceFullInfo1 = givenDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
|
val deviceFullInfo2 = givenDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
// signout only selected devices
|
||||||
|
fakeSignoutSessionsUseCase.givenSignoutSuccess(listOf(A_DEVICE_ID_2), fakeInterceptSignoutFlowResponseUseCase)
|
||||||
|
val expectedViewState = OtherSessionsViewState(
|
||||||
|
devices = Success(listOf(deviceFullInfo1, deviceFullInfo2)),
|
||||||
|
currentFilter = defaultArgs.defaultFilter,
|
||||||
|
excludeCurrentDevice = defaultArgs.excludeCurrentDevice,
|
||||||
|
isSelectModeEnabled = isSelectModeEnabled,
|
||||||
|
)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel(OtherSessionsViewState(defaultArgs).copy(isSelectModeEnabled = isSelectModeEnabled))
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.MultiSignout)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest
|
||||||
|
.assertStatesChanges(
|
||||||
|
expectedViewState,
|
||||||
|
{ copy(isLoading = true) },
|
||||||
|
{ copy(isLoading = false) }
|
||||||
|
)
|
||||||
|
.assertEvent { it is OtherSessionsViewEvents.SignoutSuccess }
|
||||||
|
.finish()
|
||||||
|
verify {
|
||||||
|
fakeRefreshDevicesUseCaseUseCase.execute()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given no reAuth is needed and NOT in selectMode when handling multiSignout action then signout process is performed`() {
|
||||||
|
// Given
|
||||||
|
val isSelectModeEnabled = false
|
||||||
|
val deviceFullInfo1 = givenDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
|
val deviceFullInfo2 = givenDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
// signout all devices
|
||||||
|
fakeSignoutSessionsUseCase.givenSignoutSuccess(listOf(A_DEVICE_ID_1, A_DEVICE_ID_2), fakeInterceptSignoutFlowResponseUseCase)
|
||||||
|
val expectedViewState = OtherSessionsViewState(
|
||||||
|
devices = Success(listOf(deviceFullInfo1, deviceFullInfo2)),
|
||||||
|
currentFilter = defaultArgs.defaultFilter,
|
||||||
|
excludeCurrentDevice = defaultArgs.excludeCurrentDevice,
|
||||||
|
isSelectModeEnabled = isSelectModeEnabled,
|
||||||
|
)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel(OtherSessionsViewState(defaultArgs).copy(isSelectModeEnabled = isSelectModeEnabled))
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.MultiSignout)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest
|
||||||
|
.assertStatesChanges(
|
||||||
|
expectedViewState,
|
||||||
|
{ copy(isLoading = true) },
|
||||||
|
{ copy(isLoading = false) }
|
||||||
|
)
|
||||||
|
.assertEvent { it is OtherSessionsViewEvents.SignoutSuccess }
|
||||||
|
.finish()
|
||||||
|
verify {
|
||||||
|
fakeRefreshDevicesUseCaseUseCase.execute()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given server error during multiSignout when handling multiSignout action then signout process is performed`() {
|
||||||
|
// Given
|
||||||
|
val deviceFullInfo1 = givenDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
|
val deviceFullInfo2 = givenDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
val serverError = Failure.OtherServerError(errorBody = "", httpCode = HttpsURLConnection.HTTP_UNAUTHORIZED)
|
||||||
|
fakeSignoutSessionsUseCase.givenSignoutError(listOf(A_DEVICE_ID_1, A_DEVICE_ID_2), serverError)
|
||||||
|
val expectedViewState = OtherSessionsViewState(
|
||||||
|
devices = Success(listOf(deviceFullInfo1, deviceFullInfo2)),
|
||||||
|
currentFilter = defaultArgs.defaultFilter,
|
||||||
|
excludeCurrentDevice = defaultArgs.excludeCurrentDevice,
|
||||||
|
)
|
||||||
|
fakeStringProvider.given(R.string.authentication_error, AUTH_ERROR_MESSAGE)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.MultiSignout)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest
|
||||||
|
.assertStatesChanges(
|
||||||
|
expectedViewState,
|
||||||
|
{ copy(isLoading = true) },
|
||||||
|
{ copy(isLoading = false) }
|
||||||
|
)
|
||||||
|
.assertEvent { it is OtherSessionsViewEvents.SignoutError && it.error.message == AUTH_ERROR_MESSAGE }
|
||||||
|
.finish()
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given unexpected error during multiSignout when handling multiSignout action then signout process is performed`() {
|
||||||
|
// Given
|
||||||
|
val deviceFullInfo1 = givenDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
|
val deviceFullInfo2 = givenDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
val error = Exception()
|
||||||
|
fakeSignoutSessionsUseCase.givenSignoutError(listOf(A_DEVICE_ID_1, A_DEVICE_ID_2), error)
|
||||||
|
val expectedViewState = OtherSessionsViewState(
|
||||||
|
devices = Success(listOf(deviceFullInfo1, deviceFullInfo2)),
|
||||||
|
currentFilter = defaultArgs.defaultFilter,
|
||||||
|
excludeCurrentDevice = defaultArgs.excludeCurrentDevice,
|
||||||
|
)
|
||||||
|
fakeStringProvider.given(R.string.matrix_error, AN_ERROR_MESSAGE)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.MultiSignout)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest
|
||||||
|
.assertStatesChanges(
|
||||||
|
expectedViewState,
|
||||||
|
{ copy(isLoading = true) },
|
||||||
|
{ copy(isLoading = false) }
|
||||||
|
)
|
||||||
|
.assertEvent { it is OtherSessionsViewEvents.SignoutError && it.error.message == AN_ERROR_MESSAGE }
|
||||||
|
.finish()
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given reAuth is needed during multiSignout when handling multiSignout action then requestReAuth is sent and pending auth is stored`() {
|
||||||
|
// Given
|
||||||
|
val deviceFullInfo1 = givenDeviceFullInfo(A_DEVICE_ID_1, isSelected = false)
|
||||||
|
val deviceFullInfo2 = givenDeviceFullInfo(A_DEVICE_ID_2, isSelected = true)
|
||||||
|
val devices: List<DeviceFullInfo> = listOf(deviceFullInfo1, deviceFullInfo2)
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
val reAuthNeeded = fakeSignoutSessionsUseCase.givenSignoutReAuthNeeded(listOf(A_DEVICE_ID_1, A_DEVICE_ID_2), fakeInterceptSignoutFlowResponseUseCase)
|
||||||
|
val expectedPendingAuth = DefaultBaseAuth(session = reAuthNeeded.flowResponse.session)
|
||||||
|
val expectedReAuthEvent = OtherSessionsViewEvents.RequestReAuth(reAuthNeeded.flowResponse, reAuthNeeded.errCode)
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.MultiSignout)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest
|
||||||
|
.assertEvent { it == expectedReAuthEvent }
|
||||||
|
.finish()
|
||||||
|
fakePendingAuthHandler.instance.pendingAuth shouldBeEqualTo expectedPendingAuth
|
||||||
|
fakePendingAuthHandler.instance.uiaContinuation shouldBeEqualTo reAuthNeeded.uiaContinuation
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given SSO auth has been done when handling ssoAuthDone action then corresponding method of pending auth handler is called`() {
|
||||||
|
// Given
|
||||||
|
val devices = mockk<List<DeviceFullInfo>>()
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
justRun { fakePendingAuthHandler.instance.ssoAuthDone() }
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.SsoAuthDone)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest.finish()
|
||||||
|
verifyAll {
|
||||||
|
fakePendingAuthHandler.instance.ssoAuthDone()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given password auth has been done when handling passwordAuthDone action then corresponding method of pending auth handler is called`() {
|
||||||
|
// Given
|
||||||
|
val devices = mockk<List<DeviceFullInfo>>()
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
justRun { fakePendingAuthHandler.instance.passwordAuthDone(any()) }
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.PasswordAuthDone(A_PASSWORD))
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest.finish()
|
||||||
|
verifyAll {
|
||||||
|
fakePendingAuthHandler.instance.passwordAuthDone(A_PASSWORD)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given reAuth has been cancelled when handling reAuthCancelled action then corresponding method of pending auth handler is called`() {
|
||||||
|
// Given
|
||||||
|
val devices = mockk<List<DeviceFullInfo>>()
|
||||||
|
givenGetDeviceFullInfoListReturns(filterType = defaultArgs.defaultFilter, devices)
|
||||||
|
justRun { fakePendingAuthHandler.instance.reAuthCancelled() }
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
val viewModelTest = viewModel.test()
|
||||||
|
viewModel.handle(OtherSessionsAction.ReAuthCancelled)
|
||||||
|
|
||||||
|
// Then
|
||||||
|
viewModelTest.finish()
|
||||||
|
verifyAll {
|
||||||
|
fakePendingAuthHandler.instance.reAuthCancelled()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private fun givenGetDeviceFullInfoListReturns(
|
private fun givenGetDeviceFullInfoListReturns(
|
||||||
filterType: DeviceManagerFilterType,
|
filterType: DeviceManagerFilterType,
|
||||||
devices: List<DeviceFullInfo>,
|
devices: List<DeviceFullInfo>,
|
||||||
|
@ -26,11 +26,10 @@ import im.vector.app.features.settings.devices.v2.RefreshDevicesUseCase
|
|||||||
import im.vector.app.features.settings.devices.v2.notification.GetNotificationsStatusUseCase
|
import im.vector.app.features.settings.devices.v2.notification.GetNotificationsStatusUseCase
|
||||||
import im.vector.app.features.settings.devices.v2.notification.NotificationsStatus
|
import im.vector.app.features.settings.devices.v2.notification.NotificationsStatus
|
||||||
import im.vector.app.features.settings.devices.v2.signout.InterceptSignoutFlowResponseUseCase
|
import im.vector.app.features.settings.devices.v2.signout.InterceptSignoutFlowResponseUseCase
|
||||||
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionResult
|
|
||||||
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionUseCase
|
|
||||||
import im.vector.app.features.settings.devices.v2.verification.CheckIfCurrentSessionCanBeVerifiedUseCase
|
import im.vector.app.features.settings.devices.v2.verification.CheckIfCurrentSessionCanBeVerifiedUseCase
|
||||||
import im.vector.app.test.fakes.FakeActiveSessionHolder
|
import im.vector.app.test.fakes.FakeActiveSessionHolder
|
||||||
import im.vector.app.test.fakes.FakePendingAuthHandler
|
import im.vector.app.test.fakes.FakePendingAuthHandler
|
||||||
|
import im.vector.app.test.fakes.FakeSignoutSessionUseCase
|
||||||
import im.vector.app.test.fakes.FakeStringProvider
|
import im.vector.app.test.fakes.FakeStringProvider
|
||||||
import im.vector.app.test.fakes.FakeTogglePushNotificationUseCase
|
import im.vector.app.test.fakes.FakeTogglePushNotificationUseCase
|
||||||
import im.vector.app.test.fakes.FakeVerificationService
|
import im.vector.app.test.fakes.FakeVerificationService
|
||||||
@ -43,7 +42,6 @@ import io.mockk.just
|
|||||||
import io.mockk.mockk
|
import io.mockk.mockk
|
||||||
import io.mockk.mockkStatic
|
import io.mockk.mockkStatic
|
||||||
import io.mockk.runs
|
import io.mockk.runs
|
||||||
import io.mockk.slot
|
|
||||||
import io.mockk.unmockkAll
|
import io.mockk.unmockkAll
|
||||||
import io.mockk.verify
|
import io.mockk.verify
|
||||||
import io.mockk.verifyAll
|
import io.mockk.verifyAll
|
||||||
@ -53,14 +51,10 @@ import org.junit.After
|
|||||||
import org.junit.Before
|
import org.junit.Before
|
||||||
import org.junit.Rule
|
import org.junit.Rule
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import org.matrix.android.sdk.api.auth.UIABaseAuth
|
|
||||||
import org.matrix.android.sdk.api.auth.UserInteractiveAuthInterceptor
|
|
||||||
import org.matrix.android.sdk.api.auth.registration.RegistrationFlowResponse
|
|
||||||
import org.matrix.android.sdk.api.failure.Failure
|
import org.matrix.android.sdk.api.failure.Failure
|
||||||
import org.matrix.android.sdk.api.session.crypto.model.RoomEncryptionTrustLevel
|
import org.matrix.android.sdk.api.session.crypto.model.RoomEncryptionTrustLevel
|
||||||
import org.matrix.android.sdk.api.session.uia.DefaultBaseAuth
|
import org.matrix.android.sdk.api.session.uia.DefaultBaseAuth
|
||||||
import javax.net.ssl.HttpsURLConnection
|
import javax.net.ssl.HttpsURLConnection
|
||||||
import kotlin.coroutines.Continuation
|
|
||||||
|
|
||||||
private const val A_SESSION_ID_1 = "session-id-1"
|
private const val A_SESSION_ID_1 = "session-id-1"
|
||||||
private const val A_SESSION_ID_2 = "session-id-2"
|
private const val A_SESSION_ID_2 = "session-id-2"
|
||||||
@ -83,10 +77,10 @@ class SessionOverviewViewModelTest {
|
|||||||
private val fakeActiveSessionHolder = FakeActiveSessionHolder()
|
private val fakeActiveSessionHolder = FakeActiveSessionHolder()
|
||||||
private val fakeStringProvider = FakeStringProvider()
|
private val fakeStringProvider = FakeStringProvider()
|
||||||
private val checkIfCurrentSessionCanBeVerifiedUseCase = mockk<CheckIfCurrentSessionCanBeVerifiedUseCase>()
|
private val checkIfCurrentSessionCanBeVerifiedUseCase = mockk<CheckIfCurrentSessionCanBeVerifiedUseCase>()
|
||||||
private val signoutSessionUseCase = mockk<SignoutSessionUseCase>()
|
private val fakeSignoutSessionUseCase = FakeSignoutSessionUseCase()
|
||||||
private val interceptSignoutFlowResponseUseCase = mockk<InterceptSignoutFlowResponseUseCase>()
|
private val interceptSignoutFlowResponseUseCase = mockk<InterceptSignoutFlowResponseUseCase>()
|
||||||
private val fakePendingAuthHandler = FakePendingAuthHandler()
|
private val fakePendingAuthHandler = FakePendingAuthHandler()
|
||||||
private val refreshDevicesUseCase = mockk<RefreshDevicesUseCase>()
|
private val refreshDevicesUseCase = mockk<RefreshDevicesUseCase>(relaxed = true)
|
||||||
private val togglePushNotificationUseCase = FakeTogglePushNotificationUseCase()
|
private val togglePushNotificationUseCase = FakeTogglePushNotificationUseCase()
|
||||||
private val fakeGetNotificationsStatusUseCase = mockk<GetNotificationsStatusUseCase>()
|
private val fakeGetNotificationsStatusUseCase = mockk<GetNotificationsStatusUseCase>()
|
||||||
private val notificationsStatus = NotificationsStatus.ENABLED
|
private val notificationsStatus = NotificationsStatus.ENABLED
|
||||||
@ -96,7 +90,7 @@ class SessionOverviewViewModelTest {
|
|||||||
stringProvider = fakeStringProvider.instance,
|
stringProvider = fakeStringProvider.instance,
|
||||||
getDeviceFullInfoUseCase = getDeviceFullInfoUseCase,
|
getDeviceFullInfoUseCase = getDeviceFullInfoUseCase,
|
||||||
checkIfCurrentSessionCanBeVerifiedUseCase = checkIfCurrentSessionCanBeVerifiedUseCase,
|
checkIfCurrentSessionCanBeVerifiedUseCase = checkIfCurrentSessionCanBeVerifiedUseCase,
|
||||||
signoutSessionUseCase = signoutSessionUseCase,
|
signoutSessionUseCase = fakeSignoutSessionUseCase.instance,
|
||||||
interceptSignoutFlowResponseUseCase = interceptSignoutFlowResponseUseCase,
|
interceptSignoutFlowResponseUseCase = interceptSignoutFlowResponseUseCase,
|
||||||
pendingAuthHandler = fakePendingAuthHandler.instance,
|
pendingAuthHandler = fakePendingAuthHandler.instance,
|
||||||
activeSessionHolder = fakeActiveSessionHolder.instance,
|
activeSessionHolder = fakeActiveSessionHolder.instance,
|
||||||
@ -115,11 +109,50 @@ class SessionOverviewViewModelTest {
|
|||||||
every { fakeGetNotificationsStatusUseCase.execute(A_SESSION_ID_1) } returns flowOf(notificationsStatus)
|
every { fakeGetNotificationsStatusUseCase.execute(A_SESSION_ID_1) } returns flowOf(notificationsStatus)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun givenVerificationService(): FakeVerificationService {
|
||||||
|
val fakeVerificationService = fakeActiveSessionHolder
|
||||||
|
.fakeSession
|
||||||
|
.fakeCryptoService
|
||||||
|
.fakeVerificationService
|
||||||
|
fakeVerificationService.givenAddListenerSucceeds()
|
||||||
|
fakeVerificationService.givenRemoveListenerSucceeds()
|
||||||
|
return fakeVerificationService
|
||||||
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
fun tearDown() {
|
fun tearDown() {
|
||||||
unmockkAll()
|
unmockkAll()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given the viewModel when initializing it then verification listener is added`() {
|
||||||
|
// Given
|
||||||
|
val fakeVerificationService = givenVerificationService()
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
|
||||||
|
// Then
|
||||||
|
verify {
|
||||||
|
fakeVerificationService.addListener(viewModel)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `given the viewModel when clearing it then verification listener is removed`() {
|
||||||
|
// Given
|
||||||
|
val fakeVerificationService = givenVerificationService()
|
||||||
|
|
||||||
|
// When
|
||||||
|
val viewModel = createViewModel()
|
||||||
|
viewModel.onCleared()
|
||||||
|
|
||||||
|
// Then
|
||||||
|
verify {
|
||||||
|
fakeVerificationService.removeListener(viewModel)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun `given the viewModel has been initialized then pushers are refreshed`() {
|
fun `given the viewModel has been initialized then pushers are refreshed`() {
|
||||||
createViewModel()
|
createViewModel()
|
||||||
@ -223,8 +256,7 @@ class SessionOverviewViewModelTest {
|
|||||||
val deviceFullInfo = mockk<DeviceFullInfo>()
|
val deviceFullInfo = mockk<DeviceFullInfo>()
|
||||||
every { deviceFullInfo.isCurrentDevice } returns false
|
every { deviceFullInfo.isCurrentDevice } returns false
|
||||||
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
||||||
givenSignoutSuccess(A_SESSION_ID_1)
|
fakeSignoutSessionUseCase.givenSignoutSuccess(A_SESSION_ID_1, interceptSignoutFlowResponseUseCase)
|
||||||
every { refreshDevicesUseCase.execute() } just runs
|
|
||||||
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
||||||
givenCurrentSessionIsTrusted()
|
givenCurrentSessionIsTrusted()
|
||||||
val expectedViewState = SessionOverviewViewState(
|
val expectedViewState = SessionOverviewViewState(
|
||||||
@ -261,7 +293,7 @@ class SessionOverviewViewModelTest {
|
|||||||
every { deviceFullInfo.isCurrentDevice } returns false
|
every { deviceFullInfo.isCurrentDevice } returns false
|
||||||
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
||||||
val serverError = Failure.OtherServerError(errorBody = "", httpCode = HttpsURLConnection.HTTP_UNAUTHORIZED)
|
val serverError = Failure.OtherServerError(errorBody = "", httpCode = HttpsURLConnection.HTTP_UNAUTHORIZED)
|
||||||
givenSignoutError(A_SESSION_ID_1, serverError)
|
fakeSignoutSessionUseCase.givenSignoutError(A_SESSION_ID_1, serverError)
|
||||||
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
||||||
givenCurrentSessionIsTrusted()
|
givenCurrentSessionIsTrusted()
|
||||||
val expectedViewState = SessionOverviewViewState(
|
val expectedViewState = SessionOverviewViewState(
|
||||||
@ -296,7 +328,7 @@ class SessionOverviewViewModelTest {
|
|||||||
every { deviceFullInfo.isCurrentDevice } returns false
|
every { deviceFullInfo.isCurrentDevice } returns false
|
||||||
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
||||||
val error = Exception()
|
val error = Exception()
|
||||||
givenSignoutError(A_SESSION_ID_1, error)
|
fakeSignoutSessionUseCase.givenSignoutError(A_SESSION_ID_1, error)
|
||||||
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
||||||
givenCurrentSessionIsTrusted()
|
givenCurrentSessionIsTrusted()
|
||||||
val expectedViewState = SessionOverviewViewState(
|
val expectedViewState = SessionOverviewViewState(
|
||||||
@ -330,7 +362,7 @@ class SessionOverviewViewModelTest {
|
|||||||
val deviceFullInfo = mockk<DeviceFullInfo>()
|
val deviceFullInfo = mockk<DeviceFullInfo>()
|
||||||
every { deviceFullInfo.isCurrentDevice } returns false
|
every { deviceFullInfo.isCurrentDevice } returns false
|
||||||
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
every { getDeviceFullInfoUseCase.execute(A_SESSION_ID_1) } returns flowOf(deviceFullInfo)
|
||||||
val reAuthNeeded = givenSignoutReAuthNeeded(A_SESSION_ID_1)
|
val reAuthNeeded = fakeSignoutSessionUseCase.givenSignoutReAuthNeeded(A_SESSION_ID_1, interceptSignoutFlowResponseUseCase)
|
||||||
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
val signoutAction = SessionOverviewAction.SignoutOtherSession
|
||||||
givenCurrentSessionIsTrusted()
|
givenCurrentSessionIsTrusted()
|
||||||
val expectedPendingAuth = DefaultBaseAuth(session = reAuthNeeded.flowResponse.session)
|
val expectedPendingAuth = DefaultBaseAuth(session = reAuthNeeded.flowResponse.session)
|
||||||
@ -415,53 +447,6 @@ class SessionOverviewViewModelTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun givenSignoutSuccess(deviceId: String) {
|
|
||||||
val interceptor = slot<UserInteractiveAuthInterceptor>()
|
|
||||||
val flowResponse = mockk<RegistrationFlowResponse>()
|
|
||||||
val errorCode = "errorCode"
|
|
||||||
val promise = mockk<Continuation<UIABaseAuth>>()
|
|
||||||
every { interceptSignoutFlowResponseUseCase.execute(flowResponse, errorCode, promise) } returns SignoutSessionResult.Completed
|
|
||||||
coEvery { signoutSessionUseCase.execute(deviceId, capture(interceptor)) } coAnswers {
|
|
||||||
secondArg<UserInteractiveAuthInterceptor>().performStage(flowResponse, errorCode, promise)
|
|
||||||
Result.success(Unit)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun givenSignoutReAuthNeeded(deviceId: String): SignoutSessionResult.ReAuthNeeded {
|
|
||||||
val interceptor = slot<UserInteractiveAuthInterceptor>()
|
|
||||||
val flowResponse = mockk<RegistrationFlowResponse>()
|
|
||||||
every { flowResponse.session } returns A_SESSION_ID_1
|
|
||||||
val errorCode = "errorCode"
|
|
||||||
val promise = mockk<Continuation<UIABaseAuth>>()
|
|
||||||
val reAuthNeeded = SignoutSessionResult.ReAuthNeeded(
|
|
||||||
pendingAuth = mockk(),
|
|
||||||
uiaContinuation = promise,
|
|
||||||
flowResponse = flowResponse,
|
|
||||||
errCode = errorCode,
|
|
||||||
)
|
|
||||||
every { interceptSignoutFlowResponseUseCase.execute(flowResponse, errorCode, promise) } returns reAuthNeeded
|
|
||||||
coEvery { signoutSessionUseCase.execute(deviceId, capture(interceptor)) } coAnswers {
|
|
||||||
secondArg<UserInteractiveAuthInterceptor>().performStage(flowResponse, errorCode, promise)
|
|
||||||
Result.success(Unit)
|
|
||||||
}
|
|
||||||
|
|
||||||
return reAuthNeeded
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun givenSignoutError(deviceId: String, error: Throwable) {
|
|
||||||
coEvery { signoutSessionUseCase.execute(deviceId, any()) } returns Result.failure(error)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun givenVerificationService(): FakeVerificationService {
|
|
||||||
val fakeVerificationService = fakeActiveSessionHolder
|
|
||||||
.fakeSession
|
|
||||||
.fakeCryptoService
|
|
||||||
.fakeVerificationService
|
|
||||||
fakeVerificationService.givenAddListenerSucceeds()
|
|
||||||
fakeVerificationService.givenRemoveListenerSucceeds()
|
|
||||||
return fakeVerificationService
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun givenCurrentSessionIsTrusted() {
|
private fun givenCurrentSessionIsTrusted() {
|
||||||
fakeActiveSessionHolder.fakeSession.givenSessionId(A_SESSION_ID_2)
|
fakeActiveSessionHolder.fakeSession.givenSessionId(A_SESSION_ID_2)
|
||||||
val deviceFullInfo = mockk<DeviceFullInfo>()
|
val deviceFullInfo = mockk<DeviceFullInfo>()
|
||||||
|
@ -0,0 +1,77 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2022 New Vector Ltd
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package im.vector.app.test.fakes
|
||||||
|
|
||||||
|
import im.vector.app.features.settings.devices.v2.signout.InterceptSignoutFlowResponseUseCase
|
||||||
|
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionResult
|
||||||
|
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionUseCase
|
||||||
|
import io.mockk.coEvery
|
||||||
|
import io.mockk.every
|
||||||
|
import io.mockk.mockk
|
||||||
|
import io.mockk.slot
|
||||||
|
import org.matrix.android.sdk.api.auth.UIABaseAuth
|
||||||
|
import org.matrix.android.sdk.api.auth.UserInteractiveAuthInterceptor
|
||||||
|
import org.matrix.android.sdk.api.auth.registration.RegistrationFlowResponse
|
||||||
|
import kotlin.coroutines.Continuation
|
||||||
|
|
||||||
|
class FakeSignoutSessionUseCase {
|
||||||
|
|
||||||
|
val instance = mockk<SignoutSessionUseCase>()
|
||||||
|
|
||||||
|
fun givenSignoutSuccess(
|
||||||
|
deviceId: String,
|
||||||
|
interceptSignoutFlowResponseUseCase: InterceptSignoutFlowResponseUseCase,
|
||||||
|
) {
|
||||||
|
val interceptor = slot<UserInteractiveAuthInterceptor>()
|
||||||
|
val flowResponse = mockk<RegistrationFlowResponse>()
|
||||||
|
val errorCode = "errorCode"
|
||||||
|
val promise = mockk<Continuation<UIABaseAuth>>()
|
||||||
|
every { interceptSignoutFlowResponseUseCase.execute(flowResponse, errorCode, promise) } returns SignoutSessionResult.Completed
|
||||||
|
coEvery { instance.execute(deviceId, capture(interceptor)) } coAnswers {
|
||||||
|
secondArg<UserInteractiveAuthInterceptor>().performStage(flowResponse, errorCode, promise)
|
||||||
|
Result.success(Unit)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun givenSignoutReAuthNeeded(
|
||||||
|
deviceId: String,
|
||||||
|
interceptSignoutFlowResponseUseCase: InterceptSignoutFlowResponseUseCase,
|
||||||
|
): SignoutSessionResult.ReAuthNeeded {
|
||||||
|
val interceptor = slot<UserInteractiveAuthInterceptor>()
|
||||||
|
val flowResponse = mockk<RegistrationFlowResponse>()
|
||||||
|
every { flowResponse.session } returns "a-session-id"
|
||||||
|
val errorCode = "errorCode"
|
||||||
|
val promise = mockk<Continuation<UIABaseAuth>>()
|
||||||
|
val reAuthNeeded = SignoutSessionResult.ReAuthNeeded(
|
||||||
|
pendingAuth = mockk(),
|
||||||
|
uiaContinuation = promise,
|
||||||
|
flowResponse = flowResponse,
|
||||||
|
errCode = errorCode,
|
||||||
|
)
|
||||||
|
every { interceptSignoutFlowResponseUseCase.execute(flowResponse, errorCode, promise) } returns reAuthNeeded
|
||||||
|
coEvery { instance.execute(deviceId, capture(interceptor)) } coAnswers {
|
||||||
|
secondArg<UserInteractiveAuthInterceptor>().performStage(flowResponse, errorCode, promise)
|
||||||
|
Result.success(Unit)
|
||||||
|
}
|
||||||
|
|
||||||
|
return reAuthNeeded
|
||||||
|
}
|
||||||
|
|
||||||
|
fun givenSignoutError(deviceId: String, error: Throwable) {
|
||||||
|
coEvery { instance.execute(deviceId, any()) } returns Result.failure(error)
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,77 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2022 New Vector Ltd
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package im.vector.app.test.fakes
|
||||||
|
|
||||||
|
import im.vector.app.features.settings.devices.v2.signout.InterceptSignoutFlowResponseUseCase
|
||||||
|
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionResult
|
||||||
|
import im.vector.app.features.settings.devices.v2.signout.SignoutSessionsUseCase
|
||||||
|
import io.mockk.coEvery
|
||||||
|
import io.mockk.every
|
||||||
|
import io.mockk.mockk
|
||||||
|
import io.mockk.slot
|
||||||
|
import org.matrix.android.sdk.api.auth.UIABaseAuth
|
||||||
|
import org.matrix.android.sdk.api.auth.UserInteractiveAuthInterceptor
|
||||||
|
import org.matrix.android.sdk.api.auth.registration.RegistrationFlowResponse
|
||||||
|
import kotlin.coroutines.Continuation
|
||||||
|
|
||||||
|
class FakeSignoutSessionsUseCase {
|
||||||
|
|
||||||
|
val instance = mockk<SignoutSessionsUseCase>()
|
||||||
|
|
||||||
|
fun givenSignoutSuccess(
|
||||||
|
deviceIds: List<String>,
|
||||||
|
interceptSignoutFlowResponseUseCase: InterceptSignoutFlowResponseUseCase,
|
||||||
|
) {
|
||||||
|
val interceptor = slot<UserInteractiveAuthInterceptor>()
|
||||||
|
val flowResponse = mockk<RegistrationFlowResponse>()
|
||||||
|
val errorCode = "errorCode"
|
||||||
|
val promise = mockk<Continuation<UIABaseAuth>>()
|
||||||
|
every { interceptSignoutFlowResponseUseCase.execute(flowResponse, errorCode, promise) } returns SignoutSessionResult.Completed
|
||||||
|
coEvery { instance.execute(deviceIds, capture(interceptor)) } coAnswers {
|
||||||
|
secondArg<UserInteractiveAuthInterceptor>().performStage(flowResponse, errorCode, promise)
|
||||||
|
Result.success(Unit)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun givenSignoutReAuthNeeded(
|
||||||
|
deviceIds: List<String>,
|
||||||
|
interceptSignoutFlowResponseUseCase: InterceptSignoutFlowResponseUseCase,
|
||||||
|
): SignoutSessionResult.ReAuthNeeded {
|
||||||
|
val interceptor = slot<UserInteractiveAuthInterceptor>()
|
||||||
|
val flowResponse = mockk<RegistrationFlowResponse>()
|
||||||
|
every { flowResponse.session } returns "a-session-id"
|
||||||
|
val errorCode = "errorCode"
|
||||||
|
val promise = mockk<Continuation<UIABaseAuth>>()
|
||||||
|
val reAuthNeeded = SignoutSessionResult.ReAuthNeeded(
|
||||||
|
pendingAuth = mockk(),
|
||||||
|
uiaContinuation = promise,
|
||||||
|
flowResponse = flowResponse,
|
||||||
|
errCode = errorCode,
|
||||||
|
)
|
||||||
|
every { interceptSignoutFlowResponseUseCase.execute(flowResponse, errorCode, promise) } returns reAuthNeeded
|
||||||
|
coEvery { instance.execute(deviceIds, capture(interceptor)) } coAnswers {
|
||||||
|
secondArg<UserInteractiveAuthInterceptor>().performStage(flowResponse, errorCode, promise)
|
||||||
|
Result.success(Unit)
|
||||||
|
}
|
||||||
|
|
||||||
|
return reAuthNeeded
|
||||||
|
}
|
||||||
|
|
||||||
|
fun givenSignoutError(deviceIds: List<String>, error: Throwable) {
|
||||||
|
coEvery { instance.execute(deviceIds, any()) } returns Result.failure(error)
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user