class TestGenerateReports(unittest.TestCase): """T1.68 - Generate Reports.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.admin.login() def tearDown(self): """Test destructor.""" self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass # Case C8361 - 001 - Admin | Export research data to OwnCloud Research @pytest.mark.skipif(str(8361) not in TESTS, reason='Excluded') def test_admin_export_research_data_to_own_cloud_research_8361(self): """Export research data to OwnCloud Research. Steps: Open the user menu by clicking on the user's name Click on the 'Admin' button Click the 'Research Data' button Click on the 'Export Data' button Expected Result: The page is reloaded and a confirmation message is displayed. """ self.ps.test_updates['name'] = 't1.68.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.68', 't1.68.001', '8361'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.LINK_TEXT, 'Admin') ) ).click() self.admin.page.wait_for_page_load() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Research Data")]').click() self.admin.driver.find_element( By.XPATH, '//input[@value="Export Data"]').click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"alert-info")]') self.ps.test_updates['passed'] = True
class TestStaxingAdmin(unittest.TestCase): """Staxing case tests.""" def setUp(self): """Pretest settings.""" self.admin = Admin(use_env_vars=True, driver_type=DRIVER) self.admin.set_window_size(height=700, width=1200) def tearDown(self): """Test destructor.""" try: self.admin.delete() except Exception: pass
def test_admin_import_content_into_tutor_7604(self): """Import content into Tutor. Steps: Select Customer Analyst from the dropdown menu on the name Click on Ecosystems in the header Click "Download Manifest" for the desired course Scroll down and click Import a new Ecosystem button. Click "Choose File" Select the downloaded file In comment section add today's date and your name. Eg: 2016-03-03 Kajal Click on the button Import Now wait for at most 5 mins. Expected Result: The message "Ecosystem import job queued" appears at the top """ self.ps.test_updates['name'] = 'cc1.03.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = [ 'cc1', 'cc1.03', 'cc1.03.002', '7604' ] self.ps.test_updates['passed'] = False # Test steps and verification assertions admin = Admin( existing_driver=self.content.driver, username=os.getenv('ADMIN_USER'), password=os.getenv('ADMIN_PASSWORD'), pasta_user=self.ps, capabilities=self.desired_capabilities, ) admin.login() admin.open_user_menu() admin.driver.find_element( By.LINK_TEXT, "Content Analyst" ).click() admin.page.wait_for_page_load() admin.driver.find_element( By.LINK_TEXT, "Ecosystems" ).click() # download a manifest to test with admin.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, "Download Manifest") ) ).click() # import a new ecosystem admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") admin.driver.find_element( By.LINK_TEXT, "Import a new Ecosystem" ).click() # find a downloaded manifest home = os.getenv("HOME") files = os.listdir(home + '/Downloads') file = '' for i in range(len(files)): if (files[i][-4:] == '.yml'): file = files[i] break else: if i == len(files)-1: print('no .yml file found in downloads') raise Exception admin.wait.until( expect.visibility_of_element_located( (By.ID, "ecosystem_manifest") ) ).send_keys(home + '/Downloads/' + file) admin.wait.until( expect.visibility_of_element_located( (By.ID, "ecosystem_comments") ) ).send_keys(str(datetime.date.today()) + ' automated-admin') admin.driver.find_element( By.XPATH, "//input[@type='submit']" ).click() admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//div[contains(@class,"alert-info")]') ) ) admin.delete() self.ps.test_updates['passed'] = True
class TestManageDistricsSchoolsAndCourses(unittest.TestCase): def setUp(self): """Pretest settings.""" # login as admin, go to user menu, click admin option self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) else: self.admin = Admin(use_env_vars=True, ) self.admin.login() self.admin.goto_admin_control() def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() except: pass def test_district_admin(self): """ Go to https://tutor-qa.openstax.org/ Click on the 'Login' button Login to admin account Click on the 'Sign in' button Click on the user menu in the right corner of the header Click "Admin" Click "Course Organization" in the header Click "Districts" Click "Add district" Enter a name for the district in the Name text box Click "Save" ***A new district is added and the user is returned to the 'Districts' section (t1.59.01)*** Click "edit" for a district Enter a new name into the Name text box Click "Save" ***A district's name is changed (t1.59.02) and user should be returned to 'Districts' section*** Click "delete" for the desired district Click "OK" on the dialogue box ***An existing district is deleted (t1.59.03)*** Corresponds to... T1.59 01 --> 3 :return: """ def test_school_admin(self): """ Go to https://tutor-qa.openstax.org/ Login to admin account Click on the 'Sign in' button Click on the user menu in the right corner of the header Click "Admin" Click "Course Organization" in the header Click "Schools" Click "Add school" Enter a name for the school in the Name text box Click "Save" ***A new school is added and the user is returned to the 'Schools' section (t1.59.04)*** Click "edit" for a school Enter a new name into the Name text box Click "Save" ***A school's name is changed (t1.59.05) and user should be returned to 'School' section*** Click "edit" for the desired school Select a new district Click "Save" ***A school's district is changed (t1.59.06)*** Click "delete" for the desired school Click "OK" on the dialogue box ***An existing school is deleted (t1.59.07)*** Corresponds to... T1.59 04 --> 07 :return: """ def test_course_admin(self): """ Pre-req: 'Course-Navigate' Click "Add course" Enter a name in the Name text box Click "Save" ***A new course is added and the user is returned to the 'Courses' section (t1.59.08)*** Click "Edit" for a school Change information in desired text boxes Click "Save" ***The course is edited (t1.59.09) and user should be returned to list of all courses*** Corresponds to... T1.59 08--> 9 :return: """ def test_periods_admin(self): """ Pre-Req "Course-Navigate" Click "Edit" on the desired course Click the "Periods" tab Click "Add Period" Enter a name into the Name text box Click "Save" ***A new empty period is added (t1.59.14)*** Click "Edit" on the desired course Click the "Periods" tab Click "Edit" for the desired period enter new information into the name and enrollment code text boxes Click on the "Save" button ***Period is edited (t1.59.15)*** Click "Edit" on the desired course Click the "Periods" tab Click "Delete" for an empty period ***Empty period is deleted (t1.59.16)*** Click "Edit" on the desired course Click the "Periods" tab Click "Delete" on a non-empty period ***A non-empty period is deleted (t1.59.17)*** Corresponds to... t1.59 14 --> 17 :return: """ def test_teachers_admin(self): """ Click "Edit" on the desired course Click the "Teachers" tab Enter the teacher's name or the username into the search engine Click on the name that matches the teacher's name or the username ***A teacher is added to a course (t1.59.10) and user directed back to the 'Courses' section*** Click "Edit" on the desired course Click the "Teachers" tab Click "Remove from course" for the desired teacher Click "OK" on the dialogue box ***A teacher is removed from a course (t1.59.11)*** Corresponds to... t1.59. 10,11 :return: """ def test_course_ecosystem_admin(self): """ Pre-req: 'Course Navigate' Click "edit" on the desired course Click the "course content" tab Select a course ecosystem Click "Submit" ***Request for course ecosystem update submitted and message displayed (t1.59.12)*** Click "edit" on the desired course Click the "course content" tab Select a course ecosystem Click "Submit" ***The course ecosystem is queued for the course (t1.59.13)*** Check the desired courses to update Scroll to the bottom of the page Select an ecosystem Click "Set ecosystem" ***The message "Course ecosystem update background jobs queued" appears beneath the page title "Courses" (t1.59.19)*** CORRESPONDS TO... T1.59 12,13,19 :return: """ def test_tutor_student_count_admin(self): """
class TestCourseMaintenance(unittest.TestCase): """T1.57 - Course Maintenance.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.admin.login() self.admin.goto_admin_control() self.admin.sleep(5) def tearDown(self): """Test destructor.""" self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass # Case C8311 - 001 - Admin | Import courses from Salesforece @pytest.mark.skipif(str(8311) not in TESTS, reason='Excluded') def test_admin_import_courses_from_salesforce_8311(self): """Import courses from Salesforce. Steps: Click on the user menu Click on the Admin option Click on Salesforce on the header Click on the Import Courses button Expected Result: """ self.ps.test_updates['name'] = 't1.57.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.001', '8311'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8312 - 002 - Admin | Update Salesforce Staistics @pytest.mark.skipif(str(8312) not in TESTS, reason='Excluded') def test_admin_update_salesforce_statistice_8312(self): """Update Salesforce statistics. Steps: Click on the user menu Click on the Admin option Click on Salesforce on the header Click on Update Salesforce Expected Result: """ self.ps.test_updates['name'] = 't1.57.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.002', '8312'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8313 - 003 - Admin | Exclude assesments from all courses @pytest.mark.skipif(str(8313) not in TESTS, reason='Excluded') def test_admin_exclude_assesments_from_all_courses_8313(self): """Exclude assesments from all courses. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.003', '8313'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8314 - 004 - Admin | Add a system notification @pytest.mark.skipif(str(8314) not in TESTS, reason='Excluded') def test_admin_add_a_system_notification_8314(self): """Add a system notification. Steps: Click on the user menu Click on the Admin option Click on System Setting on the header Click on the Notifications option Enter a notification into the New Notification text box Click on the Add button Expected Result: A system notification is added """ self.ps.test_updates['name'] = 't1.57.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.004', '8314'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting') ) ).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications') ) ).click() self.admin.sleep(5) self.admin.find(By.XPATH, "//input[@id='new_message']").send_keys( 'automated test') self.admin.find(By.XPATH, "//input[@class='btn btn-default']").click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break # Case C8315 - 005 - Admin | Delete a system notification @pytest.mark.skipif(str(8315) not in TESTS, reason='Excluded') def test_admin_delete_a_system_notification_8315(self): """Delete a system notification. Steps: Click on the user menu Click on the Admin option Click on System Setting on the header Click on the Notifications option Click on the Remove button next to a notification Click OK on the dialouge box Expected Result: A system notification is deleted """ self.ps.test_updates['name'] = 't1.57.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.005', '8315'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting') ) ).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications') ) ).click() self.admin.sleep(5) self.admin.find(By.XPATH, "//input[@id='new_message']").send_keys( 'automated test') self.admin.find(By.XPATH, "//input[@class='btn btn-default']").click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() break deleted = True notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for n in notif: if n.text.find('automated test') >= 0: deleted = False break if deleted: self.ps.test_updates['passed'] = True
class TestAccountMaintenance(unittest.TestCase): """T1.37 - Account Maintenance.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.admin.login() self.admin.wait = WebDriverWait(self.admin.driver, 15) self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.LINK_TEXT, 'Admin') ) ).click() self.admin.page.wait_for_page_load() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Users")]' ).click() def tearDown(self): """Test destructor.""" self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass # Case C8247 - 001 - Admin | Search for a username @pytest.mark.skipif(str(8247) not in TESTS, reason='Excluded') def test_admin_search_for_a_username_8247(self): """Search for a username. Steps: Enter a username into the search here text box Click on the 'Search' button Expected Result: A list of users with the search term in their name, or username is displayed. """ self.ps.test_updates['name'] = 't1.37.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.001', '8247'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.driver.find_element( By.ID, 'query').send_keys('Atticus') self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element( By.XPATH, '//td[contains(text(),"Atticus")]') self.ps.test_updates['passed'] = True # Case C8248 - 002 - Admin | Search for a user's name @pytest.mark.skipif(str(8248) not in TESTS, reason='Excluded') def test_admin_search_for_a_users_name_8248(self): """Search for a user's name. Steps: Click on the user's name in the top right corner to open drop down menu Click on the 'Admin' option of the drop down menu Click on 'Users' on the bar across the top Enter a user's name into the search here text box Click on the 'Search' button Expected Result: A list of users with the search term in their name, or username is displayed. """ self.ps.test_updates['name'] = 't1.37.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.002', '8248'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.driver.find_element( By.ID, 'query').send_keys('student01') self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element( By.XPATH, '//td[text()="student01"]') self.ps.test_updates['passed'] = True # Case C8249 - 003 - Admin | Create a new user @pytest.mark.skipif(str(8249) not in TESTS, reason='Excluded') def test_admin_create_a_user_8249(self): """Create a new user. Steps: Scroll to the bottom of the page Click on the 'Create user' button Enter account information into: -Username, Password, First name, and Last name text boxes Click on the 'Save' button Expected Result: Takes User back to the Users screen. New user is added. """ self.ps.test_updates['name'] = 't1.37.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.003', '8249'] self.ps.test_updates['passed'] = False # Test steps and verification assertions num = str(randint(0, 999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username')) ).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_'+num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # look up account to check that the account was made self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element( By.XPATH, '//td[text()="automated_test_user_'+num+'"]') self.ps.test_updates['passed'] = True # Case C8250 - 004 - Admin | Edit a user @pytest.mark.skipif(str(8250) not in TESTS, reason='Excluded') def test_admin_edit_a_user_8250(self): """Edit a user. Steps: Create a user to edit Enter the user's name into the search here text box Click on the 'Search' button Click on the 'Edit' button next to the user Enter new account information into the First name text box Click on the 'Save' button Expected Result: User is taken back to the User screen. The chosen account's information is updated """ self.ps.test_updates['name'] = 't1.37.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.004', '8250'] self.ps.test_updates['passed'] = False # create a user num = str(randint(1000, 1999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username')) ).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_'+num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # search for that user self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() # edit user self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Edit")]') ) ).click() self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('_EDITED') self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # search for user to make sure they were updated self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element( By.XPATH, '//td[contains(text(),"first_name_' + num + '_EDITED")]') self.ps.test_updates['passed'] = True # Case C8251 - 005 - Admin | Assign elevated permissions @pytest.mark.skipif(str(8251) not in TESTS, reason='Excluded') def test_admin_assign_elevated_permissions_8251(self): """Assign elevated permissions. Steps: Create a user to edit Enter the user's username into the search here text box Click on the 'Search' button Click on the 'Edit' button next to the user If check box for chosen permission is not checked, click on check box. Click on the 'Save' button Expected Result: User is taken back to the User screen. The chosen account's permissions are modified. """ self.ps.test_updates['name'] = 't1.37.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.005', '8251'] self.ps.test_updates['passed'] = False # create a user num = str(randint(2000, 2999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username')) ).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_'+num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # search for that user self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() # edit user self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Edit")]') ) ).click() self.admin.driver.find_element( By.ID, 'user_content_analyst').click() self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # search for user to make sure they were updated self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() element = self.admin.driver.find_element(By.XPATH, '//tr/td[5]') assert(element.get_attribute('innerHTML') == 'Yes'), \ 'permission not elevated ' + element.get_attribute('innerHTML') self.ps.test_updates['passed'] = True # Case C8252 - 006 - Admin | Remove elevated permissions @pytest.mark.skipif(str(8252) not in TESTS, reason='Excluded') def test_admin_remove_elevated_permissions_8252(self): """Remove elevated permissions. Steps: Create a user to edit Enter the user's name into the search here text box Click on the 'Search' button Click on the 'Edit' button next to the user If check box for chosen permission is checked, click to uncheck it. Click on the 'Save' button Expected Result: User is taken back to the User screen. The chosen account's permissions are modified. """ self.ps.test_updates['name'] = 't1.37.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.006', '8252'] self.ps.test_updates['passed'] = False # create a user num = str(randint(3000, 3999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username')) ).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_'+num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_'+num) self.admin.driver.find_element( By.ID, 'user_content_analyst').click() self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # search for that user self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() element = self.admin.driver.find_element(By.XPATH, '//tr/td[5]') assert(element.get_attribute('innerHTML') == 'Yes'), \ 'permission not elevated ' + element.get_attribute('innerHTML') # edit user self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Edit")]') ) ).click() self.admin.driver.find_element( By.ID, 'user_content_analyst').click() self.admin.driver.find_element( By.XPATH, '//input[@value="Save"]').click() # search for user to make sure they were updated self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'query')) ).send_keys('automated_test_user_'+num) self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() element = self.admin.driver.find_element(By.XPATH, '//tr/td[5]') assert(element.get_attribute('innerHTML') == 'No'), \ 'permission not elevated ' + element.get_attribute('innerHTML') self.ps.test_updates['passed'] = True # Case C8253 - 007 - Admin | Impersonate a user @pytest.mark.skipif(str(8253) not in TESTS, reason='Excluded') def test_admin_impersonate_a_user_8253(self): """Impersonate a user. Steps: Click on the 'Sign in as' button next to a user Expected Result: Signs in as chosen chosen user. Goes to chosen users initial screen after login (different depending on the user) """ self.ps.test_updates['name'] = 't1.37.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.007', '8253'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.driver.find_element(By.ID, 'query').send_keys('student01') self.admin.driver.find_element( By.XPATH, '//input[@value="Search"]').click() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Sign in as")]') ) ).click() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//span[contains(text(),"Atticus Finch")]') ) ) self.ps.test_updates['passed'] = True
class TestOpenStaxMetrics(unittest.TestCase): """CC1.15 - OpenStax Metrics.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) def tearDown(self): """Test destructor.""" self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass # Case C7608 - 001 - Admin | View a report of enrolled students by course @pytest.mark.skipif(str(7608) not in TESTS, reason='Excluded') def test_admin_view_a_report_of_enrolled_students_by_course_7608(self): """View a report of enrolled students by course. Steps: Go to Tutor Click on the 'Login' button Enter the admin user account in the username and password text boxes Click on the 'Sign in' button Click on the 'Admin' button from the user menu Open the drop down menu by clicking 'Course Organization' Click the 'Courses' option Click the 'List Students' button for the chosen course Expected Result: List of students for chosen course is displayed """ self.ps.test_updates['name'] = 'cc1.15.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = [ 'cc1', 'cc1.15', 'cc1.15.001', '7608' ] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.login() self.admin.open_user_menu() self.admin.find( By.LINK_TEXT, 'Admin' ).click() self.admin.page.wait_for_page_load() self.admin.find( By.LINK_TEXT, 'Course Organization' ).click() self.admin.find( By.LINK_TEXT, 'Courses' ).click() self.admin.page.wait_for_page_load() self.admin.find( By.LINK_TEXT, 'List Students' ).click() # assert thaken to correct page self.admin.find( By.XPATH, '//h1[contains(text(),"Students for course")]' ) assert('student' in self.admin.current_url()) self.ps.test_updates['passed'] = True
def test_admin_import_content_into_tutor_7604(self): """Import content into Tutor. Steps: Select Customer Analyst from the dropdown menu on the name Click on Ecosystems in the header Click "Download Manifest" for the desired course Scroll down and click Import a new Ecosystem button. Click "Choose File" Select the downloaded file In comment section add today's date and your name. Eg: 2016-03-03 Kajal Click on the button Import Now wait for at most 5 mins. Expected Result: The message "Ecosystem import job queued" appears at the top """ self.ps.test_updates['name'] = 'cc1.03.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['cc1', 'cc1.03', 'cc1.03.002', '7604'] self.ps.test_updates['passed'] = False # Test steps and verification assertions if not LOCAL_RUN: admin = Admin( use_env_vars=True, existing_driver=self.content.driver, pasta_user=self.ps, capabilities=self.desired_capabilities, ) else: admin = Admin( use_env_vars=True, existing_driver=self.content.driver, ) admin.login() admin.open_user_menu() admin.driver.find_element(By.LINK_TEXT, "Content Analyst").click() admin.page.wait_for_page_load() admin.driver.find_element(By.LINK_TEXT, "Ecosystems").click() # download a manifest to test with admin.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, "Download Manifest"))).click() # import a new ecosystem admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") admin.driver.find_element(By.LINK_TEXT, "Import a new Ecosystem").click() # find a downloaded manifest home = os.getenv("HOME") files = os.listdir(home + '/Downloads') file = '' for i in range(len(files)): if (files[i][-4:] == '.yml'): file = files[i] break else: if i == len(files) - 1: print('no .yml file found in downloads') raise Exception admin.wait.until( expect.visibility_of_element_located( (By.ID, "ecosystem_manifest"))).send_keys(home + '/Downloads/' + file) admin.wait.until( expect.visibility_of_element_located( (By.ID, "ecosystem_comments"))).send_keys( str(datetime.date.today()) + ' automated-admin') admin.driver.find_element(By.XPATH, "//input[@type='submit']").click() admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//div[contains(@class,"alert-info")]'))) admin.delete() self.ps.test_updates['passed'] = True
class TestAccountMaintenance(unittest.TestCase): """T1.37 - Account Maintenance.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.admin.login() self.admin.wait = WebDriverWait(self.admin.driver, 15) self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable((By.LINK_TEXT, 'Admin'))).click() self.admin.page.wait_for_page_load() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Users")]').click() def tearDown(self): """Test destructor.""" self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() except: pass # Case C8247 - 001 - Admin | Search for a username @pytest.mark.skipif(str(8247) not in TESTS, reason='Excluded') def test_admin_search_for_a_username_8247(self): """Search for a username. Steps: Enter a username into the search here text box Click on the 'Search' button Expected Result: A list of users with the search term in their name, or username is displayed. """ self.ps.test_updates['name'] = 't1.37.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.001', '8247'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.driver.find_element(By.ID, 'query').send_keys('Atticus') self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element(By.XPATH, '//td[contains(text(),"Atticus")]') self.ps.test_updates['passed'] = True # Case C8248 - 002 - Admin | Search for a user's name @pytest.mark.skipif(str(8248) not in TESTS, reason='Excluded') def test_admin_search_for_a_users_name_8248(self): """Search for a user's name. Steps: Click on the user's name in the top right corner to open drop down menu Click on the 'Admin' option of the drop down menu Click on 'Users' on the bar across the top Enter a user's name into the search here text box Click on the 'Search' button Expected Result: A list of users with the search term in their name, or username is displayed. """ self.ps.test_updates['name'] = 't1.37.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.002', '8248'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.driver.find_element(By.ID, 'query').send_keys('student01') self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element(By.XPATH, '//td[text()="student01"]') self.ps.test_updates['passed'] = True # Case C8249 - 003 - Admin | Create a new user @pytest.mark.skipif(str(8249) not in TESTS, reason='Excluded') def test_admin_create_a_user_8249(self): """Create a new user. Steps: Scroll to the bottom of the page Click on the 'Create user' button Enter account information into: -Username, Password, First name, and Last name text boxes Click on the 'Save' button Expected Result: Takes User back to the Users screen. New user is added. """ self.ps.test_updates['name'] = 't1.37.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.003', '8249'] self.ps.test_updates['passed'] = False # Test steps and verification assertions num = str(randint(0, 999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username'))).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_' + num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # look up account to check that the account was made self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element( By.XPATH, '//td[text()="automated_test_user_' + num + '"]') self.ps.test_updates['passed'] = True # Case C8250 - 004 - Admin | Edit a user @pytest.mark.skipif(str(8250) not in TESTS, reason='Excluded') def test_admin_edit_a_user_8250(self): """Edit a user. Steps: Create a user to edit Enter the user's name into the search here text box Click on the 'Search' button Click on the 'Edit' button next to the user Enter new account information into the First name text box Click on the 'Save' button Expected Result: User is taken back to the User screen. The chosen account's information is updated """ self.ps.test_updates['name'] = 't1.37.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.004', '8250'] self.ps.test_updates['passed'] = False # create a user num = str(randint(1000, 1999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username'))).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_' + num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # search for that user self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() # edit user self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Edit")]'))).click() self.admin.driver.find_element(By.ID, 'user_first_name').send_keys('_EDITED') self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # search for user to make sure they were updated self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() self.admin.driver.find_element( By.XPATH, '//td[contains(text(),"first_name_' + num + '_EDITED")]') self.ps.test_updates['passed'] = True # Case C8251 - 005 - Admin | Assign elevated permissions @pytest.mark.skipif(str(8251) not in TESTS, reason='Excluded') def test_admin_assign_elevated_permissions_8251(self): """Assign elevated permissions. Steps: Create a user to edit Enter the user's username into the search here text box Click on the 'Search' button Click on the 'Edit' button next to the user If check box for chosen permission is not checked, click on check box. Click on the 'Save' button Expected Result: User is taken back to the User screen. The chosen account's permissions are modified. """ self.ps.test_updates['name'] = 't1.37.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.005', '8251'] self.ps.test_updates['passed'] = False # create a user num = str(randint(2000, 2999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username'))).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_' + num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # search for that user self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() # edit user self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Edit")]'))).click() self.admin.driver.find_element(By.ID, 'user_content_analyst').click() self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # search for user to make sure they were updated self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() element = self.admin.driver.find_element(By.XPATH, '//tr/td[5]') assert(element.get_attribute('innerHTML') == 'Yes'), \ 'permission not elevated ' + element.get_attribute('innerHTML') self.ps.test_updates['passed'] = True # Case C8252 - 006 - Admin | Remove elevated permissions @pytest.mark.skipif(str(8252) not in TESTS, reason='Excluded') def test_admin_remove_elevated_permissions_8252(self): """Remove elevated permissions. Steps: Create a user to edit Enter the user's name into the search here text box Click on the 'Search' button Click on the 'Edit' button next to the user If check box for chosen permission is checked, click to uncheck it. Click on the 'Save' button Expected Result: User is taken back to the User screen. The chosen account's permissions are modified. """ self.ps.test_updates['name'] = 't1.37.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.006', '8252'] self.ps.test_updates['passed'] = False # create a user num = str(randint(3000, 3999)) self.admin.driver.execute_script( "window.scrollTo(0, document.body.scrollHeight);") self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Create user")]').click() self.admin.wait.until( expect.element_to_be_clickable((By.ID, 'user_username'))).click() self.admin.driver.find_element( By.ID, 'user_username').send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.ID, 'user_password').send_keys('password') self.admin.driver.find_element( By.ID, 'user_first_name').send_keys('first_name_' + num) self.admin.driver.find_element( By.ID, 'user_last_name').send_keys('last_name_' + num) self.admin.driver.find_element(By.ID, 'user_content_analyst').click() self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # search for that user self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() element = self.admin.driver.find_element(By.XPATH, '//tr/td[5]') assert(element.get_attribute('innerHTML') == 'Yes'), \ 'permission not elevated ' + element.get_attribute('innerHTML') # edit user self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Edit")]'))).click() self.admin.driver.find_element(By.ID, 'user_content_analyst').click() self.admin.driver.find_element(By.XPATH, '//input[@value="Save"]').click() # search for user to make sure they were updated self.admin.wait.until(expect.element_to_be_clickable( (By.ID, 'query'))).send_keys('automated_test_user_' + num) self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() element = self.admin.driver.find_element(By.XPATH, '//tr/td[5]') assert(element.get_attribute('innerHTML') == 'No'), \ 'permission not elevated ' + element.get_attribute('innerHTML') self.ps.test_updates['passed'] = True # Case C8253 - 007 - Admin | Impersonate a user @pytest.mark.skipif(str(8253) not in TESTS, reason='Excluded') def test_admin_impersonate_a_user_8253(self): """Impersonate a user. Steps: Click on the 'Sign in as' button next to a user Expected Result: Signs in as chosen chosen user. Goes to chosen users initial screen after login (different depending on the user) """ self.ps.test_updates['name'] = 't1.37.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.37', 't1.37.007', '8253'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.driver.find_element(By.ID, 'query').send_keys('student01') self.admin.driver.find_element(By.XPATH, '//input[@value="Search"]').click() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Sign in as")]'))).click() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//span[contains(text(),"Atticus Finch")]'))) self.ps.test_updates['passed'] = True
class TestManageEcosystems(unittest.TestCase): def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.content = ContentQA(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) else: self.admin = Admin(use_env_vars=True) self.content = ContentQA(use_env_vars=True, existing_driver=self.admin.driver) self.wait = WebDriverWait(self.admin.driver, Assignment.WAIT_TIME) self.admin.login() self.wait.sleep(2) self.admin.goto_admin_control() def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() # self.content.delete() except: pass def test_content_tag_search_admin(self): """ Go to https://tutor-qa.openstax.org/ Login to admin account Open the drop down menu by clicking on the user menu link containing the user's name Click on the 'Admin' button Open the drop down menu by clicking 'Content' Click the 'Tags' button Enter text into the text box with 'Search here' Click the 'Search' button ***Results of the search are returned.(t1.58.19)*** Click the 'Edit' button for one of the returned tags Edit the text box labeled 'Name' Edit the text box labeled 'Description' Click the 'Save' button ***The user is returned to the Tags page and the text 'The tag has been updated.' is displayed. (t1.58.20)*** :return: CORRESPONDS TO: t1.58.19,20 """ # t1.58.19 --> Results of the search are returned. content_dropdown = "//a[contains(@class,'dropdown-toggle') and " + \ "contains(text(),'Content')]" content_ecosystems = "//a[contains(text(),'Tags')]" search_term = "bio" search_btn = "//input[contains(@value,'Search')]" # (t1.58.20) --> The user is returned to the Tags page and the text # 'The tag has been updated.' is displayed. edit = "//a[contains(@edit,'Edit')]" # NEED CODE FOR ACTUALLY FILLING IN TEXTBOXES print(content_dropdown, content_ecosystems, search_term, search_btn) print(edit) self.admin.find(By.XPATH, "//div[contains(@class,'alert-info')]") self.admin.find( By.XPATH, "//div[contains(@class,'alert-info')]" + "//*[contains(text(),'The tag has been updated')]")
class TestCourseMaintenance(unittest.TestCase): """T1.57 - Course Maintenance.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.admin.login() self.admin.goto_admin_control() self.admin.sleep(5) def tearDown(self): """Test destructor.""" self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() except: pass # Case C8311 - 001 - Admin | Import courses from Salesforece @pytest.mark.skipif(str(8311) not in TESTS, reason='Excluded') def test_admin_import_courses_from_salesforce_8311(self): """Import courses from Salesforce. Steps: Click on the user menu Click on the Admin option Click on Salesforce on the header Click on the Import Courses button Expected Result: """ self.ps.test_updates['name'] = 't1.57.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.001', '8311'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8312 - 002 - Admin | Update Salesforce Staistics @pytest.mark.skipif(str(8312) not in TESTS, reason='Excluded') def test_admin_update_salesforce_statistice_8312(self): """Update Salesforce statistics. Steps: Click on the user menu Click on the Admin option Click on Salesforce on the header Click on Update Salesforce Expected Result: """ self.ps.test_updates['name'] = 't1.57.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.002', '8312'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8313 - 003 - Admin | Exclude assesments from all courses @pytest.mark.skipif(str(8313) not in TESTS, reason='Excluded') def test_admin_exclude_assesments_from_all_courses_8313(self): """Exclude assesments from all courses. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.003', '8313'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8314 - 004 - Admin | Add a system notification @pytest.mark.skipif(str(8314) not in TESTS, reason='Excluded') def test_admin_add_a_system_notification_8314(self): """Add a system notification. Steps: Click on the user menu Click on the Admin option Click on System Setting on the header Click on the Notifications option Enter a notification into the New Notification text box Click on the Add button Expected Result: A system notification is added """ self.ps.test_updates['name'] = 't1.57.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.004', '8314'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//input[@id='new_message']").send_keys('automated test') self.admin.find(By.XPATH, "//input[@class='btn btn-default']").click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break # Case C8315 - 005 - Admin | Delete a system notification @pytest.mark.skipif(str(8315) not in TESTS, reason='Excluded') def test_admin_delete_a_system_notification_8315(self): """Delete a system notification. Steps: Click on the user menu Click on the Admin option Click on System Setting on the header Click on the Notifications option Click on the Remove button next to a notification Click OK on the dialouge box Expected Result: A system notification is deleted """ self.ps.test_updates['name'] = 't1.57.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.005', '8315'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//input[@id='new_message']").send_keys('automated test') self.admin.find(By.XPATH, "//input[@class='btn btn-default']").click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() break deleted = True notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for n in notif: if n.text.find('automated test') >= 0: deleted = False break if deleted: self.ps.test_updates['passed'] = True
class TestOpenStaxMetrics(unittest.TestCase): """CC1.15 - OpenStax Metrics.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) else: self.admin = Admin( use_env_vars=True, ) def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass # Case C7608 - 001 - Admin | View a report of enrolled students by course @pytest.mark.skipif(str(7608) not in TESTS, reason='Excluded') def test_admin_view_a_report_of_enrolled_students_by_course_7608(self): """View a report of enrolled students by course. Steps: Go to Tutor Click on the 'Login' button Enter the admin user account in the username and password text boxes Click on the 'Sign in' button Click on the 'Admin' button from the user menu Open the drop down menu by clicking 'Course Organization' Click the 'Courses' option Click the 'List Students' button for the chosen course Expected Result: List of students for chosen course is displayed """ self.ps.test_updates['name'] = 'cc1.15.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = [ 'cc1', 'cc1.15', 'cc1.15.001', '7608' ] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.login() self.admin.open_user_menu() self.admin.find( By.LINK_TEXT, 'Admin' ).click() self.admin.page.wait_for_page_load() self.admin.find( By.LINK_TEXT, 'Course Organization' ).click() self.admin.find( By.LINK_TEXT, 'Courses' ).click() self.admin.page.wait_for_page_load() self.admin.find( By.LINK_TEXT, 'List Students' ).click() # assert thaken to correct page self.admin.find( By.XPATH, '//h1[contains(text(),"Students for course")]' ) assert('student' in self.admin.current_url()) self.ps.test_updates['passed'] = True
class TestUserLogin(unittest.TestCase): """T1.36 - User login.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.content = ContentQA(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.student = Student(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.teacher = Teacher(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) else: self.admin = Admin(use_env_vars=True, ) self.content = ContentQA( existing_driver=self.admin.driver, use_env_vars=True, ) self.student = Student( existing_driver=self.admin.driver, use_env_vars=True, ) self.teacher = Teacher( existing_driver=self.admin.driver, use_env_vars=True, ) def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.teacher = None self.student = None self.content = None self.admin.delete() except: pass # Case C8238 - 001 - Admin | Log into Tutor @pytest.mark.skipif(str(8238) not in TESTS, reason='Excluded') def test_admin_log_into_tutor_8238(self): """Log into Tutor. Steps: Click on the 'Log in' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Expected Result: User is logged in """ self.ps.test_updates['name'] = 't1.36.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.001', '8238'] self.ps.test_updates['passed'] = False self.admin.get(self.admin.url) self.admin.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.admin.driver.get_window_size()['width'] <= \ self.admin.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.admin.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.admin.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Log in'))).click() self.admin.page.wait_for_page_load() self.admin.find(By.ID, 'login_username_or_email') \ .send_keys(self.admin.username) self.admin.find(By.XPATH, "//input[@value='Next']").click() self.admin.find(By.ID, 'login_password') \ .send_keys(self.admin.password) # click on the sign in button self.admin.find(By.XPATH, "//input[@value='Log in']").click() self.admin.page.wait_for_page_load() assert('dashboard' in self.admin.current_url()), \ 'Not taken to dashboard: %s' % self.admin.current_url() self.ps.test_updates['passed'] = True # Case C8239 - 002 - Admin | Access the Admin Console @pytest.mark.skipif(str(8239) not in TESTS, reason='Excluded') def test_admin_access_the_admin_console_8239(self): """Access the Admin console. Steps: Click on the 'Log in' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Click on the user menu Click on the Admin option Expected Result: User is presented with the admin console """ self.ps.test_updates['name'] = 't1.36.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.002', '8239'] self.ps.test_updates['passed'] = False self.admin.login() self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable((By.LINK_TEXT, 'Admin'))).click() self.admin.page.wait_for_page_load() self.admin.find(By.XPATH, '//h1[contains(text(),"Admin Console")]') self.ps.test_updates['passed'] = True # Case C8240 - 003 - Admin | Log out @pytest.mark.skipif(str(8240) not in TESTS, reason='Excluded') def test_admin_log_out_8240(self): """Log out. Steps: Click on the 'Log in' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The User is signed out """ self.ps.test_updates['name'] = 't1.36.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.003', '8240'] self.ps.test_updates['passed'] = False self.admin.login() self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log out")]'))).click() self.admin.page.wait_for_page_load() self.admin.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C8241 - 004 - Content Analyst | Log into Tutor @pytest.mark.skipif(str(8241) not in TESTS, reason='Excluded') def test_content_analyst_log_into_tutor_8241(self): """Log into Tutor. Steps: Click on the 'Log in' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Expected Result: The user is signed in """ self.ps.test_updates['name'] = 't1.36.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.004', '8241'] self.ps.test_updates['passed'] = False self.content.get(self.content.url) self.content.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.content.driver.get_window_size()['width'] <= \ self.content.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.content.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.content.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Log in'))).click() self.content.page.wait_for_page_load() self.content.find(By.ID, 'login_username_or_email') \ .send_keys(self.content.username) self.content.find(By.XPATH, "//input[@value='Next']").click() self.content.find(By.ID, 'login_password') \ .send_keys(self.content.password) # click on the sign in button self.content.find(By.XPATH, "//input[@value='Log in']").click() self.content.page.wait_for_page_load() assert('dashboard' in self.content.current_url()), \ 'Not taken to dashboard: %s' % self.content.current_url() self.ps.test_updates['passed'] = True # Case C8242 - 005 - Content Analyst | Access the QA Viewer @pytest.mark.skipif(str(8242) not in TESTS, reason='Excluded') def test_content_analyst_access_the_qa_viewer_8242(self): """Access the QA Viewer. Steps: Click on the 'Log in' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the QA Content option Expected Result: The user is presented with the QA viewer """ self.ps.test_updates['name'] = 't1.36.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.005', '8242'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//div[contains(text(),"QA Content")]'))).click() self.content.page.wait_for_page_load() assert('/qa' in self.content.current_url()), \ 'Not taken to the QA viewer: %s' % self.content.current_url() self.ps.test_updates['passed'] = True # Case C8243 - 006 - Content Analyst | Access the Content Analyst Console @pytest.mark.skipif(str(8243) not in TESTS, reason='Excluded') def test_content_analyst_access_the_content_analyst_console_8243(self): """Access the Content Annalyst Console. Steps: Click on the 'Log in' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Content Analyst option Expected Result: The user is presented with the Content Analyst Console """ self.ps.test_updates['name'] = 't1.36.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.006', '8243'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//div[contains(text(),"Content Analyst")]'))).click() self.content.page.wait_for_page_load() self.content.find(By.XPATH, '//h1[contains(text(),"Content Analyst Console")]') self.ps.test_updates['passed'] = True # Case C8244 - 007 - Content Analyst | Log out @pytest.mark.skipif(str(8244) not in TESTS, reason='Excluded') def test_content_analyst_log_out_8244(self): """Log out. Steps: Click on the 'Log in' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.007', '8244'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log out")]'))).click() self.content.page.wait_for_page_load() self.content.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C8245 - 008 - Student | Log into Tutor @pytest.mark.skipif(str(8245) not in TESTS, reason='Excluded') def test_student_log_into_tutor_8245(self): """Log into Tutor. Steps: Click on the 'Log in' button Enter the student account in the username and password text boxes Click on the 'Sign in' button Expected Result: The user is logged in """ self.ps.test_updates['name'] = 't1.36.008' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.008', '8245'] self.ps.test_updates['passed'] = False self.student.get(self.student.url) self.student.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.student.driver.get_window_size()['width'] <= \ self.student.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.student.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.student.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Log in'))).click() self.student.page.wait_for_page_load() self.student.find(By.ID, 'login_username_or_email') \ .send_keys(self.student.username) self.student.find(By.XPATH, "//input[@value='Next']") \ .click() self.student.find(By.ID, 'login_password') \ .send_keys(self.student.password) # click on the sign in button self.student.find(By.XPATH, "//input[@value='Log in']").click() self.student.page.wait_for_page_load() assert('dashboard' in self.student.current_url()), \ 'Not taken to dashboard: %s' % self.student.current_url() self.ps.test_updates['passed'] = True # Case C8246 - 009 - Teacher | Log into Tutor @pytest.mark.skipif(str(8246) not in TESTS, reason='Excluded') def test_teacher_log_into_tutor_8246(self): """Log into Tutor. Steps: Click on the 'Log in' button Enter the teacher account in the username and password text boxes Click on the 'Sign in' button Expected Result: The user is logged in """ self.ps.test_updates['name'] = 't1.36.009' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.009', '8246'] self.ps.test_updates['passed'] = False self.teacher.get(self.teacher.url) self.teacher.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.teacher.driver.get_window_size()['width'] <= \ self.teacher.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.teacher.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.teacher.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Log in'))).click() self.teacher.page.wait_for_page_load() self.teacher.find(By.ID, 'login_username_or_email') \ .send_keys(self.teacher.username) self.teacher.find(By.XPATH, "//input[@value='Next']").click() self.teacher.find(By.ID, 'login_password') \ .send_keys(self.teacher.password) # click on the sign in button self.teacher.find(By.XPATH, "//input[@value='Log in']").click() self.teacher.page.wait_for_page_load() assert('dashboard' in self.teacher.current_url()),\ 'Not taken to dashboard: %s' % self.teacher.current_url() self.ps.test_updates['passed'] = True # Case C58271 - 010 - Student | Log out @pytest.mark.skipif(str(58271) not in TESTS, reason='Excluded') def test_content_analyst_log_out_58271(self): """Log out. Steps: Click on the 'Log in' button Enter the student account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.010' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.010', '58271'] self.ps.test_updates['passed'] = False self.student.login() self.student.open_user_menu() self.student.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log out")]'))).click() self.student.page.wait_for_page_load() self.student.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C58272 - 011 - Teacher | Log out @pytest.mark.skipif(str(58272) not in TESTS, reason='Excluded') def test_teacher_log_out_58272(self): """Log out. Steps: Click on the 'Log in' button Enter the teacher account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.011' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.011', '58272'] self.ps.test_updates['passed'] = False self.teacher.login() self.teacher.open_user_menu() self.teacher.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log out")]'))).click() self.teacher.page.wait_for_page_load() self.teacher.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C96962 - 012 - Content Reviewer | Log into Exercises @pytest.mark.skipif(str(96962) not in TESTS, reason='Excluded') def test_content_reviewer_log_into_exercises_96962(self): """Log into Exercises. Steps: Go to https://exercises-qa.openstax.org/ Click "SIGN IN" Enter the Content username into "Email or username" text box Click "Next" Enter the Content password into "password" text box Click "Login" Expected Result: User is logged in """ self.ps.test_updates['name'] = 't1.36.012' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.012', '96962'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.content.driver.get("https://exercises-qa.openstax.org/") self.content.sleep(3) self.content.find(By.LINK_TEXT, "SIGN IN").click() self.content.find(By.XPATH, "//input[@id='login_username_or_email']") \ .send_keys(os.getenv('CONTENT_USER')) self.content.find(By.XPATH, "//input[@id='login_username_or_email']") \ .send_keys(Keys.RETURN) self.content.sleep(2) self.content.find(By.XPATH, "//input[@id='login_password']") \ .send_keys(os.getenv('CONTENT_PASSWORD')) self.content.find(By.XPATH, "//input[@id='login_password']") \ .send_keys(Keys.RETURN) self.content.sleep(3) self.content.find(By.LINK_TEXT, "SIGN OUT") self.ps.test_updates['passed'] = True # Case C96963 - 013 - Content Reviewer | Access Reviewer Display @pytest.mark.skipif(str(96963) not in TESTS, reason='Excluded') def test_content_reviewer_access_reviewer_display_96963(self): """Access Reviewer Display. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.36.013' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.013', '96963'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C96964 - 014 - Content Reviewer | Log out @pytest.mark.skipif(str(96964) not in TESTS, reason='Excluded') def test_content_reviewer_log_out_96964(self): """Log out. Steps: go to https://exercises-qa.openstax.org/ Click "SIGN IN" Enter [content] into "Email or username" text box Click "Next" Enter [staxly16] into "password" text box Click "Login" Click "SIGN OUT" Expected Result: User is logged out. """ self.ps.test_updates['name'] = 't1.36.014' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.014', '96964'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.content.driver.get("https://exercises-qa.openstax.org/") self.content.sleep(3) self.content.find(By.LINK_TEXT, "SIGN IN").click() self.content.find(By.XPATH, "//input[@id='login_username_or_email']") \ .send_keys(os.getenv('CONTENT_USER')) self.content.find(By.XPATH, "//input[@id='login_username_or_email']") \ .send_keys(Keys.RETURN) self.content.sleep(2) self.content.find(By.XPATH, "//input[@id='login_password']") \ .send_keys(os.getenv('CONTENT_PASSWORD')) self.content.find(By.XPATH, "//input[@id='login_password']") \ .send_keys(Keys.RETURN) self.content.sleep(3) self.content.find(By.LINK_TEXT, "SIGN OUT").click() self.content.sleep(2) self.content.find(By.LINK_TEXT, "SIGN IN") self.ps.test_updates['passed'] = True # Case C96965 - 015 - Content Editor | Log into Exercises @pytest.mark.skipif(str(96965) not in TESTS, reason='Excluded') def test_content_editor_log_into_exercises_96965(self): """Log into Exercises. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.36.015' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.015', '96965'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C96962 - 016 - Content Editor | Access the Exercise Editor @pytest.mark.skipif(str(96966) not in TESTS, reason='Excluded') def test_content_editor_access_the_exercise_editor_96966(self): """Access the Exercise Editor. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.36.016' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.016', '96966'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C96967 - 017 - Content Editor | Log out @pytest.mark.skipif(str(96967) not in TESTS, reason='Excluded') def test_content_editor_log_out_96967(self): """Log out. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.36.017' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.017', '96967'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True
class TestTutorAdmin(unittest.TestCase): """Tutor | Teacher""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) else: self.admin = Admin( use_env_vars=True ) def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job( job_id=str(self.teacher.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass @pytest.mark.skipif(str(162255) not in TESTS, reason='Excluded') def test_admin_change_course_start_end_dates_162255(self): """ Log in as an Admin Go to the course management page Edit a course Change the term and course year Click Save ***Start and end dates should reflect the new term's timeframe*** Edit a course Change the Starts at date and Ends at date Click Save Expected Result: ***Start and end dates are changed*** https://trello.com/c/YuvX7DN0/25-admin-change-course-start-end-dates """ self.ps.test_updates['name'] = 'tutor_course_settings_admin_162255' + \ inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['tutor', 'course_settings', 'admin', '162255'] self.ps.test_updates['passed'] = False # go to courses admin page directly and log in URL = str(os.getenv('SERVER_URL')) + '/admin/courses' self.admin.login(url=URL) # search 'preview' in the search bar self.admin.find(By.CSS_SELECTOR, "#search-courses").send_keys('preview\n') self.admin.page.wait_for_page_load() pages = self.admin.find_all(By.CSS_SELECTOR, ".pagination>a") # go to very last page self.admin.scroll_to(pages[-2]) self.admin.sleep(1) pages[-2].click() # click on Edit button for very last course edit = self.admin.find_all(By.XPATH, ".//*[contains(text(),'Edit')]") self.admin.scroll_to(edit[-1]) edit[-1].click() # change year field by adding 1 yearfield = self.admin.find(By.CSS_SELECTOR, "#course_year") year = yearfield.get_attribute('value') newyear = str(int(year) + 1) yearfield.send_keys(len(year) * Keys.DELETE) yearfield.send_keys(newyear) # change start date and end date oldstartdatefield = self.admin.find(By.CSS_SELECTOR, "#course_starts_at") oldenddatefield = self.admin.find(By.CSS_SELECTOR, "#course_ends_at") # get start date and end date values oldstartdate = oldstartdatefield.get_attribute('value') oldenddate = oldenddatefield.get_attribute('value') change = datetime.timedelta(days=400) # converts start date and end date values into datetime objects and adds the change newstartdate = datetime.datetime.strptime( oldstartdate, '%Y-%m-%d %X %Z') + change # converts into a string format accepted by the form oldstartdatefield.send_keys( datetime.datetime.strftime( newstartdate, '%Y/%m/%d %X' )[:-3] ) # converts start date and end date values into datetime objects and adds change ( 400 days) newenddate = datetime.datetime.strptime( oldenddate, '%Y-%m-%d %X %Z') + change # converts into a string format accepted by teh form # newenddate = datetime.datetime.strftime(newenddate1, '%Y/%m/%d %X')[:-3] oldenddatefield.send_keys( datetime.datetime.strftime( newenddate, '%Y/%m/%d %X')[:-3] ) # saves changes self.admin.sleep(1) self.admin.find(By.CSS_SELECTOR, "#edit-save").click() self.admin.sleep(1) # updated start date and end date fields, get their values updatedstartdate = self.admin.find( By.CSS_SELECTOR, "#course_starts_at").get_attribute('value') updatedstartdatetime = datetime.datetime.strptime( updatedstartdate, '%Y-%m-%d %X %Z' ) updatedenddate = self.admin.find( By.CSS_SELECTOR, "#course_ends_at").get_attribute('value') updatedenddatetime = datetime.datetime.strptime( updatedenddate, '%Y-%m-%d %X %Z' ) # assert that the datetime objects I put into it are the ones in the updated field assert(newstartdate.isocalendar() == updatedstartdatetime.isocalendar()) assert(newenddate.isocalendar() == updatedenddatetime.isocalendar()) # change start date and end date to what it was yearfield = self.admin.find(By.CSS_SELECTOR, "#course_year") yearfield.send_keys(len(year) * Keys.DELETE) yearfield.send_keys(year) startdatefield = self.admin.find(By.CSS_SELECTOR, "#course_starts_at") startdatefield.send_keys(datetime.datetime.strftime( datetime.datetime.strptime(oldstartdate, '%Y-%m-%d %X %Z'), '%Y/%m/%d %X')[:-3] ) enddatefield = self.admin.find(By.CSS_SELECTOR, "#course_ends_at") enddatefield.send_keys(datetime.datetime.strftime( datetime.datetime.strptime(oldenddate, '%Y-%m-%d %X %Z'), '%Y/%m/%d %X')[:-3] ) self.admin.find(By.CSS_SELECTOR, "#edit-save").click() self.ps.test_updates['passed'] = True @pytest.mark.skipif(str(162256) not in TESTS, reason='Excluded') def test_notification_and_faulty_url_162256(self): """ Go to tutor qa Log in as admin Click "Admin" from the user menu Click "System Setting" Click "Notifications" Enter a new notification into the text box Click "Add" Log out of admin account Log in as a teacher ***An orange header with the notification pops up when you sign in*** Go to a fake url page to test if styled error page is displayed Expected result: ***a styled error page is displayed*** Corresponding test case: T2.18 001, 030 """ self.ps.test_updates['name'] = 'tutor_system_settings_admin_162256' + \ inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['tutor', 'system_settings', 'admin', '162256'] self.ps.test_updates['passed'] = False # go to admin instance self.admin.login(url=os.getenv('SERVER_URL') + '/admin') # go to system settings, then notifications, then set a notification self.admin.find(By.XPATH,".//*[contains(text(),'System Setting')]").click() self.admin.find(By.CSS_SELECTOR,"a[href*='notification']").click() self.admin.find(By.CSS_SELECTOR, "#message").send_keys('test_notification') self.admin.find(By.CSS_SELECTOR, ".btn.btn-default").click() # logout of admin self.admin.find(By.XPATH,".//*[contains(text(),'admin')]").click() self.admin.find(By.CSS_SELECTOR, 'a[href*="logout"]').click() # log into teacher account self.admin.login(username=os.getenv('TEACHER_USER'), password=os.getenv('TEACHER_PASSWORD')) self.admin.find(By.CSS_SELECTOR, '.my-courses-item-title>a').click() # if popup asking how you will be using Tutor shows up try: self.admin.find(By.XPATH, './/*[contains(text(),"I don’t know yet")]') except: pass # checks if notification is there self.admin.wait.until( expect.visibility_of_element_located(( By.XPATH, '//div[contains(@class,"notifications-bar")]' + '//span[text()="test_notification"]' )) ) self.admin.find( By.XPATH, '//div[contains(@class,"notifications-bar")]' + '//span[text()="test_notification"]' ) # log out of teacher self.admin.logout() # log into admin self.admin.login(url=os.getenv('SERVER_URL') + '/admin') self.admin.find(By.XPATH, '//a[text()="System Setting"]').click() self.admin.find(By.XPATH, '//a[text()="Notifications"]').click() # remove general notification self.admin.find(By.XPATH, '//a[text()="Remove"]').click() self.admin.driver.switch_to_alert().accept() # go to invalid website self.admin.get(os.getenv('SERVER_URL') + '/not_a_Real_page') # confirm styling of webpage self.admin.find(By.CSS_SELECTOR, '.invalid-page') self.ps.test_updates['passed'] = True
class TestUserLogin(unittest.TestCase): """T1.36 - User login.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.content = ContentQA(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.student = Student(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.teacher = Teacher(existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) def tearDown(self): """Test destructor.""" self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.teacher = None self.student = None self.content = None self.admin.delete() except: pass # Case C8238 - 001 - Admin | Log into Tutor @pytest.mark.skipif(str(8238) not in TESTS, reason='Excluded') def test_admin_log_into_tutor_8238(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Expected Result: User is logged in """ self.ps.test_updates['name'] = 't1.36.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.001', '8238'] self.ps.test_updates['passed'] = False self.admin.get(self.admin.url) self.admin.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.admin.driver.get_window_size()['width'] <= \ self.admin.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.admin.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.admin.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login'))).click() self.admin.page.wait_for_page_load() self.admin.find(By.ID, 'auth_key').send_keys(self.admin.username) self.admin.find(By.ID, 'password').send_keys(self.admin.password) # click on the sign in button self.admin.find(By.XPATH, '//button[text()="Sign in"]').click() self.admin.page.wait_for_page_load() assert('dashboard' in self.admin.current_url()), \ 'Not taken to dashboard: %s' % self.admin.current_url() self.ps.test_updates['passed'] = True # Case C8239 - 002 - Admin | Access the Admin Console @pytest.mark.skipif(str(8239) not in TESTS, reason='Excluded') def test_admin_access_the_admin_console_8239(self): """Access the Admin console. Steps: Click on the 'Login' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Click on the user menu Click on the Admin option Expected Result: User is presented with the admin console """ self.ps.test_updates['name'] = 't1.36.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.002', '8239'] self.ps.test_updates['passed'] = False # self.user = admin self.admin.login() self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable((By.LINK_TEXT, 'Admin'))).click() self.admin.page.wait_for_page_load() self.admin.find(By.XPATH, '//h1[contains(text(),"Admin Console")]') self.ps.test_updates['passed'] = True # Case C8240 - 003 - Admin | Log out @pytest.mark.skipif(str(8240) not in TESTS, reason='Excluded') def test_admin_log_out_8240(self): """Log out. Steps: Click on the 'Login' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The User is signed out """ self.ps.test_updates['name'] = 't1.36.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.003', '8240'] self.ps.test_updates['passed'] = False self.admin.login() self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]'))).click() self.admin.page.wait_for_page_load() self.admin.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C8241 - 004 - Content Analyst | Log into Tutor @pytest.mark.skipif(str(8241) not in TESTS, reason='Excluded') def test_content_analyst_log_into_tutor_8241(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Expected Result: The user is signed in """ self.ps.test_updates['name'] = 't1.36.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.004', '8241'] self.ps.test_updates['passed'] = False self.content.get(self.content.url) self.content.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.content.driver.get_window_size()['width'] <= \ self.content.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.content.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.content.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login'))).click() self.content.page.wait_for_page_load() self.content.find(By.ID, 'auth_key').send_keys(self.content.username) self.content.find(By.ID, 'password').send_keys(self.content.password) # click on the sign in button self.content.find(By.XPATH, '//button[text()="Sign in"]').click() self.content.page.wait_for_page_load() assert('dashboard' in self.content.current_url()), \ 'Not taken to dashboard: %s' % self.content.current_url() self.ps.test_updates['passed'] = True # Case C8242 - 005 - Content Analyst | Access the QA Viewer @pytest.mark.skipif(str(8242) not in TESTS, reason='Excluded') def test_content_analyst_access_the_qa_viewer_8242(self): """Access the QA Viewer. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the QA Content option Expected Result: The user is presented with the QA viewer """ self.ps.test_updates['name'] = 't1.36.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.005', '8242'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"QA Content") and @role="menuitem"]' ))).click() self.content.page.wait_for_page_load() assert('/qa' in self.content.current_url()), \ 'Not taken to the QA viewer: %s' % self.content.current_url() self.ps.test_updates['passed'] = True # Case C8243 - 006 - Content Analyst | Access the Content Analyst Console @pytest.mark.skipif(str(8243) not in TESTS, reason='Excluded') def test_content_analyst_access_the_content_analyst_console_8243(self): """Access the Content Annalyst Console. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Content Analyst option Expected Result: The user is presented with the Content Analyst Console """ self.ps.test_updates['name'] = 't1.36.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.006', '8243'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Content Analyst") and @role="menuitem"]' ))).click() self.content.page.wait_for_page_load() self.content.find(By.XPATH, '//h1[contains(text(),"Content Analyst Console")]') self.ps.test_updates['passed'] = True # Case C8244 - 007 - Content Analyst | Log out @pytest.mark.skipif(str(8244) not in TESTS, reason='Excluded') def test_content_analyst_log_out_8244(self): """Log out. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.007', '8244'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]'))).click() self.content.page.wait_for_page_load() self.content.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C8245 - 008 - Student | Log into Tutor @pytest.mark.skipif(str(8245) not in TESTS, reason='Excluded') def test_student_log_into_tutor_8245(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the student account in the username and password text boxes Click on the 'Sign in' button Expected Result: The user is logged in """ self.ps.test_updates['name'] = 't1.36.008' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.008', '8245'] self.ps.test_updates['passed'] = False self.student.get(self.student.url) self.student.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.student.driver.get_window_size()['width'] <= \ self.student.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.student.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.student.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login'))).click() self.student.page.wait_for_page_load() self.student.find(By.ID, 'auth_key').send_keys(self.student.username) self.student.find(By.ID, 'password').send_keys(self.student.password) # click on the sign in button self.student.find(By.XPATH, '//button[text()="Sign in"]').click() self.student.page.wait_for_page_load() assert('dashboard' in self.student.current_url()), \ 'Not taken to dashboard: %s' % self.student.current_url() self.ps.test_updates['passed'] = True # Case C8246 - 009 - Teacher | Log into Tutor @pytest.mark.skipif(str(8246) not in TESTS, reason='Excluded') def test_teacher_log_into_tutor_8246(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the teacher account in the username and password text boxes Click on the 'Sign in' button Expected Result: The user is logged in """ self.ps.test_updates['name'] = 't1.36.009' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.009', '8246'] self.ps.test_updates['passed'] = False self.teacher.get(self.teacher.url) self.teacher.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.teacher.driver.get_window_size()['width'] <= \ self.teacher.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.teacher.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]') # check if the menu is collapsed and, if yes, open it if ('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.teacher.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login'))).click() self.teacher.page.wait_for_page_load() self.teacher.find(By.ID, 'auth_key').send_keys(self.teacher.username) self.teacher.find(By.ID, 'password').send_keys(self.teacher.password) # click on the sign in button self.teacher.find(By.XPATH, '//button[text()="Sign in"]').click() self.teacher.page.wait_for_page_load() assert('dashboard' in self.teacher.current_url()),\ 'Not taken to dashboard: %s' % self.teacher.current_url() self.ps.test_updates['passed'] = True # Case C58271 - 010 - Student | Log out @pytest.mark.skipif(str(58271) not in TESTS, reason='Excluded') def test_content_analyst_log_out_58271(self): """Log out. Steps: Click on the 'Login' button Enter the student account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.010' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.010', '58271'] self.ps.test_updates['passed'] = False self.student.login() self.student.open_user_menu() self.student.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]'))).click() self.student.page.wait_for_page_load() self.student.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C58272 - 011 - Teacher | Log out @pytest.mark.skipif(str(58272) not in TESTS, reason='Excluded') def test_teacher_log_out_58272(self): """Log out. Steps: Click on the 'Login' button Enter the teacher account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.011' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.011', '58272'] self.ps.test_updates['passed'] = False self.teacher.login() self.teacher.open_user_menu() self.teacher.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]'))).click() self.teacher.page.wait_for_page_load() self.teacher.find(By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True
class TestContractControls(unittest.TestCase): """T1.35 - Contract Controls.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.admin.login() # make sure there are no new terms to accept try: self.admin.driver.find_element( By.ID, 'i_agree' ).click() self.admin.driver.find_element( By.ID, 'agreement_submit' ).click() except NoSuchElementException: pass # go to admin console self.wait = WebDriverWait(self.admin.driver, 15) self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.LINK_TEXT, 'Admin') ) ).click() self.admin.page.wait_for_page_load() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Legal")]').click() def tearDown(self): """Test destructor.""" self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.admin.delete() except: pass # Case C8228 - 001 - Admin | Add a new contract @pytest.mark.skipif(str(8228) not in TESTS, reason='Excluded') def test_admin_add_a_new_contract_8228(self): """Add a new contract. Steps: Click on the 'Terms' option Click on the "New Contract" Link Enter information into the Name, Title, and Content text boxes Click on the 'Create contract' button Expected Result: Contract is created as a draft. User is shown the contract they just made, and has options on what to do with it next """ self.ps.test_updates['name'] = 't1.35.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.001', '8228'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_001') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_001') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_001') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.driver.find_element( By.XPATH, '//h1[contains(text(),"Details")]').click() self.ps.test_updates['passed'] = True # Case C8229 - 002 - Admin | Cancel adding a new contract @pytest.mark.skipif(str(8229) not in TESTS, reason='Excluded') def test_admin_cancel_adding_a_new_contract_8229(self): """Cancel adding a new contract. Steps: Click on the 'Terms' option Click on the "New Contract" Link Enter information into the Name, Title, and Content text boxes Click on the 'Create contract' button Click on the Delete link Expected Result: Contract is deleted. User is taken back to the Contracts page. """ self.ps.test_updates['name'] = 't1.35.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.002', '8229'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_002') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_002') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_002') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="Delete"]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"alert-info")]') contracts = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"test_contract_title_002")]') assert(len(contracts) == 0), 'contract not cancled' self.ps.test_updates['passed'] = True # Case C8230 - 003 - Admin | Publish a draft contract @pytest.mark.skipif(str(8230) not in TESTS, reason='Excluded') def test_admin_publish_a_draft_contract_8230(self): """Publish a draft contract. Steps: Click on the 'Terms' option Create a draft contract and return to contract list Click on the draft contract Click on the Publish link Click ok Expected Result: Draft contract is published """ self.ps.test_updates['name'] = 't1.35.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.003', '8230'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_003') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_003') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_003') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]') ) ).click() self.admin.driver.find_element( By.XPATH, '//li//a[contains(text(),"test_contract_title_003")]').click() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Publish")]').click() try: WebDriverWait(self.admin.driver, 3). \ until( expect.alert_is_present(), 'Timed out waiting for alert.' ) alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') self.ps.test_updates['passed'] = True # Case C8231 - 004 - Admin | Delete a draft contract @pytest.mark.skipif(str(8231) not in TESTS, reason='Excluded') def test_admin_delete_a_draft_contract_8231(self): """Delete a draft contract. Steps: Click on the 'Terms' option Create a draft contract and return to the contract list Click on the draft contract Click on Delete next to chosen draft contract Expected Result: Draft contract is deleted """ self.ps.test_updates['name'] = 't1.35.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.004', '8231'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() contracts_original = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"test_contract_title_004")]') self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_004') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_004') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_004') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]') ) ).click() self.admin.driver.find_element( By.XPATH, '//li//a[contains(text(),"test_contract_title_004")]').click() self.admin.page.wait_for_page_load() self.admin.sleep(2) self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Delete")]').click() self.admin.sleep(2) try: WebDriverWait(self.admin.driver, 3). \ until( expect.alert_is_present(), 'Timed out waiting for alert.' ) alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') self.admin.page.wait_for_page_load() contracts = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"test_contract_title_004")]') self.admin.page.wait_for_page_load() assert(len(contracts) == len(contracts_original)), \ 'contract not deleted' self.ps.test_updates['passed'] = True # Case C8232 - 005 - Admin | View a current contract @pytest.mark.skipif(str(8232) not in TESTS, reason='Excluded') def test_admin_view_a_current_contract_8232(self): """View a current contract. Steps: Click on the 'Terms' option Create a contract and then return to contract list Click on chosen contract Expected Result: Displays the information of chosen contract. """ self.ps.test_updates['name'] = 't1.35.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.005', '8232'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_005') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_005') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_005') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]') ) ).click() self.admin.driver.find_element( By.XPATH, '//li//a[contains(text(),"test_contract_title_005")]').click() self.admin.driver.find_element( By.XPATH, '//h2[contains(text(),"test_contract_title_005")]') self.ps.test_updates['passed'] = True # Case C8233 - 006 - Admin | Add a new version of a current contract @pytest.mark.skipif(str(8233) not in TESTS, reason='Excluded') def test_admin_add_a_new_version_of_a_current_contract_8233(self): """Add a new version of a current contract. Steps: Click on the 'Terms' option Click on New version next to chosen contract Update information in the Name, Title, and Content text boxes. Click on the 'Create Contract' button Expected Result: New version of contract is saved as a draft. """ self.ps.test_updates['name'] = 't1.35.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.006', '8233'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="New Version"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('NEW_006') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('NEW_006') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('NEW_006') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.driver.find_element( By.XPATH, '//h2[contains(text(),"NEW_006")]') self.ps.test_updates['passed'] = True # Case C8234 - 007 - Admin | View a contract's signatories @pytest.mark.skipif(str(8234) not in TESTS, reason='Excluded') def test_admin_view_a_contracts_signatures_8234(self): """View a contract's signatories. Steps: Click on the 'Terms' option Click on Signatures next to chosen draft contract Expected Result: Displays list of signatures for the chosen contract. """ self.ps.test_updates['name'] = 't1.35.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.007', '8234'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() wait = WebDriverWait(self.admin.driver, 45) self.admin.driver.find_element( By.XPATH, '//a[text()="Signatures"]').click() wait.until( expect.element_to_be_clickable( (By.XPATH, '//div[contains(@class,"signature_index")]') ) ) self.ps.test_updates['passed'] = True # Case C8235 - 008 - Admin | Terminate a signatory's contract @pytest.mark.skipif(str(8235) not in TESTS, reason='Excluded') def test_admin_terminate_a_signnatorys_contract_8235(self): """Terminate a signatory's contract. Steps: Click on the 'Terms' option Click on Signatures next to chosen draft contract Click on Terminate next to chosen user Click on the 'ok' button Expected Result: Selected user's signing of contract is terminated. """ self.ps.test_updates['name'] = 't1.35.008' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.008', '8235'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//a[text()="Signatures"]').click() # is it okay to just terminate some random person's signature wait = WebDriverWait(self.admin.driver, 45) wait.until( expect.element_to_be_clickable( (By.XPATH, '//td//a[contains(text(),"Terminate")]') ) ).click() try: WebDriverWait(self.admin.driver, 3). \ until(expect.alert_is_present(), 'Timed out waiting for PA creation ' + 'confirmation popup to appear.') alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') self.ps.test_updates['passed'] = True # Case C8236 - 009 - Admin | Add a targeted contract @pytest.mark.skipif(str(8236) not in TESTS, reason='Excluded') def test_admin_add_a_targeted_contract_8236(self): """Add a targeted contract. Steps: Click on the 'Targeted Contracts' option Click on the 'Add Target Contract' button Click the 'Submit' button Expected Result: User taken back to Targeted contracts page. New Targeted Contract is added """ self.ps.test_updates['name'] = 't1.35.009' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.009', '8236'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Targeted Contracts")]') ) ).click() orig_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') self.admin.driver.find_element( By.XPATH, '//a[text()="Add Targeted Contract"]').click() self.admin.driver.find_element( By.XPATH, '//input[@value="Submit"]').click() end_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') assert(len(orig_contracts) == len(end_contracts)-1), \ 'targeted contract not added' self.ps.test_updates['passed'] = True # Case C8237 - 010 - Admin | Delete a targeted contract @pytest.mark.skipif(str(8237) not in TESTS, reason='Excluded') def test_admin_delete_a_targeted_contract_8237(self): """Delete a targeted contract. Steps: Click on the user's name in the top right corner to open drop down menu Click on the 'Admin' option of the drop down menu Click on 'Legal' on the bar across the top to open drop down menu Click on the 'Targeted Contracts' option Create a targeted contract and return to the list of targed contracts Click on delete next to chosen contract Click on the 'ok' button Expected Result: Targeted contract is deleted """ self.ps.test_updates['name'] = 't1.35.010' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.010', '8237'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Targeted Contracts")]') ) ).click() orig_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') # create contract self.admin.driver.find_element( By.XPATH, '//a[text()="Add Targeted Contract"]').click() self.admin.driver.find_element( By.XPATH, '//input[@value="Submit"]').click() # delete contract deletes = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"delete")]') deletes[-1].click() try: WebDriverWait(self.admin.driver, 3).until( expect.alert_is_present(), 'Timed out waiting for alert.' ) alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') end_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') assert(len(orig_contracts) == len(end_contracts)), \ 'targeted contract not added' self.ps.test_updates['passed'] = True # Case C8389 - 011 - Admin | Edit a draft contract @pytest.mark.skipif(str(8389) not in TESTS, reason='Excluded') def test_admin_edit_a_draft_contract_8389(self): """Edit a draft contract. Steps: Click on the 'Terms' option Create a new contract and return to list of contracts Click on Edit next to chosen draft contract Enter new information into the Name, Title, and Content text boxes Click on the 'Update Contract' button Expected Result: User is taken to Details page for selected contract. """ self.ps.test_updates['name'] = 't1.35.011' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.011', '8389'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_011') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_011') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_011') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]') ) ).click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//li//a[contains(text(),"test_contract_title_011")]') ) ).click() self.admin.sleep(1) self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="Edit"]') ) ).click() self.admin.sleep(1) self.admin.driver.find_element( By.ID, 'contract_name').send_keys('_New') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('_New') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('_New') self.admin.driver.find_element( By.XPATH, '//input[@value="Update contract"]').click() self.admin.sleep(1) self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h2[contains(text(),"test_contract_title_011_New")]') ) ) self.ps.test_updates['passed'] = True
class TestManageDistricsSchoolsAndCourses(unittest.TestCase): """T1.59 - Manage districts, schools, and courses.""" def setUp(self): """Pretest settings.""" # login as admin, go to user menu, click admin option self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) else: self.admin = Admin(use_env_vars=True, ) self.wait = WebDriverWait(self.admin.driver, Assignment.WAIT_TIME) self.admin.login() self.admin.goto_admin_control() def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() except: pass def test_set_course_details_admin(self): """ Pre-req: "Course-Navigate" Log into Admin Click on user name for drop down Click on 'Admin' option in menu Click on 'Course Organization' for dropdown menu Click on 'Courses' Click on 'Edit' Type new course scholastic year into 'Year' text-book ***(t1.59.21)*** Type new number into number of sections ***(t1.59.22)*** Set the course start date and time under the 'Starts at' text box ***(t1.59.23)*** Set the course end date and time under the 'Ends at' textbox ***(t1.59.24)*** Set the course offering under the 'Catalog Offering' dropdown ***(t1.59.25)*** Set the course offering appearance code under the 'Appearance Code' dropdown ***(t1.59.26)*** Click 'Course duration' ***End and start dates should be displayed (t2.07.11)*** Corresponds to... t1.59 21 --> 26 :return: """ # t1.59.21 --> Type new course scholastic year into 'Year' text-book # Setup() leaves you at the admin control self.admin.goto_course_list() ### # Create the course create_new_course = self.admin.find(By.XPATH, "//a[text()='Add Course']") self.admin.driver.execute_script( 'return arguments[0].scrollIntoView();', create_new_course) create_new_course.click() self.admin.find( By.ID, "course_year").send_keys((Keys.DELETE * 4) + str(datetime.date.today().year)) # t1.59.22 --> Type new number into number of sections self.admin.find(By.ID, "course_num_sections").send_keys((Keys.DELETE) + str(1)) # t1.59.23 -->Set the course start date and time under the 'Starts at' text box self.admin.find(By.ID, "course_starts_at").click() self.admin.sleep(1) next_calendar_arrows = self.admin.find_all( By.XPATH, '//div[contains(@class,"datepicker")]' + '//button[contains(@class,"_next")]') # next_calendar_arrows[0].click() # have to find all because the two right arrows for the # start and end date have identical xpath's --> doing this allows us to pick the first or second #get the date right_now = datetime.datetime.now() hour_plus_one = str(right_now.replace(hour=right_now.hour + 1).hour) month_now = str(right_now.replace(month=right_now.month - 1).month) month_plus_one = str( right_now.month) # months are 1 minus their actual number print(right_now) print(month_now) print(hour_plus_one) print(month_plus_one) self.admin.find( By.XPATH, '//div[contains(@class,"calendar")]' + '//td[@data-date="1" and @data-month="{0}"]'.format(month_now) ).click() # Choose start date self.wait.until( expect.visibility_of_element_located( (By.XPATH, '//div[contains(@class,"timepicker")]//div[@data-hour="{0}"]'. format(hour_plus_one)))).click() # t1.59.24 --> Set the course end date and time under the 'Ends at' textbox # Choose end date self.admin.find(By.ID, "course_ends_at").click() self.admin.sleep(1) next_calendar_arrows[-1].click() self.admin.find_all( By.XPATH, '//div[contains(@class,"calendar")]' + '//td[@data-date="1" and @data-month="{0}"]'.format(month_plus_one) )[-1].click() self.admin.sleep(5) # choose end time self.admin.find_all( By.XPATH, '//div[contains(@class,"timepicker")]//div[@data-hour="{0}"]'. format(hour_plus_one))[-1].click() # t1.59.25 --> Set the course offering under the 'Catalog Offering' dropdown self.admin.find(By.ID, "course_catalog_offering_id").click() self.admin.find( By.XPATH, '//select[@id="course_catalog_offering_id"]/option[2]').click() # t1.59.26 -->Set the course offering appearance code under the 'Appearance Code' dropdown self.admin.find(By.ID, "course_appearance_code").click() self.admin.find( By.XPATH, '//select[@id="course_appearance_code"]/option[2]').click()
class TestUserLogin(unittest.TestCase): """T1.36 - User login.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin( use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.content = ContentQA( existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.student = Student( existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) self.teacher = Teacher( existing_driver=self.admin.driver, use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities ) def tearDown(self): """Test destructor.""" self.ps.update_job( job_id=str(self.admin.driver.session_id), **self.ps.test_updates ) try: self.teacher = None self.student = None self.content = None self.admin.delete() except: pass # Case C8238 - 001 - Admin | Log into Tutor @pytest.mark.skipif(str(8238) not in TESTS, reason='Excluded') def test_admin_log_into_tutor_8238(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Expected Result: User is logged in """ self.ps.test_updates['name'] = 't1.36.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.001', '8238'] self.ps.test_updates['passed'] = False self.admin.get(self.admin.url) self.admin.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.admin.driver.get_window_size()['width'] <= \ self.admin.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.admin.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]' ) # check if the menu is collapsed and, if yes, open it if('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.admin.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login') ) ).click() self.admin.page.wait_for_page_load() self.admin.find( By.ID, 'auth_key' ).send_keys(self.admin.username) self.admin.find( By.ID, 'password' ).send_keys(self.admin.password) # click on the sign in button self.admin.find( By.XPATH, '//button[text()="Sign in"]' ).click() self.admin.page.wait_for_page_load() assert('dashboard' in self.admin.current_url()), \ 'Not taken to dashboard: %s' % self.admin.current_url() self.ps.test_updates['passed'] = True # Case C8239 - 002 - Admin | Access the Admin Console @pytest.mark.skipif(str(8239) not in TESTS, reason='Excluded') def test_admin_access_the_admin_console_8239(self): """Access the Admin console. Steps: Click on the 'Login' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Click on the user menu Click on the Admin option Expected Result: User is presented with the admin console """ self.ps.test_updates['name'] = 't1.36.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.002', '8239'] self.ps.test_updates['passed'] = False # self.user = admin self.admin.login() self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.LINK_TEXT, 'Admin') ) ).click() self.admin.page.wait_for_page_load() self.admin.find( By.XPATH, '//h1[contains(text(),"Admin Console")]') self.ps.test_updates['passed'] = True # Case C8240 - 003 - Admin | Log out @pytest.mark.skipif(str(8240) not in TESTS, reason='Excluded') def test_admin_log_out_8240(self): """Log out. Steps: Click on the 'Login' button Enter the admin account in the username and password text boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The User is signed out """ self.ps.test_updates['name'] = 't1.36.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.003', '8240'] self.ps.test_updates['passed'] = False self.admin.login() self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]') ) ).click() self.admin.page.wait_for_page_load() self.admin.find( By.XPATH, '//div[contains(@class,"tutor-home")]') self.ps.test_updates['passed'] = True # Case C8241 - 004 - Content Analyst | Log into Tutor @pytest.mark.skipif(str(8241) not in TESTS, reason='Excluded') def test_content_analyst_log_into_tutor_8241(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Expected Result: The user is signed in """ self.ps.test_updates['name'] = 't1.36.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.004', '8241'] self.ps.test_updates['passed'] = False self.content.get(self.content.url) self.content.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.content.driver.get_window_size()['width'] <= \ self.content.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.content.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]' ) # check if the menu is collapsed and, if yes, open it if('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.content.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login') ) ).click() self.content.page.wait_for_page_load() self.content.find( By.ID, 'auth_key' ).send_keys(self.content.username) self.content.find( By.ID, 'password' ).send_keys(self.content.password) # click on the sign in button self.content.find( By.XPATH, '//button[text()="Sign in"]' ).click() self.content.page.wait_for_page_load() assert('dashboard' in self.content.current_url()), \ 'Not taken to dashboard: %s' % self.content.current_url() self.ps.test_updates['passed'] = True # Case C8242 - 005 - Content Analyst | Access the QA Viewer @pytest.mark.skipif(str(8242) not in TESTS, reason='Excluded') def test_content_analyst_access_the_qa_viewer_8242(self): """Access the QA Viewer. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the QA Content option Expected Result: The user is presented with the QA viewer """ self.ps.test_updates['name'] = 't1.36.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.005', '8242'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable(( By.XPATH, '//a[contains(text(),"QA Content") and @role="menuitem"]' )) ).click() self.content.page.wait_for_page_load() assert('/qa' in self.content.current_url()), \ 'Not taken to the QA viewer: %s' % self.content.current_url() self.ps.test_updates['passed'] = True # Case C8243 - 006 - Content Analyst | Access the Content Analyst Console @pytest.mark.skipif(str(8243) not in TESTS, reason='Excluded') def test_content_analyst_access_the_content_analyst_console_8243(self): """Access the Content Annalyst Console. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Content Analyst option Expected Result: The user is presented with the Content Analyst Console """ self.ps.test_updates['name'] = 't1.36.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.006', '8243'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable(( By.XPATH, '//a[contains(text(),"Content Analyst") and @role="menuitem"]' )) ).click() self.content.page.wait_for_page_load() self.content.find( By.XPATH, '//h1[contains(text(),"Content Analyst Console")]' ) self.ps.test_updates['passed'] = True # Case C8244 - 007 - Content Analyst | Log out @pytest.mark.skipif(str(8244) not in TESTS, reason='Excluded') def test_content_analyst_log_out_8244(self): """Log out. Steps: Click on the 'Login' button Enter the content analyst account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.007', '8244'] self.ps.test_updates['passed'] = False self.content.login() self.content.open_user_menu() self.content.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]') ) ).click() self.content.page.wait_for_page_load() self.content.find( By.XPATH, '//div[contains(@class,"tutor-home")]' ) self.ps.test_updates['passed'] = True # Case C8245 - 008 - Student | Log into Tutor @pytest.mark.skipif(str(8245) not in TESTS, reason='Excluded') def test_student_log_into_tutor_8245(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the student account in the username and password text boxes Click on the 'Sign in' button Expected Result: The user is logged in """ self.ps.test_updates['name'] = 't1.36.008' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.008', '8245'] self.ps.test_updates['passed'] = False self.student.get(self.student.url) self.student.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.student.driver.get_window_size()['width'] <= \ self.student.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.student.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]' ) # check if the menu is collapsed and, if yes, open it if('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.student.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login') ) ).click() self.student.page.wait_for_page_load() self.student.find( By.ID, 'auth_key' ).send_keys(self.student.username) self.student.find( By.ID, 'password' ).send_keys(self.student.password) # click on the sign in button self.student.find( By.XPATH, '//button[text()="Sign in"]' ).click() self.student.page.wait_for_page_load() assert('dashboard' in self.student.current_url()), \ 'Not taken to dashboard: %s' % self.student.current_url() self.ps.test_updates['passed'] = True # Case C8246 - 009 - Teacher | Log into Tutor @pytest.mark.skipif(str(8246) not in TESTS, reason='Excluded') def test_teacher_log_into_tutor_8246(self): """Log into Tutor. Steps: Click on the 'Login' button Enter the teacher account in the username and password text boxes Click on the 'Sign in' button Expected Result: The user is logged in """ self.ps.test_updates['name'] = 't1.36.009' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.009', '8246'] self.ps.test_updates['passed'] = False self.teacher.get(self.teacher.url) self.teacher.page.wait_for_page_load() # check to see if the screen width is normal or condensed if self.teacher.driver.get_window_size()['width'] <= \ self.teacher.CONDENSED_WIDTH: # get small-window menu toggle is_collapsed = self.teacher.find( By.XPATH, '//button[contains(@class,"navbar-toggle")]' ) # check if the menu is collapsed and, if yes, open it if('collapsed' in is_collapsed.get_attribute('class')): is_collapsed.click() self.teacher.wait.until( expect.visibility_of_element_located( (By.LINK_TEXT, 'Login') ) ).click() self.teacher.page.wait_for_page_load() self.teacher.find( By.ID, 'auth_key' ).send_keys(self.teacher.username) self.teacher.find( By.ID, 'password' ).send_keys(self.teacher.password) # click on the sign in button self.teacher.find( By.XPATH, '//button[text()="Sign in"]' ).click() self.teacher.page.wait_for_page_load() assert('dashboard' in self.teacher.current_url()),\ 'Not taken to dashboard: %s' % self.teacher.current_url() self.ps.test_updates['passed'] = True # Case C58271 - 010 - Student | Log out @pytest.mark.skipif(str(58271) not in TESTS, reason='Excluded') def test_content_analyst_log_out_58271(self): """Log out. Steps: Click on the 'Login' button Enter the student account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.010' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.010', '58271'] self.ps.test_updates['passed'] = False self.student.login() self.student.open_user_menu() self.student.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]') ) ).click() self.student.page.wait_for_page_load() self.student.find( By.XPATH, '//div[contains(@class,"tutor-home")]' ) self.ps.test_updates['passed'] = True # Case C58272 - 011 - Teacher | Log out @pytest.mark.skipif(str(58272) not in TESTS, reason='Excluded') def test_teacher_log_out_58272(self): """Log out. Steps: Click on the 'Login' button Enter the teacher account in the username and password boxes Click on the 'Sign in' button Click on the user menu Click on the Log out option Expected Result: The user is logged out """ self.ps.test_updates['name'] = 't1.36.011' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.36', 't1.36.011', '58272'] self.ps.test_updates['passed'] = False self.teacher.login() self.teacher.open_user_menu() self.teacher.wait.until( expect.element_to_be_clickable( (By.XPATH, '//input[contains(@value,"Log Out")]') ) ).click() self.teacher.page.wait_for_page_load() self.teacher.find( By.XPATH, '//div[contains(@class,"tutor-home")]' ) self.ps.test_updates['passed'] = True
class TestCourseMaintenance(unittest.TestCase): """T1.57 - Course Maintenance.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) self.admin.login() self.admin.goto_admin_control() self.admin.sleep(5) def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() except: pass # Case C8311 - 001 - Admin | Import courses from Salesforece @pytest.mark.skipif(str(8311) not in TESTS, reason='Excluded') def test_admin_import_courses_from_salesforce_8311(self): """Import courses from Salesforce. Steps: Click on the user menu Click on the Admin option Click on Salesforce on the header Click on the Import Courses button Expected Result: """ self.ps.test_updates['name'] = 't1.57.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.001', '8311'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8312 - 002 - Admin | Update Salesforce Staistics @pytest.mark.skipif(str(8312) not in TESTS, reason='Excluded') def test_admin_update_salesforce_statistice_8312(self): """Update Salesforce statistics. Steps: Click on the user menu Click on the Admin option Click on Salesforce on the header Click on Update Salesforce Expected Result: """ self.ps.test_updates['name'] = 't1.57.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.002', '8312'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8313 - 003 - Admin | Exclude assesments from all courses @pytest.mark.skipif(str(8313) not in TESTS, reason='Excluded') def test_admin_exclude_assesments_from_all_courses_8313(self): """Exclude assesments from all courses. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.003', '8313'] self.ps.test_updates['passed'] = False # Test steps and verification assertions raise NotImplementedError(inspect.currentframe().f_code.co_name) self.ps.test_updates['passed'] = True # Case C8314 - 004 - Admin | Add a system notification @pytest.mark.skipif(str(8314) not in TESTS, reason='Excluded') def test_admin_add_a_system_notification_8314(self): """Add a system notification. Steps: Click on the user menu Click on the Admin option Click on System Setting on the header Click on the Notifications option Enter a notification into the New Notification text box Click on the Add button Expected Result: A system notification is added """ self.ps.test_updates['name'] = 't1.57.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.004', '8314'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//input[@id='new_message']").send_keys('automated test') self.admin.find(By.XPATH, "//input[@class='btn btn-default']").click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break # Case C8315 - 005 - Admin | Delete a system notification @pytest.mark.skipif(str(8315) not in TESTS, reason='Excluded') def test_admin_delete_a_system_notification_8315(self): """Delete a system notification. Steps: Click on the user menu Click on the Admin option Click on System Setting on the header Click on the Notifications option Click on the Remove button next to a notification Click OK on the dialouge box Expected Result: A system notification is deleted """ self.ps.test_updates['name'] = 't1.57.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.005', '8315'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//input[@id='new_message']").send_keys('automated test') self.admin.find(By.XPATH, "//input[@class='btn btn-default']").click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() break deleted = True notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for n in notif: if n.text.find('automated test') >= 0: deleted = False break if deleted: self.ps.test_updates['passed'] = True # Case C112519 - 006 - Admin | Add an instructor-only system notification @pytest.mark.skipif(str(112519) not in TESTS, reason='Excluded') def test_admin_add_instructor_notification_112519(self): """Add an instructor-only system notification. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.006', '112519'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//div[3]//input[@id='message']").send_keys('automated test') self.admin.driver.find_elements_by_xpath( "//input[@class='btn btn-default']")[1].click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break self.admin.sleep(5) self.ps.test_updates['passed'] = True # Case C112520 - 007 - Admin | Delete a instructor-only system notification @pytest.mark.skipif(str(112520) not in TESTS, reason='Excluded') def test_admin_delete_instructor_notification_112520(self): """Delete an instructor-only system notification. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.007', '112520'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//div[3]//input[@id='message']").send_keys('automated test') self.admin.driver.find_elements_by_xpath( "//input[@class='btn btn-default']")[1].click() self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break self.admin.sleep(5) deleted = True notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for n in notif: if n.text.find('automated test') >= 0: deleted = False break assert (deleted), 'notification not deleted' self.ps.test_updates['passed'] = True # Case C112521 - 008 - Student | View an active system notification @pytest.mark.skipif(str(112521) not in TESTS, reason='Excluded') def test_student_view_active_notification_112521(self): """View an active system notification. Steps: Expected Result: //div[@class='notification system']/span """ self.ps.test_updates['name'] = 't1.57.008' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.008', '112521'] self.ps.test_updates['passed'] = False # Test steps and verification assertions # Create notification self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find(By.XPATH, "//input[@id='message']").send_keys('automated test') self.admin.driver.find_elements_by_xpath( "//input[@class='btn btn-default']")[0].click() self.admin.sleep(5) # View notification as student student = Student(use_env_vars=True) student.login() student.select_course(appearance='physics') student.sleep(10) notifs = student.driver.find_elements_by_xpath( "//div[@class='notification system']/span") found = False for notif in notifs: if notif.text.find("automated test") >= 0: found = True student.delete() # Delete notification notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") assert (found), 'notification not seen' self.ps.test_updates['passed'] = True # Case C112522 - 009 - Teacher | View an active system notification @pytest.mark.skipif(str(112522) not in TESTS, reason='Excluded') def test_teacher_view_active_notification_112522(self): """View an active system notification. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.009' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.009', '112522'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find(By.XPATH, "//input[@id='message']").send_keys('automated test') self.admin.driver.find_elements_by_xpath( "//input[@class='btn btn-default']")[0].click() self.admin.sleep(5) # View notification as student teacher = Teacher(use_env_vars=True) teacher.login() teacher.select_course(appearance='physics') teacher.sleep(10) notifs = teacher.driver.find_elements_by_xpath( "//div[@class='notification system']/span") found = False for notif in notifs: if notif.text.find("automated test") >= 0: found = True teacher.delete() # Delete notification notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") assert (found), 'notification not seen' self.ps.test_updates['passed'] = True # Case C112523 - 010 - Teacher | View an active instructor-only # system notification @pytest.mark.skipif(str(112523) not in TESTS, reason='Excluded') def test_teacher_view_instructor_notification_112523(self): """View an active instructor-only system notification. Steps: Expected Result: """ self.ps.test_updates['name'] = 't1.57.010' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.57', 't1.57.010', '112523'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'System Setting'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.PARTIAL_LINK_TEXT, 'Notifications'))).click() self.admin.sleep(5) self.admin.find( By.XPATH, "//div[3]//input[@id='message']").send_keys('automated test') self.admin.driver.find_elements_by_xpath( "//input[@class='btn btn-default']")[1].click() self.admin.sleep(5) # View notification as student teacher = Teacher(use_env_vars=True) teacher.login() teacher.select_course(appearance='physics') teacher.sleep(10) notifs = teacher.driver.find_elements_by_xpath( "//div[@class='notification system']/span") found = False for notif in notifs: if notif.text.find("automated test") >= 0: found = True teacher.delete() # Delete notification notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") for index, n in enumerate(notif): if n.text.find('automated test') >= 0: self.admin.driver.find_elements_by_xpath( "//a[@class='btn btn-warning']")[index].click() self.admin.driver.switch_to_alert().accept() self.ps.test_updates['passed'] = True break self.admin.sleep(5) notif = self.admin.driver.find_elements_by_xpath( "//div[@class='col-xs-12']") assert (found), 'notification not seen' self.ps.test_updates['passed'] = True
class TestContractControls(unittest.TestCase): """T1.35 - Contract Controls.""" def setUp(self): """Pretest settings.""" self.ps = PastaSauce() self.desired_capabilities['name'] = self.id() if not LOCAL_RUN: self.admin = Admin(use_env_vars=True, pasta_user=self.ps, capabilities=self.desired_capabilities) else: self.admin = Admin(use_env_vars=True, ) self.admin.login() # make sure there are no new terms to accept try: self.admin.driver.find_element(By.ID, 'i_agree').click() except NoSuchElementException: pass try: self.admin.driver.find_element(By.ID, 'agreement_submit').click() except NoSuchElementException: pass # go to admin console self.wait = WebDriverWait(self.admin.driver, 15) self.admin.open_user_menu() self.admin.wait.until( expect.element_to_be_clickable((By.LINK_TEXT, 'Admin'))).click() self.admin.page.wait_for_page_load() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Legal")]').click() def tearDown(self): """Test destructor.""" if not LOCAL_RUN: self.ps.update_job(job_id=str(self.admin.driver.session_id), **self.ps.test_updates) try: self.admin.delete() except: pass # Case C8228 - 001 - Admin | Add a new contract @pytest.mark.skipif(str(8228) not in TESTS, reason='Excluded') def test_admin_add_a_new_contract_8228(self): """Add a new contract. Steps: Click on the 'Terms' option Click on the "New Contract" Link Enter information into the Name, Title, and Content text boxes Click on the 'Create contract' button Expected Result: Contract is created as a draft. User is shown the contract they just made, and has options on what to do with it next """ self.ps.test_updates['name'] = 't1.35.001' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.001', '8228'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click( ) self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]'))).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_001') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_001') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_001') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.driver.find_element( By.XPATH, '//h1[contains(text(),"Details")]').click() self.ps.test_updates['passed'] = True ''' # Case C8229 - 002 - Admin | Cancel adding a new contract @pytest.mark.skipif(str(8229) not in TESTS, reason='Excluded') def test_admin_cancel_adding_a_new_contract_8229(self): """Cancel adding a new contract. Steps: Click on the 'Terms' option Click on the "New Contract" Link Enter information into the Name, Title, and Content text boxes Click on the 'Create contract' button Click on the Delete link Expected Result: Contract is deleted. User is taken back to the Contracts page. """ self.ps.test_updates['name'] = 't1.35.002' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.002', '8229'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]') ) ).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_002') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_002') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_002') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="Delete"]') ) ).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"alert-info")]') contracts = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"test_contract_title_002")]') assert(len(contracts) == 0), 'contract not cancled' self.ps.test_updates['passed'] = True ''' # Case C8230 - 003 - Admin | Publish a draft contract @pytest.mark.skipif(str(8230) not in TESTS, reason='Excluded') def test_admin_publish_a_draft_contract_8230(self): """Publish a draft contract. Steps: Click on the 'Terms' option Create a draft contract and return to contract list Click on the draft contract Click on the Publish link Click ok Expected Result: Draft contract is published """ self.ps.test_updates['name'] = 't1.35.003' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.003', '8230'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click( ) self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]'))).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_003') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_003') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_003') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]'))).click() self.admin.driver.find_element( By.XPATH, '//li//a[contains(text(),"test_contract_title_003")]').click() self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Publish")]').click() try: WebDriverWait(self.admin.driver, 3). \ until( expect.alert_is_present(), 'Timed out waiting for alert.' ) alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') self.ps.test_updates['passed'] = True # Case C8231 - 004 - Admin | Delete a draft contract @pytest.mark.skipif(str(8231) not in TESTS, reason='Excluded') def test_admin_delete_a_draft_contract_8231(self): """Delete a draft contract. Steps: Click on the 'Terms' option Create a draft contract and return to the contract list Click on the draft contract Click on Delete next to chosen draft contract Expected Result: Draft contract is deleted """ self.ps.test_updates['name'] = 't1.35.004' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.004', '8231'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() contracts_original = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"test_contract_title_004")]') self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click( ) self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]'))).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_004') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_004') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_004') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]'))).click() self.admin.driver.find_element( By.XPATH, '//li//a[contains(text(),"test_contract_title_004")]').click() self.admin.page.wait_for_page_load() self.admin.sleep(2) self.admin.driver.find_element( By.XPATH, '//a[contains(text(),"Delete")]').click() self.admin.sleep(2) try: WebDriverWait(self.admin.driver, 3). \ until( expect.alert_is_present(), 'Timed out waiting for alert.' ) alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') self.admin.page.wait_for_page_load() contracts = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"test_contract_title_004")]') self.admin.page.wait_for_page_load() assert(len(contracts) == len(contracts_original)), \ 'contract not deleted' self.ps.test_updates['passed'] = True # Case C8232 - 005 - Admin | View a current contract @pytest.mark.skipif(str(8232) not in TESTS, reason='Excluded') def test_admin_view_a_current_contract_8232(self): """View a current contract. Steps: Click on the 'Terms' option Create a contract and then return to contract list Click on chosen contract Expected Result: Displays the information of chosen contract. """ self.ps.test_updates['name'] = 't1.35.005' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.005', '8232'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() self.admin.driver.find_element( By.XPATH, '//div[contains(@class,"links")]/a[text()="New Contract"]').click( ) self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//h1[text()="New Contract"]'))).click() self.admin.driver.find_element( By.ID, 'contract_name').send_keys('test_contract_name_005') self.admin.driver.find_element( By.ID, 'contract_title').send_keys('test_contract_title_005') self.admin.driver.find_element( By.ID, 'contract_content').send_keys('test_contract_content_005') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="List"]'))).click() self.admin.driver.find_element( By.XPATH, '//li//a[contains(text(),"test_contract_title_005")]').click() self.admin.driver.find_element( By.XPATH, '//h2[contains(text(),"test_contract_title_005")]') self.ps.test_updates['passed'] = True # Case C8233 - 006 - Admin | Add a new version of a current contract @pytest.mark.skipif(str(8233) not in TESTS, reason='Excluded') def test_admin_add_a_new_version_of_a_current_contract_8233(self): """Add a new version of a current contract. Steps: Click on the 'Terms' option Click on New version next to chosen contract Update information in the Name, Title, and Content text boxes. Click on the 'Create Contract' button Expected Result: New version of contract is saved as a draft. """ self.ps.test_updates['name'] = 't1.35.006' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.006', '8233'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() self.admin.wait.until( expect.visibility_of_element_located( (By.XPATH, '//a[text()="New Version"]'))).click() self.admin.driver.find_element(By.ID, 'contract_name').send_keys('NEW_006') self.admin.driver.find_element(By.ID, 'contract_title').send_keys('NEW_006') self.admin.driver.find_element(By.ID, 'contract_content').send_keys('NEW_006') self.admin.driver.find_element( By.XPATH, '//input[@value="Create contract"]').click() self.admin.driver.find_element(By.XPATH, '//h2[contains(text(),"NEW_006")]') self.ps.test_updates['passed'] = True # Case C8234 - 007 - Admin | View a contract's signatories @pytest.mark.skipif(str(8234) not in TESTS, reason='Excluded') def test_admin_view_a_contracts_signatures_8234(self): """View a contract's signatories. Steps: Click on the 'Terms' option Click on Signatures next to chosen draft contract Expected Result: Displays list of signatures for the chosen contract. """ self.ps.test_updates['name'] = 't1.35.007' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.007', '8234'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() wait = WebDriverWait(self.admin.driver, 45) self.admin.driver.find_element(By.XPATH, '//a[text()="Signatures"]').click() wait.until( expect.element_to_be_clickable( (By.XPATH, '//div[contains(@class,"signature_index")]'))) self.ps.test_updates['passed'] = True # Case C8235 - 008 - Admin | Terminate a signatory's contract @pytest.mark.skipif(str(8235) not in TESTS, reason='Excluded') def test_admin_terminate_a_signnatorys_contract_8235(self): """Terminate a signatory's contract. Steps: Click on the 'Terms' option Click on Signatures next to chosen draft contract Click on Terminate next to chosen user Click on the 'ok' button Expected Result: Selected user's signing of contract is terminated. """ self.ps.test_updates['name'] = 't1.35.008' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.008', '8235'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Terms")]'))).click() self.admin.driver.find_element(By.XPATH, '//a[text()="Signatures"]').click() # is it okay to just terminate some random person's signature wait = WebDriverWait(self.admin.driver, 45) wait.until( expect.element_to_be_clickable( (By.XPATH, '//td//a[contains(text(),"Terminate")]'))).click() try: WebDriverWait(self.admin.driver, 3). \ until(expect.alert_is_present(), 'Timed out waiting for PA creation ' + 'confirmation popup to appear.') alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') self.ps.test_updates['passed'] = True # Case C8236 - 009 - Admin | Add a targeted contract @pytest.mark.skipif(str(8236) not in TESTS, reason='Excluded') def test_admin_add_a_targeted_contract_8236(self): """Add a targeted contract. Steps: Click on the 'Targeted Contracts' option Click on the 'Add Target Contract' button Click the 'Submit' button Expected Result: User taken back to Targeted contracts page. New Targeted Contract is added """ self.ps.test_updates['name'] = 't1.35.009' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.009', '8236'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Targeted Contracts")]'))).click() orig_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') self.admin.driver.find_element( By.XPATH, '//a[text()="Add Targeted Contract"]').click() self.admin.driver.find_element(By.XPATH, '//input[@value="Submit"]').click() end_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') assert(len(orig_contracts) == len(end_contracts)-1), \ 'targeted contract not added' self.ps.test_updates['passed'] = True # Case C8237 - 010 - Admin | Delete a targeted contract @pytest.mark.skipif(str(8237) not in TESTS, reason='Excluded') def test_admin_delete_a_targeted_contract_8237(self): """Delete a targeted contract. Steps: Click on the user's name in the top right corner to open drop down menu Click on the 'Admin' option of the drop down menu Click on 'Legal' on the bar across the top to open drop down menu Click on the 'Targeted Contracts' option Create a targeted contract and return to the list of targed contracts Click on delete next to chosen contract Click on the 'ok' button Expected Result: Targeted contract is deleted """ self.ps.test_updates['name'] = 't1.35.010' \ + inspect.currentframe().f_code.co_name[4:] self.ps.test_updates['tags'] = ['t1', 't1.35', 't1.35.010', '8237'] self.ps.test_updates['passed'] = False # Test steps and verification assertions self.admin.wait.until( expect.element_to_be_clickable( (By.XPATH, '//a[contains(text(),"Targeted Contracts")]'))).click() orig_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') # create contract self.admin.driver.find_element( By.XPATH, '//a[text()="Add Targeted Contract"]').click() self.admin.driver.find_element(By.XPATH, '//input[@value="Submit"]').click() # delete contract deletes = self.admin.driver.find_elements( By.XPATH, '//a[contains(text(),"delete")]') deletes[-1].click() try: WebDriverWait(self.admin.driver, 3).until(expect.alert_is_present(), 'Timed out waiting for alert.') alert = self.admin.driver.switch_to_alert() alert.accept() print('alert accepted') except TimeoutException: print('no alert') end_contracts = self.admin.driver.find_elements(By.XPATH, '//tr') assert(len(orig_contracts) == len(end_contracts)), \ 'targeted contract not added' self.ps.test_updates['passed'] = True '''