门户网站模板下载wordpress网页提速

张小明 2026/1/2 9:39:46
门户网站模板下载,wordpress网页提速,社交网站备案,做网站建设一条龙全包概念 什么是POM#xff1f; POM是PageObjectModule#xff08;页面对象模式#xff09;的缩写#xff0c;其目的是为了Web UI测试创建对象库。 在这种模式下#xff0c;应用涉及的每一个页面应该定义为一个单独的类#xff0c;类中应该包含此页面上的页面元素对象和处…概念什么是POMPOM是PageObjectModule页面对象模式的缩写其目的是为了WebUI测试创建对象库。在这种模式下应用涉及的每一个页面应该定义为一个单独的类类中应该包含此页面上的页面元素对象和处理这些元素对象所需要的方法等。将流程所关联的页面作为对象将对象串联起来形成一个个不同的流程POM是业内公认最佳的设计模式。POM的优点1PO提供了页面元素操作和业务流程相分离的模式可以使测试的代码结构比之前清晰可读性强。2更方便地复用对象和方法。3对象库是独立于测试用例的、统一的对象库可以通过集成不同的工具类来达到不同的测试目的。比如集成UnitTest可以用来做单元测试、自动化/功能测试同时也可以集成JBehave/Cucumber等来做验收测试。4使得整体自动化测试的优点变得更容易一些如果有某个页面的元素需要变更那么就可以直接更改封装好的页面元素类即可而不用更改调用它的其他测试类/代码。这样整个的代码维护成本也会缩减。PO的核心就是分层思想把同属于一个页面的元素都放在一个页面类中。简要结构设计逻辑代码基类实现所有工具函数封装类似于关键字驱动设计模式。页面对象代码基于系统页面通过调用工具函数来实现业务的操作生成对应的页面对象。测试代码基于测试需要组件页面对象实现核心流程的自动化执行测试用例。测试数据为测试用例的执行提供所需要的测试数据。POM完整框架Base层定义项目需要的基础方法特别是一些基础操作如元素click操作、sendkeys操作调用JavaScript脚本的方法和其他一些与基本浏览器相关的操作。Common层包含处理Excel文件的方法获取项目路径、测试系统URL的信息和框架执行相关日志功能的实现方法。Data层存放测试数据在这里可以维护测试数据这样存放是为了让项目的可维护性强、整体的条理性强。测试数据有时是自动化测试的驱动因素因此对Data的管理和维护就显的特别重要。Logs层存放项目在运行过程中产生的日志文件。PageObject层这里是PO的核心层该层不但涉及代码技术还涉及对项目业务的分析进而对项目的页面进行分析。Reports层存放项目执行过程中产生的测试报告文件测试报告是对测试结果的总结。TestCase层管理测试用例和执行测试相当于测试的总入口。config.ini整个项目需要用到的配置项。项目实战以百度搜索为例我们首先新建一个简单的项目结构base、data、page_object、cases如下图所示在base包下新建一个base_page.py文件在base_page.py文件下新建一个BasePage类作为基类提供各个常用的已封装好的函数便于后续的页面对象类进行调用。selenium中常用的函数元素定位、输入、点击、访问URL、等待、关闭等。代码如下 基类提供各个常用的已封装好的函数便于后续的页面对象类进行调用。 selenium中常用的函数:元素定位、输入、点击、访问URL、等待、关闭 from time import sleep from selenium import webdriver class BasePage: driver webdriver.Chrome() # 访问URL def visit(self, url): self.driver.get(url) # 元素定位 def locator(self, loc): return self.driver.find_element(*loc) # 输入 def input(self, loc, txt): self.locator(loc).send_keys(txt) # 点击 def click(self, loc): self.locator(loc).click() # 等待 def wait(self, time): sleep(time) # 关闭 def close(self): self.driver.quit()selenium中常用的函数:元素定位、输入、点击、访问URL、等待、关闭在page_object包下新建一个search_page.py文件在该文件下新建一个SearchPage类继承BasePage类调用基础类中的方法实现页面操作生成对应的页面对象。代码如下 百度查询页面搜索功能 from selenium.webdriver.common.by import By from base.base_page import BasePage from selenium import webdriver class SearchPage(BasePage): url http://www.baidu.com # 定位百度输入框 search_input (By.NAME, wd) # 定位百度一下按钮 search_button (By.ID, su) # 封装实现业务流程的函数 def search(self, txt): self.visit(self.url) self.wait(2) self.input(self.search_input, txt) self.wait(2) self.click(self.search_button)在cases包下新建一个testcase.py文件作为测试类实现在百度中分别搜索selenium、python代码如下 测试类 import unittest from page_object.search_page import SearchPage from selenium import webdriver class Case(unittest.TestCase): def test_search1(self): driver webdriver.Chrome() txt selenium SearchPage(driver).search(txt) def test_search2(self): driver webdriver.Chrome() txt python SearchPage(driver).search(txt) if __name__ __main__: unittest.main()运行以上代码发现因为创建了两次webdriver所以每运行一次代码都会打开一个Chrome浏览器同时代码中也存在冗余。优化方案可以增加classmethod作为前置条件和后置条件搜索的条件也可以采用数据驱动的方式完成提高代码的可读性与维护性。在data包下新建一个searchTXT.yaml文件存放搜索的内容如下优化之后代码如下 测试类 import unittest from page_object.search_page import SearchPage from selenium import webdriver import ddt ddt.ddt() class Case(unittest.TestCase): classmethod def setUpClass(cls) - None: cls.driver webdriver.Chrome() cls.se SearchPage(cls.driver) classmethod def tearDownClass(cls) - None: cls.driver.quit() ddt.file_data(../data/searchTXT.yaml) def test_search(self, txt): self.se.search(txt) if __name__ __main__: unittest.main()运行以上代码发现测试用例执行了四次分别搜索了selenium、python、java、php如此实现了数据驱动同时也在一个浏览器中完成了操作。后记以上简单的实现了POM的设计模式完成了基类、页面对象层、数据层、测试层的代码编写若读者有兴趣可以完成报告层、日志层等内容的编写最终实现完整的框架。最后作为一位过来人也是希望大家少走一些弯路在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈这些资料希望能给你前进的路上带来帮助。​视频文档获取方式这份文档和视频资料对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴我走过了最艰难的路程希望也能帮助到你以上均可以分享点下方小卡片即可自行领取。
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

