mirror of
https://github.com/bitwarden/android.git
synced 2026-05-21 20:20:03 -05:00
BIT-589 Prevent crash on Landing when navigating with empty input (#59)
This commit is contained in:
@@ -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())
|
||||
|
||||
Reference in New Issue
Block a user