From 3b84cce1ee43215b9f398148fda19f4b1025856b Mon Sep 17 00:00:00 2001 From: yj <2077506045@qq.com> Date: 星期三, 24 七月 2024 17:46:00 +0800 Subject: [PATCH] 测评系统自动测试 --- po/ciaq_answer_page.py | 65 +++++++++++++++----------------- 1 files changed, 31 insertions(+), 34 deletions(-) diff --git a/po/ciaq_answer_page.py b/po/ciaq_answer_page.py index 6a55341..4412727 100644 --- a/po/ciaq_answer_page.py +++ b/po/ciaq_answer_page.py @@ -1,10 +1,11 @@ import random from base.base_page import BasePage -from elements.ciaq_answer_elements import CIAQAnswerElements as Answer +from elements.ciaq_answer_elements import CIAQAnswerElements from selenium.common.exceptions import * import time +import re class CIAQAnswerPage(BasePage): @@ -13,38 +14,34 @@ """ loading_count = 0 + elements = CIAQAnswerElements + + slice_count = 3 + def answer(self): - # 鏆傚仠3绉� - time.sleep(3) - while True: - # 缁х画娴嬭瘯鎸夐挳鍑虹幇鍒欑偣鍑� - if self.continue_btn_is_display(): - self.click(Answer.continue_testing_btn) + for i in range(self.slice_count): + # 鑾峰彇鍒伴鐩� + time.sleep(3) + title = self.get_ele(self.elements.q_title, 5) + # 鎴彇宸茬瓟鏁伴噺涓庢�绘暟閲� + match = re.search(r"(\d+)/(\d+)", title.text) + current = int(match.group(1)) + total = int(match.group(2)) - # 鏍囬涓嶅瓨鍦ㄧ洿鎺ヨ繑鍥濬alse - if not self.title_is_display(): - if self.continue_btn_is_display(): - self.click(Answer.continue_testing_btn) - continue - return False - - try: + while current <= total: + print(f"\n鐜板湪鏄疌IAQ鍒嗙墖{i+1}绗瑊current}棰�") # 鑾峰彇鍒版墍鏈夐�夐」 - options = self.get_elements(Answer.options) - number = random.randint(0, len(options)-1) + options = self.get_eles(self.elements.options, 5) + number = random.randint(0, len(options) - 1) if options[number].is_enabled(): options[number].click() - except: - pass - - # 鎻愪氦鎸夐挳瀛樺湪鍒欑偣鍑� - if self.submit_btn_is_display(): - self.click(Answer.submit_btn) - # 鏁版嵁鏄惁涓婁紶瀹屾垚 - time.sleep(15) - if self.upload_is_success(): - return True - return False + current += 1 + if (i + 1) != self.slice_count: + time.sleep(2) + # 鐐瑰嚮缁х画娴嬭瘯 + self.click(self.elements.continue_testing_btn, 10) + time.sleep(2) + self.click(self.elements.submit_btn, 10) def upload_is_success(self): """ @@ -54,7 +51,7 @@ i = 0 while i < 60: try: - self.get_element_wait(Answer.upload_success_title) + self.get_ele(self.es.upload_success_title, timeout=10) return True except TimeoutException: i += 1 @@ -67,7 +64,7 @@ :return: """ try: - button = self.get_element(Answer.submit_btn) + button = self.get_ele(self.es.submit_btn) if button.is_enabled(): return True else: @@ -82,7 +79,7 @@ """ try: # 鐐瑰嚮缁х画娴嬭瘯鎸夐挳 - button = self.get_element(Answer.continue_testing_btn) + button = self.get_ele(self.es.continue_testing_btn) if button.is_enabled(): return True else: @@ -97,7 +94,7 @@ """ try: # 鑾峰彇鏍囬 - self.get_element_wait(Answer.title) + self.get_element_wait(self.es.title) return True except TimeoutException: return False @@ -110,7 +107,7 @@ i = 0 while i < 10: try: - self.get_element(Answer.loading_text) + self.get_ele(self.es.loading_text) i += 1 time.sleep(1) except: @@ -123,4 +120,4 @@ 寮�濮嬫祴璇曟寜閽� :return: """ - self.click_wait(Answer.start_btn) + self.click_wait(self.es.start_btn) -- Gitblit v1.9.1