mirror of
https://github.com/bitwarden/android.git
synced 2024-11-21 08:55:48 +03:00
BIT-589 Prevent crash on Landing when navigating with empty input (#59)
This commit is contained in:
parent
3de916cc20
commit
35483408b2
2 changed files with 14 additions and 1 deletions
|
@ -49,6 +49,10 @@ class LandingViewModel @Inject constructor(
|
|||
}
|
||||
|
||||
private fun handleContinueButtonClicked() {
|
||||
// TODO: add actual validation here: BIT-193
|
||||
if (mutableStateFlow.value.emailInput.isBlank()) {
|
||||
return
|
||||
}
|
||||
sendEvent(LandingEvent.NavigateToLogin(mutableStateFlow.value.emailInput))
|
||||
}
|
||||
|
||||
|
|
|
@ -34,15 +34,24 @@ class LandingViewModelTest : BaseViewModelTest() {
|
|||
@Test
|
||||
fun `ContinueButtonClick should emit NavigateToLogin`() = runTest {
|
||||
val viewModel = LandingViewModel(SavedStateHandle())
|
||||
viewModel.trySendAction(LandingAction.EmailInputChanged("input"))
|
||||
viewModel.eventFlow.test {
|
||||
viewModel.actionChannel.trySend(LandingAction.ContinueButtonClick)
|
||||
assertEquals(
|
||||
LandingEvent.NavigateToLogin(""),
|
||||
LandingEvent.NavigateToLogin("input"),
|
||||
awaitItem(),
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `ContinueButtonClick with empty input should do nothing`() = runTest {
|
||||
val viewModel = LandingViewModel(SavedStateHandle())
|
||||
viewModel.eventFlow.test {
|
||||
viewModel.actionChannel.trySend(LandingAction.ContinueButtonClick)
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `CreateAccountClick should emit NavigateToCreateAccount`() = runTest {
|
||||
val viewModel = LandingViewModel(SavedStateHandle())
|
||||
|
|
Loading…
Reference in a new issue