From 19dac7ac8bda42f9af3b91294f367395746ebbe4 Mon Sep 17 00:00:00 2001 From: Naomi Date: Thu, 4 Oct 2018 09:43:11 +0100 Subject: [PATCH 1/4] Added test for submitting form without filling in required fields --- ojusomap/tests.py | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/ojusomap/tests.py b/ojusomap/tests.py index 6819de8..782dd0a 100644 --- a/ojusomap/tests.py +++ b/ojusomap/tests.py @@ -32,7 +32,7 @@ class SeleniumTest(LiveServerTestCase): chrome_options.add_argument('--no-sandbox') # comment out this next line in order to see the tests running in a browser. # But be sure to put it back before comitting, or gitlab CI will fail. - chrome_options.add_argument('--headless') + #chrome_options.add_argument('--headless') chrome_options.add_argument('--disable-gpu') cls.sl = webdriver.Chrome(chrome_options=chrome_options) cls.sl.implicitly_wait(TIMEOUT) @@ -87,6 +87,19 @@ class MapTest(SeleniumTest): ) self.case_study.save() + def test_form_will_show_error(self): + self.user = User.objects.create_superuser(username='test', password='test', email='test@example.com'); + self._open('/en-gb/case-study/create/long'); + self.sl.find_element_by_id('id_username').send_keys('test'); + self.sl.find_element_by_id('id_password').send_keys('test'); + self.sl.find_element_by_css_selector('input[type="submit"]').click() + # navigate to the last tab, where the submit button is + self.sl.find_element_by_css_selector('a[href="#uploads"]').click() + # click submit without filling in any fields + self.sl.find_element_by_id('submit-id-submit').click() + error_message = self.sl.find_element_by_class_name('has-error') + self.assertTrue(error_message.is_displayed()) + def test_map(self): self._open('/') WebDriverWait(self.sl, 5).until( From fa101e6a5f4a37f37baa105a59fa29f52f7e988c Mon Sep 17 00:00:00 2001 From: Naomi Date: Thu, 4 Oct 2018 11:30:21 +0100 Subject: [PATCH 2/4] Added test for long and short case study submissions --- ojusomap/tests.py | 54 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/ojusomap/tests.py b/ojusomap/tests.py index 782dd0a..33bafe5 100644 --- a/ojusomap/tests.py +++ b/ojusomap/tests.py @@ -100,6 +100,60 @@ class MapTest(SeleniumTest): error_message = self.sl.find_element_by_class_name('has-error') self.assertTrue(error_message.is_displayed()) + def test_short_form_will_submit(self): + self.user = User.objects.create_superuser(username='test', password='test', email='test@example.com'); + self._open('/en-gb/case-study/create/short'); + self.sl.find_element_by_id('id_username').send_keys('test'); + self.sl.find_element_by_id('id_password').send_keys('test'); + self.sl.find_element_by_css_selector('input[type="submit"]').click() + self.sl.find_element_by_id('id_entry_name').send_keys('test'); + for i in range(0, 20): + self.sl.find_element_by_class_name('leaflet-control-zoom-in').click() + self.sl.find_element_by_class_name('leaflet-draw-draw-marker').click() + self.sl.find_element_by_id('id_location-map').click() + Select(self.sl.find_element_by_id('id_country')).select_by_visible_text('Albania'); + self.sl.find_element_by_id('id_area_of_land').send_keys('123'); + Select(self.sl.find_element_by_id('id_land_ownership')).select_by_visible_text('Private Land'); + Select(self.sl.find_element_by_id('id_location_context')).select_by_visible_text('Urban'); + self.sl.find_element_by_id('id_describe_ecosystem').send_keys('test'); + Select(self.sl.find_element_by_id('id_project_status')).select_by_visible_text('Existing Project'); + Select(self.sl.find_element_by_id('id_sector_of_economy')).select_by_visible_text('Power Grids'); + self.sl.find_element_by_id('id_synopsis').send_keys('test'); + self.sl.find_element_by_id('id_full_description').send_keys('test'); + Select(self.sl.find_element_by_id('id_positive_or_negative')).select_by_visible_text('Positive'); + self.sl.execute_script("window.scrollTo(0, document.body.scrollHeight);") + self.sl.find_element_by_id('submit-id-submit').click() + self.assertTrue("Thanks!" in self.sl.page_source, "Case study not successfully submitted") + + def test_long_form_will_submit(self): + self.user = User.objects.create_superuser(username='test', password='test', email='test@example.com'); + self._open('/en-gb/case-study/create/long'); + self.sl.find_element_by_id('id_username').send_keys('test'); + self.sl.find_element_by_id('id_password').send_keys('test'); + self.sl.find_element_by_css_selector('input[type="submit"]').click() + self.sl.find_element_by_id('id_entry_name').send_keys('test'); + for i in range(0, 20): + self.sl.find_element_by_class_name('leaflet-control-zoom-in').click() + self.sl.find_element_by_class_name('leaflet-draw-draw-marker').click() + self.sl.find_element_by_id('id_location-map').click() + Select(self.sl.find_element_by_id('id_country')).select_by_visible_text('Albania'); + self.sl.find_element_by_id('id_area_of_land').send_keys('123'); + Select(self.sl.find_element_by_id('id_land_ownership')).select_by_visible_text('Private Land'); + Select(self.sl.find_element_by_id('id_location_context')).select_by_visible_text('Urban'); + self.sl.find_element_by_id('id_describe_ecosystem').send_keys('test'); + Select(self.sl.find_element_by_id('id_project_status')).select_by_visible_text('Existing Project'); + self.sl.find_element_by_id('id_synopsis').send_keys('test'); + self.sl.find_element_by_id('id_full_description').send_keys('test'); + self.sl.find_element_by_id('id_project_owners').send_keys('test'); + self.sl.find_element_by_id('id_shareholders').send_keys('test'); + self.sl.find_element_by_css_selector('a[href="#technical-and-economic-analysis"]').click() + Select(self.sl.find_element_by_id('id_sector_of_economy')).select_by_visible_text('Power Grids'); + self.sl.find_element_by_css_selector('a[href="#socio-environmental-analysis"]').click() + Select(self.sl.find_element_by_id('id_positive_or_negative')).select_by_visible_text('Positive'); + self.sl.find_element_by_css_selector('a[href="#uploads"]').click() + self.sl.find_element_by_id('submit-id-submit').click() + self.assertTrue("Thanks!" in self.sl.page_source, "Case study not successfully submitted") + def test_map(self): self._open('/') WebDriverWait(self.sl, 5).until( From a061bbbb068e59a79f1324694c7a7d23380cd347 Mon Sep 17 00:00:00 2001 From: Naomi Date: Thu, 4 Oct 2018 13:46:39 +0100 Subject: [PATCH 3/4] Refactored tests, and added delay when placing map marker --- ojusomap/tests.py | 57 ++++++++++++++++++++++++++--------------------- 1 file changed, 31 insertions(+), 26 deletions(-) diff --git a/ojusomap/tests.py b/ojusomap/tests.py index 33bafe5..d9d377f 100644 --- a/ojusomap/tests.py +++ b/ojusomap/tests.py @@ -32,7 +32,7 @@ class SeleniumTest(LiveServerTestCase): chrome_options.add_argument('--no-sandbox') # comment out this next line in order to see the tests running in a browser. # But be sure to put it back before comitting, or gitlab CI will fail. - #chrome_options.add_argument('--headless') + chrome_options.add_argument('--headless') chrome_options.add_argument('--disable-gpu') cls.sl = webdriver.Chrome(chrome_options=chrome_options) cls.sl.implicitly_wait(TIMEOUT) @@ -87,12 +87,24 @@ class MapTest(SeleniumTest): ) self.case_study.save() - def test_form_will_show_error(self): + def login(self): self.user = User.objects.create_superuser(username='test', password='test', email='test@example.com'); - self._open('/en-gb/case-study/create/long'); self.sl.find_element_by_id('id_username').send_keys('test'); self.sl.find_element_by_id('id_password').send_keys('test'); self.sl.find_element_by_css_selector('input[type="submit"]').click() + + def place_marker(self): + # click the zoom out button enough to bring up the thing to draw marker then use it. + # the headless browser needs time between each click or it does not show the draw-marker control. + for i in range(0, 15): + self.sl.find_element_by_class_name('leaflet-control-zoom-in').click() + time.sleep(0.2) + self.sl.find_element_by_class_name('leaflet-draw-draw-marker').click() + self.sl.find_element_by_id('id_location-map').click() + + def test_form_will_show_error(self): + self._open('/en-gb/case-study/create/long'); + self.login(); # navigate to the last tab, where the submit button is self.sl.find_element_by_css_selector('a[href="#uploads"]').click() # click submit without filling in any fields @@ -101,16 +113,10 @@ class MapTest(SeleniumTest): self.assertTrue(error_message.is_displayed()) def test_short_form_will_submit(self): - self.user = User.objects.create_superuser(username='test', password='test', email='test@example.com'); self._open('/en-gb/case-study/create/short'); - self.sl.find_element_by_id('id_username').send_keys('test'); - self.sl.find_element_by_id('id_password').send_keys('test'); - self.sl.find_element_by_css_selector('input[type="submit"]').click() - self.sl.find_element_by_id('id_entry_name').send_keys('test'); - for i in range(0, 20): - self.sl.find_element_by_class_name('leaflet-control-zoom-in').click() - self.sl.find_element_by_class_name('leaflet-draw-draw-marker').click() - self.sl.find_element_by_id('id_location-map').click() + self.login() + self.place_marker() + self.sl.find_element_by_id('id_entry_name').send_keys('Short Entry'); Select(self.sl.find_element_by_id('id_country')).select_by_visible_text('Albania'); self.sl.find_element_by_id('id_area_of_land').send_keys('123'); Select(self.sl.find_element_by_id('id_land_ownership')).select_by_visible_text('Private Land'); @@ -121,21 +127,17 @@ class MapTest(SeleniumTest): self.sl.find_element_by_id('id_synopsis').send_keys('test'); self.sl.find_element_by_id('id_full_description').send_keys('test'); Select(self.sl.find_element_by_id('id_positive_or_negative')).select_by_visible_text('Positive'); - self.sl.execute_script("window.scrollTo(0, document.body.scrollHeight);") - self.sl.find_element_by_id('submit-id-submit').click() - self.assertTrue("Thanks!" in self.sl.page_source, "Case study not successfully submitted") + # you can submit the form on any field. Using this one because the submit button sometimes isn't visible + self.sl.find_element_by_id('id_area_of_land').submit(); + self.assertTrue("Thanks!" in self.sl.page_source, "Success message not shown") + self._open('/admin/map/casestudy/'); + self.assertTrue("Short Entry" in self.sl.page_source, "Case study not saved") def test_long_form_will_submit(self): - self.user = User.objects.create_superuser(username='test', password='test', email='test@example.com'); self._open('/en-gb/case-study/create/long'); - self.sl.find_element_by_id('id_username').send_keys('test'); - self.sl.find_element_by_id('id_password').send_keys('test'); - self.sl.find_element_by_css_selector('input[type="submit"]').click() - self.sl.find_element_by_id('id_entry_name').send_keys('test'); - for i in range(0, 20): - self.sl.find_element_by_class_name('leaflet-control-zoom-in').click() - self.sl.find_element_by_class_name('leaflet-draw-draw-marker').click() - self.sl.find_element_by_id('id_location-map').click() + self.login() + self.place_marker() + self.sl.find_element_by_id('id_entry_name').send_keys('Long Entry'); Select(self.sl.find_element_by_id('id_country')).select_by_visible_text('Albania'); self.sl.find_element_by_id('id_area_of_land').send_keys('123'); Select(self.sl.find_element_by_id('id_land_ownership')).select_by_visible_text('Private Land'); @@ -151,8 +153,11 @@ class MapTest(SeleniumTest): self.sl.find_element_by_css_selector('a[href="#socio-environmental-analysis"]').click() Select(self.sl.find_element_by_id('id_positive_or_negative')).select_by_visible_text('Positive'); self.sl.find_element_by_css_selector('a[href="#uploads"]').click() - self.sl.find_element_by_id('submit-id-submit').click() - self.assertTrue("Thanks!" in self.sl.page_source, "Case study not successfully submitted") + # you can submit the form on any field. Using this one because the submit button sometimes isn't visible + self.sl.find_element_by_id('id_name_of_territory_or_area').submit(); + self.assertTrue("Thanks!" in self.sl.page_source, "Success message not shown") + self._open('/admin/map/casestudy/'); + self.assertTrue("Long Entry" in self.sl.page_source, "Case study not saved") def test_map(self): self._open('/') From 6220f62af36323d884f36f681487015b6ce674ae Mon Sep 17 00:00:00 2001 From: Naomi Date: Thu, 4 Oct 2018 13:47:31 +0100 Subject: [PATCH 4/4] Set the images_file field to non-required in both places it was set to non-required in the form but not in reality --- apps/map/forms.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/apps/map/forms.py b/apps/map/forms.py index edc2cbe..275c54a 100644 --- a/apps/map/forms.py +++ b/apps/map/forms.py @@ -95,7 +95,7 @@ class LongCaseStudyForm(BaseCaseStudyForm): images_files = forms.ModelMultipleChoiceField( queryset=ImageFile.objects.all(), widget=CommaSeparatedTextInput(), - required=True + required=False ) official_project_documents = forms.FileField(