diff --git a/tests/admin_widgets/tests.py b/tests/admin_widgets/tests.py index ce1ef0eb7d..1fe4741125 100644 --- a/tests/admin_widgets/tests.py +++ b/tests/admin_widgets/tests.py @@ -1140,6 +1140,32 @@ class HorizontalVerticalFilterSeleniumFirefoxTests(SeleniumDataMixin, AdminSelen self.assertEqual(list(self.school.alumni.all()), [self.jason, self.peter]) + def test_back_button_bug(self): + """ + Some browsers had a bug where navigating away from the change page + and then clicking the browser's back button would clear the + filter_horizontal/filter_vertical widgets (#13614). + """ + self.school.students.set([self.lisa, self.peter]) + self.school.alumni.set([self.lisa, self.peter]) + self.admin_login(username='super', password='secret', login_url='/') + change_url = reverse('admin:admin_widgets_school_change', args=(self.school.id,)) + self.selenium.get(self.live_server_url + change_url) + # Navigate away and go back to the change form page. + self.selenium.find_element_by_link_text('Home').click() + self.selenium.back() + self.wait_for('#id_students_from') + expected_unselected_values = [ + str(self.arthur.id), str(self.bob.id), str(self.cliff.id), + str(self.jason.id), str(self.jenny.id), str(self.john.id), + ] + expected_selected_values = [str(self.lisa.id), str(self.peter.id)] + # Check that everything is still in place + self.assertSelectOptions('#id_students_from', expected_unselected_values) + self.assertSelectOptions('#id_students_to', expected_selected_values) + self.assertSelectOptions('#id_alumni_from', expected_unselected_values) + self.assertSelectOptions('#id_alumni_to', expected_selected_values) + class HorizontalVerticalFilterSeleniumChromeTests(HorizontalVerticalFilterSeleniumFirefoxTests): webdriver_class = 'selenium.webdriver.chrome.webdriver.WebDriver'