From 9cc5ec4533b160a39629c55f6ee434350d25f4df Mon Sep 17 00:00:00 2001 From: Long Wei Date: Mon, 9 Oct 2023 17:59:33 +0200 Subject: [PATCH] Don't submit answer if it's invalid according to the input or else after submitting the recycler view will not restore items on configuration change. See #4708 for more details before: https://drive.google.com/file/d/1bLgo-AYro0UbffR6X8nWo8Xv7oUuNJFa/view?usp=sharing after: https://drive.google.com/file/d/1Oek7j6dgjJmgasyyd9FHtQo4E7zTvEBd/view?usp=sharing --- .../player/state/StateFragmentPresenter.kt | 10 ++++++++-- .../app/player/state/StateViewModel.kt | 4 ++-- .../app/player/state/StateFragmentTest.kt | 19 +++++++++++++++++++ 3 files changed, 29 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/org/oppia/android/app/player/state/StateFragmentPresenter.kt b/app/src/main/java/org/oppia/android/app/player/state/StateFragmentPresenter.kt index d13a5dca065..9aabc25f075 100755 --- a/app/src/main/java/org/oppia/android/app/player/state/StateFragmentPresenter.kt +++ b/app/src/main/java/org/oppia/android/app/player/state/StateFragmentPresenter.kt @@ -202,7 +202,10 @@ class StateFragmentPresenter @Inject constructor( fun onSubmitButtonClicked() { hideKeyboard() - handleSubmitAnswer(viewModel.getPendingAnswer(recyclerViewAssembler::getPendingAnswerHandler)) + val answer = viewModel.getPendingAnswer(recyclerViewAssembler::getPendingAnswerHandler) + if (answer != null) { + handleSubmitAnswer(answer) + } } fun onResponsesHeaderClicked() { @@ -215,7 +218,10 @@ class StateFragmentPresenter @Inject constructor( fun handleKeyboardAction() { hideKeyboard() if (viewModel.getCanSubmitAnswer().get() == true) { - handleSubmitAnswer(viewModel.getPendingAnswer(recyclerViewAssembler::getPendingAnswerHandler)) + val answer = viewModel.getPendingAnswer(recyclerViewAssembler::getPendingAnswerHandler) + if (answer != null) { + handleSubmitAnswer(answer) + } } } diff --git a/app/src/main/java/org/oppia/android/app/player/state/StateViewModel.kt b/app/src/main/java/org/oppia/android/app/player/state/StateViewModel.kt index 54109859994..82071abed1f 100644 --- a/app/src/main/java/org/oppia/android/app/player/state/StateViewModel.kt +++ b/app/src/main/java/org/oppia/android/app/player/state/StateViewModel.kt @@ -101,12 +101,12 @@ class StateViewModel @Inject constructor( fun getPendingAnswer( retrieveAnswerHandler: (List) -> InteractionAnswerHandler? - ): UserAnswer { + ): UserAnswer? { return getPendingAnswerWithoutError( retrieveAnswerHandler( getAnswerItemList() ) - ) ?: UserAnswer.getDefaultInstance() + ) } fun canQuicklyToggleBetweenSwahiliAndEnglish( diff --git a/app/src/sharedTest/java/org/oppia/android/app/player/state/StateFragmentTest.kt b/app/src/sharedTest/java/org/oppia/android/app/player/state/StateFragmentTest.kt index d1d1fb3814c..a2750d5203a 100644 --- a/app/src/sharedTest/java/org/oppia/android/app/player/state/StateFragmentTest.kt +++ b/app/src/sharedTest/java/org/oppia/android/app/player/state/StateFragmentTest.kt @@ -442,6 +442,25 @@ class StateFragmentTest { } } + // Regression test for #4708. + @Test + @RunOn(TestPlatform.ESPRESSO) // Robolectric tests don't rotate like this to recreate activity + fun testStateFragment_loadExp_secondState_invalidAnswer_changeConfiguration_submitButtonExists() { + setUpTestWithLanguageSwitchingFeatureOff() + launchForExploration(TEST_EXPLORATION_ID_2, shouldSavePartialProgress = false).use { + startPlayingExploration() + clickContinueInteractionButton() + + typeFractionText("1/") + + clickSubmitAnswerButton() + + rotateToLandscape() + + onView(withId(R.id.submit_answer_button)).check(matches(isDisplayed())) + } + } + @Test fun testStateFragment_loadExp_secondState_invalidAnswer_updated_submitAnswerIsEnabled() { setUpTestWithLanguageSwitchingFeatureOff()