开发深圳网站建设开发板原理图

PKHeX自动化工具终极指南:如何快速实现宝可梦数据管理革命 【免费下载链接】PKHeX-Plugins Plugins for PKHeX 项目地址: https://gitcode.com/gh_mirrors/pk/PKHeX-Plugins 你是否曾经在深夜对着电脑屏幕,一遍遍地修改宝可梦的个体值&#xff0c…

张小明 2025/12/31 17:03:21 网站建设

常见的电子商务网站有我要推广

YOLO模型集成Fluentd实现日志统一收集 在智能制造工厂的质检线上,数十台工业相机正以每秒30帧的速度持续拍摄零部件图像。YOLO模型在边缘设备上实时运行,快速识别出划痕、气泡等缺陷。然而,当某条产线突然出现误检率飙升时,运维人…

张小明 2025/12/31 2:25:22 网站建设

深圳布吉做网站app平台开发

在数字化浪潮席卷全球的今天,高效准确的翻译服务已成为开发者和企业的刚需。然而,DeepL官方API的高昂费用让许多预算有限的用户望而却步。正是在这样的背景下,DeepLX应运而生,这个开源项目通过巧妙的技术实现,为用户提…

张小明 2025/12/31 17:03:22 网站建设

做购物网站需不需要交税费亚马逊海外购官方网

NVIDIA TensorRT镜像实测:ResNet、BERT推理提速对比 在现代AI系统中,模型训练完成只是第一步,真正决定用户体验的是推理性能——响应是否够快?吞吐能不能扛住高并发?服务器成本是否可控?尤其是在自动驾驶、…

张小明 2025/12/31 17:03:23 网站建设

如何使用框架来建设网站广告设计公司名称

第一章:Open-AutoGLM多任务并行冲突全解析 在大规模语言模型训练中,Open-AutoGLM架构因其支持多任务并行处理而备受关注。然而,当多个任务共享底层参数与计算资源时,任务间容易出现梯度冲突、资源争抢和调度延迟等问题&#xff0c…

张小明 2025/12/31 14:50:30 网站建设

最好的网站模板网站邯郸做网站哪里好

Akagi雀魂助手深度解析:从技术原理到实战应用 【免费下载链接】Akagi A helper client for Majsoul 项目地址: https://gitcode.com/gh_mirrors/ak/Akagi 想要在雀魂游戏中获得专业级的智能分析能力吗?Akagi雀魂助手通过先进的协议解析和AI算法&a…

张小明 2025/12/31 17:03:23 网站建设