Fix TestFormPageWithCustomFormBuilder assertion against Django 5.1.5 and other security releases

Django 5.1.5 (and other security releases released today) has added a `max_length` attribute to GenericIPAddressField, which breaks an assertion in the form builder tests that compares HTML directly. Change this to a BeautifulSoup-based test so that it works on older and newer releases.
pull/12774/head
Matt Westcott 2025-01-14 20:22:45 +00:00 zatwierdzone przez Matt Westcott
rodzic 88a3a397ca
commit 8b3eb44340
1 zmienionych plików z 7 dodań i 5 usunięć

Wyświetl plik

@ -603,11 +603,13 @@ class TestFormPageWithCustomFormBuilder(WagtailTestUtils, TestCase):
html=True,
)
# check ip address field has rendered
self.assertContains(
response,
'<input type="text" name="device_ip_address" required id="id_device_ip_address" />',
html=True,
)
# (not comparing HTML directly because https://docs.djangoproject.com/en/5.1/releases/5.1.5/
# added a maxlength attribute)
soup = self.get_soup(response.content)
input = soup.find("input", {"name": "device_ip_address"})
self.assertEqual(input["type"], "text")
self.assertEqual(input["required"], "")
self.assertEqual(input["id"], "id_device_ip_address")
def test_post_invalid_form(self):
response = self.client.post(