from time import sleep from hytest import * # 获取当前脚本的绝对路径 current_dir = os.path.dirname(os.path.abspath(__file__)) # 构建预定系统的绝对路径 预定系统_path = os.path.abspath(os.path.join(current_dir, '..','..','..','..')) # 添加路径 sys.path.append(预定系统_path) # 导入模块 try: from 预定系统.Base.base import * except ModuleNotFoundError as e: print(f"ModuleNotFoundError: {e}") print("尝试使用绝对路径导入") from 预定系统.Base.base import * # 获取当前脚本所在的目录 current_dir = os.path.dirname(os.path.abspath(__file__)) # 构建CSV文件的绝对路径 csv_file_path = os.path.join(current_dir, '../../../测试数据/会议室管理/会议室管理模块/会议室查询.csv') def text_query(wd,element_locator,query_text): """ 执行测试步骤以查询功能。 本函数根据参数输入定位元素,查询文本,并检查查询后的数据是否与预期相符。 """ STEP(1, f"输入查询文本:{query_text}") INFO(f"输入查询文本:{query_text}") safe_send_keys((By.XPATH, "//input[@placeholder='输入关键字']"), query_text, wd) sleep(2) send_keyboard((By.XPATH, "//input[@placeholder='输入关键字']"), wd) send_keyboard((By.XPATH, "//input[@placeholder='输入关键字']"), wd) sleep(2) STEP(2, "查看搜索结果") notify_text = elment_get_text(element_locator, wd) return notify_text class Conference_Query_000x: tags = ['会议室管理功能' , '后台管理功能','预定系统功能'] """ 执行指令: 1.cd 预定系统 2.hytest --report_title 会议室查询测试报告 --report_url_prefix http://nat.ubainsyun.com:13233 --test 会议室查询_0** """ ddt_cases = read_csv_data(csv_file_path) def teststeps(self): """ 执行测试步骤以会议室新增功能。 本函数根据参数输入会议室名称、,并检查新增后的提示信息是否与预期相符。 """ # 初始化通知文本为空字符串 notify_text = "" # 从全局存储中获取webdriver实例 wd = GSTORE['wd'] # 从self.para中解构出用户名、密码、验证码和检查文本 name = self.name conference_name, query_type, query_text = self.para if query_type == "模糊查询": notify_text = text_query(wd,(By.XPATH, "//tbody/tr[contains(@class,'el-table__row')]/td[2]/div[1]"),query_text) INFO(f"搜索结果为:{notify_text}") CHECK_POINT("搜索结果是否正确", query_text in notify_text) elif query_type == "精确查询": notify_text = text_query(wd, (By.XPATH, "//tbody/tr[contains(@class,'el-table__row')]/td[2]/div[1]"), query_text) INFO(f"搜索结果为:{notify_text}") CHECK_POINT("搜索结果是否正确", query_text in notify_text) elif query_type == "错误查询": notify_text = text_query(wd, (By.XPATH, "//span[@class='el-table__empty-text']"), query_text) INFO(f"搜索结果为:{notify_text}") CHECK_POINT("搜索结果是否正确", "暂无数据" in notify_text) elif query_type == "分页查询": # 切换分页 safe_click((By.XPATH,"//li[normalize-space()='4']"),wd) notify_text = text_query(wd, (By.XPATH, "//tbody/tr[contains(@class,'el-table__row')]/td[2]/div[1]"), query_text) INFO(f"搜索结果为:{notify_text}") CHECK_POINT("搜索结果是否正确", query_text in notify_text) if name == '会议室查询_005': wd.refresh()