mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	[1.5.x] Made a couple of selenium tests wait for page loaded
The admin_widgets tests were issuing click() to the browser but
didn't wait for the effects of those clicks. This caused the resulting
request to be processed concurrently with the test case. When using
in-memory SQLite this caused weird failures.
Also added wait_page_loaded() to admin selenium tests for code
reuse.
Fixed #19856, backpatch of 50677b29af
			
			
This commit is contained in:
		| @@ -45,6 +45,20 @@ class AdminSeleniumWebDriverTestCase(LiveServerTestCase): | |||||||
|             timeout |             timeout | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     def wait_page_loaded(self): | ||||||
|  |         """ | ||||||
|  |         Block until page has started to load. | ||||||
|  |         """ | ||||||
|  |         from selenium.common.exceptions import TimeoutException | ||||||
|  |         try: | ||||||
|  |             # Wait for the next page to be loaded | ||||||
|  |             self.wait_loaded_tag('body') | ||||||
|  |         except TimeoutException: | ||||||
|  |             # IE7 occasionnally returns an error "Internet Explorer cannot | ||||||
|  |             # display the webpage" and doesn't load the next page. We just | ||||||
|  |             # ignore it. | ||||||
|  |             pass | ||||||
|  |  | ||||||
|     def admin_login(self, username, password, login_url='/admin/'): |     def admin_login(self, username, password, login_url='/admin/'): | ||||||
|         """ |         """ | ||||||
|         Helper function to log into the admin. |         Helper function to log into the admin. | ||||||
| @@ -57,8 +71,7 @@ class AdminSeleniumWebDriverTestCase(LiveServerTestCase): | |||||||
|         login_text = _('Log in') |         login_text = _('Log in') | ||||||
|         self.selenium.find_element_by_xpath( |         self.selenium.find_element_by_xpath( | ||||||
|             '//input[@value="%s"]' % login_text).click() |             '//input[@value="%s"]' % login_text).click() | ||||||
|         # Wait for the next page to be loaded. |         self.wait_page_loaded() | ||||||
|         self.wait_loaded_tag('body') |  | ||||||
|  |  | ||||||
|     def get_css_value(self, selector, attribute): |     def get_css_value(self, selector, attribute): | ||||||
|         """ |         """ | ||||||
|   | |||||||
| @@ -546,15 +546,7 @@ class SeleniumFirefoxTests(AdminSeleniumWebDriverTestCase): | |||||||
|         self.selenium.find_element_by_name('profile_set-2-last_name').send_keys('2 last name 2') |         self.selenium.find_element_by_name('profile_set-2-last_name').send_keys('2 last name 2') | ||||||
|  |  | ||||||
|         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() |         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() | ||||||
|  |         self.wait_page_loaded() | ||||||
|         try: |  | ||||||
|             # Wait for the next page to be loaded. |  | ||||||
|             self.wait_loaded_tag('body') |  | ||||||
|         except TimeoutException: |  | ||||||
|             # IE7 occasionnally returns an error "Internet Explorer cannot |  | ||||||
|             # display the webpage" and doesn't load the next page. We just |  | ||||||
|             # ignore it. |  | ||||||
|             pass |  | ||||||
|  |  | ||||||
|         # Check that the objects have been created in the database |         # Check that the objects have been created in the database | ||||||
|         self.assertEqual(ProfileCollection.objects.all().count(), 1) |         self.assertEqual(ProfileCollection.objects.all().count(), 1) | ||||||
|   | |||||||
| @@ -3262,16 +3262,7 @@ class SeleniumPrePopulatedFirefoxTests(AdminSeleniumWebDriverTestCase): | |||||||
|  |  | ||||||
|         # Save and check that everything is properly stored in the database |         # Save and check that everything is properly stored in the database | ||||||
|         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() |         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() | ||||||
|  |         self.wait_page_loaded() | ||||||
|         try: |  | ||||||
|             # Wait for the next page to be loaded. |  | ||||||
|             self.wait_loaded_tag('body') |  | ||||||
|         except TimeoutException: |  | ||||||
|             # IE7 occasionnally returns an error "Internet Explorer cannot |  | ||||||
|             # display the webpage" and doesn't load the next page. We just |  | ||||||
|             # ignore it. |  | ||||||
|             pass |  | ||||||
|  |  | ||||||
|         self.assertEqual(MainPrepopulated.objects.all().count(), 1) |         self.assertEqual(MainPrepopulated.objects.all().count(), 1) | ||||||
|         MainPrepopulated.objects.get( |         MainPrepopulated.objects.get( | ||||||
|             name=' this is the mAin nÀMë and it\'s awεšome', |             name=' this is the mAin nÀMë and it\'s awεšome', | ||||||
|   | |||||||
| @@ -651,11 +651,13 @@ class HorizontalVerticalFilterSeleniumFirefoxTests(AdminSeleniumWebDriverTestCas | |||||||
|         self.selenium.get( |         self.selenium.get( | ||||||
|             '%s%s' % (self.live_server_url, '/admin_widgets/school/%s/' % self.school.id)) |             '%s%s' % (self.live_server_url, '/admin_widgets/school/%s/' % self.school.id)) | ||||||
|  |  | ||||||
|  |         self.wait_page_loaded() | ||||||
|         self.execute_basic_operations('vertical', 'students') |         self.execute_basic_operations('vertical', 'students') | ||||||
|         self.execute_basic_operations('horizontal', 'alumni') |         self.execute_basic_operations('horizontal', 'alumni') | ||||||
|  |  | ||||||
|         # Save and check that everything is properly stored in the database --- |         # Save and check that everything is properly stored in the database --- | ||||||
|         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() |         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() | ||||||
|  |         self.wait_page_loaded() | ||||||
|         self.school = models.School.objects.get(id=self.school.id)  # Reload from database |         self.school = models.School.objects.get(id=self.school.id)  # Reload from database | ||||||
|         self.assertEqual(list(self.school.students.all()), |         self.assertEqual(list(self.school.students.all()), | ||||||
|                          [self.arthur, self.cliff, self.jason, self.john]) |                          [self.arthur, self.cliff, self.jason, self.john]) | ||||||
| @@ -735,6 +737,7 @@ class HorizontalVerticalFilterSeleniumFirefoxTests(AdminSeleniumWebDriverTestCas | |||||||
|  |  | ||||||
|         # Save and check that everything is properly stored in the database --- |         # Save and check that everything is properly stored in the database --- | ||||||
|         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() |         self.selenium.find_element_by_xpath('//input[@value="Save"]').click() | ||||||
|  |         self.wait_page_loaded() | ||||||
|         self.school = models.School.objects.get(id=self.school.id) # Reload from database |         self.school = models.School.objects.get(id=self.school.id) # Reload from database | ||||||
|         self.assertEqual(list(self.school.students.all()), |         self.assertEqual(list(self.school.students.all()), | ||||||
|                          [self.jason, self.peter]) |                          [self.jason, self.peter]) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user