def test_secretariat_edit(self): # Secretariat user logs in # He goes to the details of a DRAFT questionnaire which he did not enter detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': 'sample_1'} detail_page.open(login=True, user=self.user_secretariat) assert detail_page.has_text('Foo 1') # He sees a button to edit the questionnaire, he clicks it detail_page.edit_questionnaire() # In edit mode, he sees that he can edit the first section edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') # He saves the step and returns step_page = SampleStepPage(self) step_page.submit_step() # He also opens a public questionnaire which he did not enter detail_page.route_kwargs = {'identifier': 'sample_3'} detail_page.open() assert detail_page.has_text('Foo 3') # In the database, there is only 1 version assert Questionnaire.objects.filter(code='sample_3').count() == 1 # He sees a button to edit the questionnaire, he clicks it and creates a # new version detail_page.create_new_version() # In the database, there are now 2 versions assert Questionnaire.objects.filter(code='sample_3').count() == 2
def test_delete_with_lock(self): # The editor logs in and starts editing, this creates a lock. detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': self.questionnaire.code} detail_page.open(login=True, user=self.robin) detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') # The compiler logs in and wants to delete the questionnaire detail_page.open(login=True, user=self.jay) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is False assert detail_page.has_text(self.questionnaire.code) detail_page.delete_questionnaire(check_success=False) # He receives an error message, the questionnaire was not deleted. assert detail_page.has_warning_message( f'This questionnaire is locked for editing by ' f'{self.robin.get_display_name()}.') assert detail_page.has_text(self.questionnaire.code) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is False # After a while, the lock expires Lock.objects.filter(questionnaire_code=self.questionnaire.code).update( is_finished=True) # Now the questionnaire can be deleted. detail_page.delete_questionnaire(check_success=True) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is True
def test_review_locked_questionnaire_blocked_by_other(self): # Reviewer logs in and goes to the details of a SUBMITTED questionnaire detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': 'sample_2'} detail_page.open(login=True, user=self.user_reviewer) assert detail_page.has_text('Foo 2') # He starts to edit the first section (this sets a lock on the # questionnaire) detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') # Secretariat user logs in and goes to the details of the same # questionnaire detail_page.open(login=True, user=self.user_secretariat) assert detail_page.has_text('Foo 2') # The user sees a message that the questionnaire is currently locked assert detail_page.is_locked_by(user=self.user_reviewer) # He reviews the questionnaire which is still locked and sees there is # no exception thrown, however she sees a warning. detail_page.review_questionnaire(check_success=False) assert detail_page.is_locked_by(user=self.user_reviewer) # He sees the questionnaire is still submitted detail_page.check_status('submitted')
def test_delete_with_lock(self): # The editor logs in and starts editing, this creates a lock. detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': self.questionnaire.code} detail_page.open(login=True, user=self.robin) detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') # The compiler logs in and wants to delete the questionnaire detail_page.open(login=True, user=self.jay) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is False assert detail_page.has_text(self.questionnaire.code) detail_page.delete_questionnaire(check_success=False) # He receives an error message, the questionnaire was not deleted. assert detail_page.has_warning_message( f'This questionnaire is locked for editing by ' f'{self.robin.get_display_name()}.') assert detail_page.has_text(self.questionnaire.code) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is False # After a while, the lock expires Lock.objects.filter( questionnaire_code=self.questionnaire.code ).update(is_finished=True) # Now the questionnaire can be deleted. detail_page.delete_questionnaire(check_success=True) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is True
def test_delete_with_lock_by_own_user(self): # The compiler (!) logs in and starts editing, this creates a lock. detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': self.questionnaire.code} detail_page.open(login=True, user=self.jay) detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') # The compiler opens the detail page (= back without saving) and wants # to delete the questionnaire while his own lock is still active. This # works because his own lock is released when deleting the # questionnaire. detail_page.open() detail_page.delete_questionnaire(check_success=True) assert Questionnaire.objects.get( code=self.questionnaire.code).is_deleted is True
def test_review_locked_questionnaire(self): # Secretariat user logs in and goes to the details of a SUBMITTED # questionnaire detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': 'sample_2'} detail_page.open(login=True, user=self.user_secretariat) assert detail_page.has_text(self.sample_2_text) # User starts to edit the first section (this sets a lock on the # questionnaire) detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category(edit_page.CATEGORIES[0][0]) # User goes back to the details (without saving!) detail_page.open() # User reviews the questionnaire and sees there is no exception thrown detail_page.review_questionnaire() # He sees the questionnaire is now reviewed detail_page.check_status('reviewed')
def test_creation_date_does_not_change(self): # Alice logs in user = User.objects.get(pk=102) # She goes to the details of an existing questionnaire and takes # note of the creation and update dates detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': 'sample_3'} detail_page.open(login=True, user=user) creation_date = detail_page.get_el(detail_page.LOC_CREATION_DATE).text update_date = detail_page.get_el(detail_page.LOC_UPDATE_DATE).text # She creates a new version detail_page.create_new_version() # She notices that the creation date did not change while the # update date changed. creation_date_1 = detail_page.get_el( detail_page.LOC_CREATION_DATE).text update_date_1 = detail_page.get_el(detail_page.LOC_UPDATE_DATE).text assert creation_date == creation_date_1 assert update_date != update_date_1 # Alice logs in as a different user # She also opens a draft version of a questionnaire and takes # note of the creation and update dates user = User.objects.get(pk=101) detail_page.route_kwargs = {'identifier': 'sample_1'} detail_page.open(login=True, user=user) creation_date = detail_page.get_el(detail_page.LOC_CREATION_DATE).text update_date = detail_page.get_el(detail_page.LOC_UPDATE_DATE).text # She makes an edit detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, ' (changed)') # She submits the questionnaire step_page.submit_step() # She sees the changes were submitted assert edit_page.has_text(' (changed)') # She notices that the creation date did not change while the # update date changed. creation_date_1 = edit_page.get_el(edit_page.LOC_CREATION_DATE).text update_date_1 = edit_page.get_el(edit_page.LOC_UPDATE_DATE).text assert creation_date == creation_date_1 assert update_date != update_date_1
def test_creation_date_does_not_change(self): # Alice logs in user = User.objects.get(pk=102) # She goes to the details of an existing questionnaire and takes # note of the creation and update dates detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': 'sample_3'} detail_page.open(login=True, user=user) creation_date = detail_page.get_el(detail_page.LOC_CREATION_DATE).text update_date = detail_page.get_el(detail_page.LOC_UPDATE_DATE).text # She creates a new version detail_page.create_new_version() # She notices that the creation date did not change while the # update date changed. creation_date_1 = detail_page.get_el(detail_page.LOC_CREATION_DATE).text update_date_1 = detail_page.get_el(detail_page.LOC_UPDATE_DATE).text assert creation_date == creation_date_1 assert update_date != update_date_1 # Alice logs in as a different user # She also opens a draft version of a questionnaire and takes # note of the creation and update dates user = User.objects.get(pk=101) detail_page.route_kwargs = {'identifier': 'sample_1'} detail_page.open(login=True, user=user) creation_date = detail_page.get_el(detail_page.LOC_CREATION_DATE).text update_date = detail_page.get_el(detail_page.LOC_UPDATE_DATE).text # She makes an edit detail_page.edit_questionnaire() edit_page = SampleEditPage(self) edit_page.click_edit_category('cat_1') step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, ' (changed)') # She submits the questionnaire step_page.submit_step() # She sees the changes were submitted assert edit_page.has_text(' (changed)') # She notices that the creation date did not change while the # update date changed. creation_date_1 = edit_page.get_el(edit_page.LOC_CREATION_DATE).text update_date_1 = edit_page.get_el(edit_page.LOC_UPDATE_DATE).text assert creation_date == creation_date_1 assert update_date != update_date_1
def test_do_not_show_deleted_links_in_form(self): user = User.objects.get(pk=101) samplemulti_link = 'This is key 1a' sample_link = 'This is the first key.' # User goes to the SAMPLE questionnaire and sees the link detail_page_sample = SampleDetailPage(self) detail_page_sample.route_kwargs = {'identifier': 'sample_1'} detail_page_sample.open(login=True, user=user) assert detail_page_sample.has_text(samplemulti_link) # User starts editing the questionnaire detail_page_sample.create_new_version() edit_page = SampleEditPage(self) assert edit_page.has_text(samplemulti_link) # User opens the step with the link and sees the link is there edit_page.click_edit_category('cat_5') step_page = QuestionnaireStepPage(self) assert step_page.check_links([samplemulti_link]) # User opens the details page of the SAMPLEMULTI questionnaire detail_page_multi = SampleMultiDetailPage(self) detail_page_multi.route_kwargs = {'identifier': 'samplemulti_1'} detail_page_multi.open() assert detail_page_multi.has_text(sample_link) # User deletes the questionnaire detail_page_multi.delete_questionnaire() # User opens the detail page of the SAMPLE questionnaire again. The link # is not there anymore. detail_page_sample.open() assert not detail_page_sample.has_text(samplemulti_link) # The link is not on the edit page either detail_page_sample.edit_questionnaire() assert not detail_page_sample.has_text(samplemulti_link) # Also on the step edit page, no link edit_page.click_edit_category('cat_5') assert step_page.check_links([]) # The step can be submitted without an error step_page.submit_step()
def test_show_only_one_linked_version(self): sample_title = 'This is the first key.' samplemulti_title = 'This is key 1a' samplemulti_changed_text = ' (changed)' samplemulti_title_changed = samplemulti_title + samplemulti_changed_text # Alice logs in # She goes to the SAMPLE questionnaire and sees the link user_1 = User.objects.get(pk=101) sample_detail_page = SampleDetailPage(self) sample_detail_page.route_kwargs = {'identifier': 'sample_1'} sample_detail_page.open(login=True, user=user_1) sample_detail_page.expand_details() expected_samplemulti_links = [ { 'title': samplemulti_title, 'configuration': 'samplemulti', } ] sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links) # She goes to the MULTISAMPLE questionnaire and sees the link sample_detail_page.click_linked_questionnaire(index=0) samplemulti_detail_page = SampleMultiDetailPage(self) samplemulti_detail_page.expand_details() expected_sample_links = [ { 'title': sample_title, 'configuration': 'sample', } ] samplemulti_detail_page.check_linked_questionnaires( expected=expected_sample_links) # She edits the MULTISAMPLE questionnaire and sees only one # version is linked (still the same) samplemulti_detail_page.create_new_version() samplemulti_edit_page = SampleMultiEditPage(self) samplemulti_edit_page.click_edit_category('mcat_1') samplemulti_step_page = SampleMultiStepPage(self) samplemulti_step_page.enter_text( samplemulti_step_page.LOC_QUESTION_MQG01_MKEY01, samplemulti_changed_text) # She submits the step samplemulti_step_page.submit_step() # She sees that only one questionnaire is linked samplemulti_edit_page.expand_details() samplemulti_edit_page.check_linked_questionnaires( expected=expected_sample_links) # She goes to the SAMPLE questionnaire and sees only one version # is linked (the pending one) samplemulti_edit_page.click_linked_questionnaire(index=0) expected_samplemulti_links_changed = [ { 'title': samplemulti_title_changed, 'configuration': 'samplemulti', } ] sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links_changed) # She even creates a new version and opens the form and sees there is # only one version sample_detail_page.create_new_version() sample_edit_page = SampleEditPage(self) sample_edit_page.click_edit_category('cat_5') sample_step_page = SampleStepPage(self) sample_step_page.check_links([samplemulti_title_changed]) sample_step_page.back_without_saving() # She logs out and sees only one questionnaire is linked (the # active one) sample_detail_page.logout() sample_detail_page.open() sample_detail_page.expand_details() sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links) # She logs in as a different user and sees only one version is # linked (the active one) user_2 = User.objects.get(pk=102) sample_detail_page.open(login=True, user=user_2) sample_detail_page.expand_details() sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links)
def test_edit_questionnaire(self): user = self.create_new_user( email='*****@*****.**', groups=['Reviewers', 'Publishers']) # Alice logs in # She enters a Questionnaire new_page = SampleNewPage(self) new_page.open(login=True, user=user) new_page.click_edit_category('cat_1') step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, 'Foo') step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_3, 'Bar') step_page.submit_step() # The questionnaire is already saved as draft # She submits it for review edit_page = SampleEditPage(self) edit_page.submit_questionnaire() # She reviews it detail_page = SampleDetailPage(self) detail_page.review_questionnaire() # She publishes it detail_page.publish_questionnaire() # She sees it is public and visible assert detail_page.has_text('Foo') assert detail_page.has_text('Bar') url = self.browser.current_url # She creates a new version detail_page.create_new_version() # She edits it edit_page.click_edit_category('cat_1') # She changes some values step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, 'asdf', clear=True) step_page.submit_step() # The questionnaire is already saved as draft # She is taken to the overview page where she sees the latest # (pending) changes of the draft edit_page.check_status('draft') assert not edit_page.has_text('Foo') assert edit_page.has_text('asdf') assert edit_page.has_text('Bar') # She sees the edit buttons assert edit_page.exists_el(edit_page.format_locator( edit_page.LOC_BUTTON_EDIT_CATEGORY, keyword='cat_1')) # She sees the possibility to view the questionnaire edit_page.view_questionnaire() self.assertIn(url, self.browser.current_url + '#top') # All the changes are there assert not detail_page.has_text('Foo') assert detail_page.has_text('asdf') assert detail_page.has_text('Bar') # There are no buttons to edit the sections anymore assert not detail_page.exists_el(detail_page.format_locator( edit_page.LOC_BUTTON_EDIT_CATEGORY, keyword='cat_1'))
def test_show_only_one_linked_version(self): sample_title = 'This is the first key.' samplemulti_title = 'This is key 1a' samplemulti_changed_text = ' (changed)' samplemulti_title_changed = samplemulti_title + samplemulti_changed_text # Alice logs in # She goes to the SAMPLE questionnaire and sees the link user_1 = User.objects.get(pk=101) sample_detail_page = SampleDetailPage(self) sample_detail_page.route_kwargs = {'identifier': 'sample_1'} sample_detail_page.open(login=True, user=user_1) sample_detail_page.expand_details() expected_samplemulti_links = [{ 'title': samplemulti_title, 'configuration': 'samplemulti', }] sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links) # She goes to the MULTISAMPLE questionnaire and sees the link sample_detail_page.click_linked_questionnaire(index=0) samplemulti_detail_page = SampleMultiDetailPage(self) samplemulti_detail_page.expand_details() expected_sample_links = [{ 'title': sample_title, 'configuration': 'sample', }] samplemulti_detail_page.check_linked_questionnaires( expected=expected_sample_links) # She edits the MULTISAMPLE questionnaire and sees only one # version is linked (still the same) samplemulti_detail_page.create_new_version() samplemulti_edit_page = SampleMultiEditPage(self) samplemulti_edit_page.click_edit_category('mcat_1') samplemulti_step_page = SampleMultiStepPage(self) samplemulti_step_page.enter_text( samplemulti_step_page.LOC_QUESTION_MQG01_MKEY01, samplemulti_changed_text) # She submits the step samplemulti_step_page.submit_step() # She sees that only one questionnaire is linked samplemulti_edit_page.expand_details() samplemulti_edit_page.check_linked_questionnaires( expected=expected_sample_links) # She goes to the SAMPLE questionnaire and sees only one version # is linked (the pending one) samplemulti_edit_page.click_linked_questionnaire(index=0) expected_samplemulti_links_changed = [{ 'title': samplemulti_title_changed, 'configuration': 'samplemulti', }] sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links_changed) # She even creates a new version and opens the form and sees there is # only one version sample_detail_page.create_new_version() sample_edit_page = SampleEditPage(self) sample_edit_page.click_edit_category('cat_5') sample_step_page = SampleStepPage(self) sample_step_page.check_links([samplemulti_title_changed]) sample_step_page.back_without_saving() # She logs out and sees only one questionnaire is linked (the # active one) sample_detail_page.logout() sample_detail_page.open() sample_detail_page.expand_details() sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links) # She logs in as a different user and sees only one version is # linked (the active one) user_2 = User.objects.get(pk=102) sample_detail_page.open(login=True, user=user_2) sample_detail_page.expand_details() sample_detail_page.check_linked_questionnaires( expected=expected_samplemulti_links)
def test_review_panel(self): # An Editor logs in and goes to the details page of a questionnaire # which he did not enter detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': 'sample_5'} detail_page.open(login=True, user=self.user_editor) assert detail_page.has_text('Foo 5') # He does see the review panel but no actions are possible detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # He goes to the details of a questionnaire where he is editor (only!). detail_page.route_kwargs = {'identifier': 'sample_3'} detail_page.open() assert detail_page.has_text('Foo 3') # He does see the review panel but can only edit detail_page.check_review_actions( create_new=True, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # He creates a new version detail_page.create_new_version() edit_page = SampleEditPage(self) # He makes some changes and saves the questionnaire edit_page.click_edit_category('cat_1') step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, ' (by Editor)') step_page.submit_step() # He sees a review panel but he does not see the button to # submit the questionnaire for review edit_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # He sees the buttons to edit each section assert edit_page.can_edit_category('cat_1') # User decides to view the questionnaire edit_page.view_questionnaire() # He does not see the button to edit each section anymore assert not edit_page.can_edit_category('cat_1') # Now the compiler logs in and goes to the detail page of the # questionnaire detail_page.open(login=True, user=self.user_compiler) # The compiler does see the button to submit the questionnaire detail_page.check_review_actions( create_new=False, edit=True, submit=True, review=False, publish=False, delete=True, change_compiler=False, ) # On the detail page, the compiler does not see buttons to edit the # categories assert not detail_page.can_edit_category('cat_1') # The compiler goes to the edit page and now sees the category buttons detail_page.edit_questionnaire() assert edit_page.can_edit_category('cat_1') # She submits the questionnaire to review assert edit_page.can_delete_questionnaire() edit_page.submit_questionnaire() # The questionnaire is now pending for review. The review panel # is visible but Compiler cannot do any actions. detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # The editor logs in again and opens the same page detail_page.open(login=True, user=self.user_editor) # He goes to the page and he also sees the review panel but no # actions can be taken. detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # Reviewer logs in and opens the page detail_page.open(login=True, user=self.user_reviewer) # He goes to the page and sees the review panel. There is a # button to do the review. detail_page.check_review_actions( create_new=False, edit=True, submit=False, review=True, publish=False, delete=False, change_compiler=False, ) # He is on the detail page and does not see the buttons to edit each # section assert not detail_page.can_edit_category('cat_1') # He goes to the edit page and now she sees the buttons detail_page.edit_questionnaire() assert edit_page.can_edit_category('cat_1') # He clicks the button to do the review edit_page.review_questionnaire() # He sees the review panel but no action is possible. detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # Compiler logs in and goes to the page, sees the review panel # but no actions possible detail_page.open(login=True, user=self.user_compiler) detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # Editor logs in and goes to the page, sees the review panel but # no actions possible. detail_page.open(login=True, user=self.user_editor) detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, ) # Publisher logs in and goes to the page. He sees the review # panel with a button to publish. detail_page.open(login=True, user=self.user_publisher) detail_page.check_review_actions( create_new=False, edit=True, submit=False, review=False, publish=True, delete=False, change_compiler=False, ) # He is on the detail page and does not see the buttons to edit each # section assert not detail_page.can_edit_category('cat_1') # He goes to the edit page and now she sees the buttons detail_page.edit_questionnaire() # He clicks the button to publish the questionnaire. detail_page.publish_questionnaire() # The review panel is there but he cannot edit detail_page.check_review_actions( create_new=False, edit=False, submit=False, review=False, publish=False, delete=False, change_compiler=False, )
def test_edit_public_new_config_edition(self, mock_choices): mock_choices.return_value = CODE_CHOICES + [ ('sample', 'sample'), ] code = 'sample_3' old_version = Questionnaire.objects.get(code=code) # A user logs in and goes to the detail page of a public questionnaire # where he is the compiler detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': code} detail_page.open(login=True, user=self.user) # The user sees a hint about a new edition on the detail page detail_page.close_edition_modal() assert detail_page.has_new_edition() # The user creates a new version detail_page.create_new_version() # The new version is in the new edition new_version = Questionnaire.objects.latest('updated') assert new_version.configuration.edition == '2018' # The data of the old version was cleaned up assert old_version.data['qg_2'][0]['key_2'] is not None assert new_version.data['qg_2'][0]['key_2'] is None assert old_version.data['qg_2'][0]['key_3'] \ == new_version.data['qg_2'][0]['key_3'] assert 'qg_5' in old_version.data assert 'qg_5' not in new_version.data # The old values are still there edit_page = SampleEditPage(self) assert edit_page.has_text('Foo 3') # New questions are available and can be entered edit_page.click_edit_category('cat_4') step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_68, 'New key for edition 2018') step_page.submit_step() assert edit_page.has_text('New key for edition 2018') # The old values are still there assert edit_page.has_text('Foo 3') # Questions also have updated labels edit_page.click_edit_category('cat_1') assert step_page.has_text('Key 1 (edition 2018):') step_page.submit_step() # The old values are still there assert edit_page.has_text('Foo 3') # The user submits the version edit_page.submit_questionnaire() # The version is reviewed (in DB) new_version.status = settings.QUESTIONNAIRE_PUBLIC new_version.save() # The new public version does not have a hint about new editions detail_page.open() assert not detail_page.has_new_edition()
def test_edit_public_new_config_edition(self, mock_choices): mock_choices.return_value = CODE_CHOICES + [('sample', 'sample'), ] code = 'sample_3' old_version = Questionnaire.objects.get(code=code) # A user logs in and goes to the detail page of a public questionnaire # where he is the compiler detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': code} detail_page.open(login=True, user=self.user) # The user sees a hint about a new edition on the detail page detail_page.close_edition_modal() assert detail_page.has_new_edition() # The user creates a new version detail_page.create_new_version() # The new version is in the new edition new_version = Questionnaire.objects.latest('updated') assert new_version.configuration.edition == '2018' # The data of the old version was cleaned up assert old_version.data['qg_2'][0]['key_2'] is not None assert new_version.data['qg_2'][0]['key_2'] is None assert old_version.data['qg_2'][0]['key_3'] \ == new_version.data['qg_2'][0]['key_3'] assert 'qg_5' in old_version.data assert 'qg_5' not in new_version.data # The old values are still there edit_page = SampleEditPage(self) assert edit_page.has_text('Foo 3') # New questions are available and can be entered edit_page.click_edit_category('cat_4') step_page = SampleStepPage(self) step_page.enter_text( step_page.LOC_FORM_INPUT_KEY_68, 'New key for edition 2018') step_page.submit_step() assert edit_page.has_text('New key for edition 2018') # The old values are still there assert edit_page.has_text('Foo 3') # Questions also have updated labels edit_page.click_edit_category('cat_1') assert step_page.has_text('Key 1 (edition 2018):') step_page.submit_step() # The old values are still there assert edit_page.has_text('Foo 3') # The user submits the version edit_page.submit_questionnaire() # The version is reviewed (in DB) new_version.status = settings.QUESTIONNAIRE_PUBLIC new_version.save() # The new public version does not have a hint about new editions detail_page.open() assert not detail_page.has_new_edition()
def test_edit_public(self): code = 'sample_3' user = User.objects.get(pk=101) old_text = 'Faz 3' new_text = 'asdf' # User logs in and goes to the detail page of a "public" Questionnaire detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': code} detail_page.open(login=True, user=user) assert code in self.browser.current_url assert detail_page.has_text(old_text) assert not detail_page.has_text(new_text) # There is only one version of this questionnaire in the db assert Questionnaire.objects.filter(code=code).count() == 1 # User uses the direct link to go to the edit page of the questionnaire # and sees no new version of the questionnaire is created in the DB. # This prevents the issue when new versions were created upon GET of the # edit page, which should be fixed now. edit_page = SampleEditPage(self) edit_page.route_kwargs = {'identifier': code} edit_page.open() assert Questionnaire.objects.filter(code=code).count() == 1 # User edits the Questionnaire (creates a new version) and sees that # the URL contains the code of the Questionnaire detail_page.open() detail_page.create_new_version() assert code in self.browser.current_url # User edits a category and sees that the URL still contains the # code of the Questionnaire edit_page.click_edit_category('cat_2') assert code in self.browser.current_url # User makes some changes and submits the category step_page = SampleStepPage(self) step_page.enter_text( step_page.LOC_FORM_INPUT_KEY_5, new_text, clear=True) step_page.submit_step() # User is back on the overview page and sees that the URL still # contains the code of the Questionnaire assert code in self.browser.current_url assert edit_page.has_text(code) # She sees that the value of Key 1 was updated assert not edit_page.has_text(old_text) assert edit_page.has_text(new_text) # Also there was an additional version created in the database assert Questionnaire.objects.count() == 11 # The newly created version has the same code assert Questionnaire.objects.filter(code=code).count() == 2 # She goes to see her own questionnaire and sees sample_3 appears only # once my_page = MyDataPage(self) my_page.open() my_page.wait_for_lists() expected_list = [ { 'description': new_text, }, { # Just to check that description is there ... 'description': 'Faz 1' }, # ... the rest does not really matter ] assert my_page.count_list_results() == 6 my_page.check_list_results(expected_list, count=False) # She clicks the first entry and sees that she is taken to the # details page of the latest (pending) version. my_page.click_list_entry(index=0) assert detail_page.has_text(new_text)
def test_add_user(self, mock_search_users, mock_user_information): mock_search_users.side_effect = self.get_mock_remote_user_client_search mock_user_information.side_effect = self.get_mock_remote_user_client_user_information # User logs in and goes to the questionnaire step where he can add a # user. new_page = SampleNewPage(self) new_page.open(login=True, user=self.user_alice) new_page.click_edit_category('cat_0') # The field to search a user is not visible. step_page = SampleStepPage(self) search_field = step_page.get_user_search_field(index=1) assert not search_field.is_displayed() # She clicks the radio to search for an existing user step_page.get_el(step_page.LOC_RADIO_SEARCH_USER).click() # Now the search field is visible assert search_field.is_displayed() # There is no loading indicator loading_indicator = step_page.get_el(step_page.LOC_LOADING_SEARCH_USER) assert not loading_indicator.is_displayed() # She enters a name and sees a search is conducted search_field.send_keys(self.user_bob.firstname) step_page.select_autocomplete(self.user_bob.get_display_name()) # She sees a loading indicator while the user is updated in the DB assert loading_indicator.is_displayed() # She waits until the loading indicator disappears step_page.wait_for(step_page.LOC_LOADING_SEARCH_USER, visibility=False) # She sees that the search field is not visible anymore assert not search_field.is_displayed() # She sees that a field with the name was added assert step_page.has_selected_user(self.user_bob) # She sees that the user ID was added to the hidden field assert step_page.get_selected_user_id() == str(self.user_bob.pk) # She removes the user step_page.remove_selected_user(self.user_bob) # The user is removed and the search box is visible again assert not step_page.has_selected_user(self.user_bob) assert search_field.is_displayed() # She hidden field does not contain the ID anymore assert step_page.get_selected_user_id() == '' # She selects the user again step_page.select_user(self.user_bob) # She submits the step step_page.submit_step() # She sees the name is in the overview edit_page = SampleEditPage(self) assert edit_page.has_text(self.user_bob.get_display_name()) # She goes back to the form edit_page.click_edit_category('cat_0') # She sees the user is selected, loading and search fields are # not visible step_page.wait_for(step_page.LOC_LOADING_SEARCH_USER, visibility=False) assert step_page.has_selected_user(self.user_bob) assert step_page.get_selected_user_id() == str(self.user_bob.pk) # She removes the user and selects another one step_page.remove_selected_user(self.user_bob) step_page.select_user(self.user_chris) # She submits the step step_page.submit_step() assert edit_page.has_text(self.user_chris.get_display_name()) # She submits the entire questionnaire and sees the name is there edit_page.submit_questionnaire() assert edit_page.has_text(self.user_chris.get_display_name()) # She checks the database to make sure the user was added. questionnaire = Questionnaire.objects.first() questionnaire_users = sorted(questionnaire.get_users(), key=lambda u: (u[0], u[1].pk)) assert questionnaire_users == [('compiler', self.user_alice), ('landuser', self.user_chris)]
def test_edit_questionnaire(self): user = self.create_new_user(email='*****@*****.**', groups=['Reviewers', 'Publishers']) # Alice logs in # She enters a Questionnaire new_page = SampleNewPage(self) new_page.open(login=True, user=user) new_page.click_edit_category('cat_1') step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, 'Foo') step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_3, 'Bar') step_page.submit_step() # The questionnaire is already saved as draft # She submits it for review edit_page = SampleEditPage(self) edit_page.submit_questionnaire() # She reviews it detail_page = SampleDetailPage(self) detail_page.review_questionnaire() # She publishes it detail_page.publish_questionnaire() # She sees it is public and visible assert detail_page.has_text('Foo') assert detail_page.has_text('Bar') url = self.browser.current_url # She creates a new version detail_page.create_new_version() # She edits it edit_page.click_edit_category('cat_1') # She changes some values step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_1, 'asdf', clear=True) step_page.submit_step() # The questionnaire is already saved as draft # She is taken to the overview page where she sees the latest # (pending) changes of the draft edit_page.check_status('draft') assert not edit_page.has_text('Foo') assert edit_page.has_text('asdf') assert edit_page.has_text('Bar') # She sees the edit buttons assert edit_page.exists_el( edit_page.format_locator(edit_page.LOC_BUTTON_EDIT_CATEGORY, keyword='cat_1')) # She sees the possibility to view the questionnaire edit_page.view_questionnaire() self.assertIn(url, self.browser.current_url + '#top') # All the changes are there assert not detail_page.has_text('Foo') assert detail_page.has_text('asdf') assert detail_page.has_text('Bar') # There are no buttons to edit the sections anymore assert not detail_page.exists_el( detail_page.format_locator(edit_page.LOC_BUTTON_EDIT_CATEGORY, keyword='cat_1'))
def test_add_user(self, mock_search_users, mock_user_information): mock_search_users.side_effect = self.get_mock_remote_user_client_search mock_user_information.side_effect = self.get_mock_remote_user_client_user_information # User logs in and goes to the questionnaire step where he can add a # user. new_page = SampleNewPage(self) new_page.open(login=True, user=self.user_alice) new_page.click_edit_category('cat_0') # The field to search a user is not visible. step_page = SampleStepPage(self) search_field = step_page.get_user_search_field(index=1) assert not search_field.is_displayed() # She clicks the radio to search for an existing user step_page.get_el(step_page.LOC_RADIO_SEARCH_USER).click() # Now the search field is visible assert search_field.is_displayed() # There is no loading indicator loading_indicator = step_page.get_el(step_page.LOC_LOADING_SEARCH_USER) assert not loading_indicator.is_displayed() # She enters a name and sees a search is conducted search_field.send_keys(self.user_bob.firstname) step_page.select_autocomplete(self.user_bob.get_display_name()) # She sees a loading indicator while the user is updated in the DB assert loading_indicator.is_displayed() # She waits until the loading indicator disappears step_page.wait_for(step_page.LOC_LOADING_SEARCH_USER, visibility=False) # She sees that the search field is not visible anymore assert not search_field.is_displayed() # She sees that a field with the name was added assert step_page.has_selected_user(self.user_bob) # She sees that the user ID was added to the hidden field assert step_page.get_selected_user_id() == str(self.user_bob.pk) # She removes the user step_page.remove_selected_user(self.user_bob) # The user is removed and the search box is visible again assert not step_page.has_selected_user(self.user_bob) assert search_field.is_displayed() # She hidden field does not contain the ID anymore assert step_page.get_selected_user_id() == '' # She selects the user again step_page.select_user(self.user_bob) # She submits the step step_page.submit_step() # She sees the name is in the overview edit_page = SampleEditPage(self) assert edit_page.has_text(self.user_bob.get_display_name()) # She goes back to the form edit_page.click_edit_category('cat_0') # She sees the user is selected, loading and search fields are # not visible step_page.wait_for(step_page.LOC_LOADING_SEARCH_USER, visibility=False) assert step_page.has_selected_user(self.user_bob) assert step_page.get_selected_user_id() == str(self.user_bob.pk) # She removes the user and selects another one step_page.remove_selected_user(self.user_bob) step_page.select_user(self.user_chris) # She submits the step step_page.submit_step() assert edit_page.has_text(self.user_chris.get_display_name()) # She submits the entire questionnaire and sees the name is there edit_page.submit_questionnaire() assert edit_page.has_text(self.user_chris.get_display_name()) # She checks the database to make sure the user was added. questionnaire = Questionnaire.objects.first() questionnaire_users = sorted( questionnaire.get_users(), key=lambda u: (u[0], u[1].pk)) assert questionnaire_users == [ ('compiler', self.user_alice), ('landuser', self.user_chris) ]
def test_edit_public(self): code = 'sample_3' user = User.objects.get(pk=101) old_text = 'Faz 3' new_text = 'asdf' # User logs in and goes to the detail page of a "public" Questionnaire detail_page = SampleDetailPage(self) detail_page.route_kwargs = {'identifier': code} detail_page.open(login=True, user=user) assert code in self.browser.current_url assert detail_page.has_text(old_text) assert not detail_page.has_text(new_text) # There is only one version of this questionnaire in the db assert Questionnaire.objects.filter(code=code).count() == 1 # User uses the direct link to go to the edit page of the questionnaire # and sees no new version of the questionnaire is created in the DB. # This prevents the issue when new versions were created upon GET of the # edit page, which should be fixed now. edit_page = SampleEditPage(self) edit_page.route_kwargs = {'identifier': code} edit_page.open() assert Questionnaire.objects.filter(code=code).count() == 1 # User edits the Questionnaire (creates a new version) and sees that # the URL contains the code of the Questionnaire detail_page.open() detail_page.create_new_version() assert code in self.browser.current_url # User edits a category and sees that the URL still contains the # code of the Questionnaire edit_page.click_edit_category('cat_2') assert code in self.browser.current_url # User makes some changes and submits the category step_page = SampleStepPage(self) step_page.enter_text(step_page.LOC_FORM_INPUT_KEY_5, new_text, clear=True) step_page.submit_step() # User is back on the overview page and sees that the URL still # contains the code of the Questionnaire assert code in self.browser.current_url assert edit_page.has_text(code) # She sees that the value of Key 1 was updated assert not edit_page.has_text(old_text) assert edit_page.has_text(new_text) # Also there was an additional version created in the database assert Questionnaire.objects.count() == 11 # The newly created version has the same code assert Questionnaire.objects.filter(code=code).count() == 2 # She goes to see her own questionnaire and sees sample_3 appears only # once my_page = MyDataPage(self) my_page.open() my_page.wait_for_lists() expected_list = [ { 'description': new_text, }, { # Just to check that description is there ... 'description': 'Faz 1' }, # ... the rest does not really matter ] assert my_page.count_list_results() == 6 my_page.check_list_results(expected_list, count=False) # She clicks the first entry and sees that she is taken to the # details page of the latest (pending) version. my_page.click_list_entry(index=0) assert detail_page.has_text(new_text)