zoukankan      html  css  js  c++  java
  • PO模式你会吗?自动化测试PO模式分层如何实现?

    一、什么是PO模式

    全称:page object model  简称:POM/PO

    PO模式最核心的思想是分层,实现松耦合!实现脚本重复使用,实现脚本易维护性!

    主要分三层:

    1.基础层BasePage:封装一些最基础的selenium的原生的api方法,元素定位,框架跳转等。

    2.PO层:元素定位、获得元素对象,页面动作

    3.测试用例层:业务逻辑,数据驱动!

    三者的关系:PO层继承继承层,测试用例层调用PO层!

    二、什么是自动化测试框架

    说到自动化框架,我相信很多人应该都听过这个词,但是不知其到底是个什么东西,为什么要用自动化框架。有很多人堆自动化框架都是懵懵懂懂,就跟谈恋爱一样,朦胧美!

    一个好的自动化测试框架是可以让不那么懂技术的人也可以写自动化测试脚本的,

    一个好的自动化测试框架可以减少自动化测试中脚本管理和维护当中的人力物力和财力。

    其实自动化框架的一个最大的意义在于可重用性。因为在框架里,你可以实现很多的通用功能来简化整个脚本的开发过程。并且生成美观的测试报告。

    三、非PO模式和PO模式优缺点对比

    自动化软件测试交流!!!群:642830685,领取最新软件测试资料大厂面试和Python自动化学习资料!一起学习交流

     非PO模式面向过程的线性脚本POM把页面元素定位和业务操作流程分开。实现松耦合。复用性差UI元素的改变不需要修改业务逻辑代码。只需要找到对应的PO页修改定位即可,数据代码分离

    维护性差PO能使我们的测试代码提高代码的可读性,高复用性,可维护性。

    四、如何从0到1搭建PO模型

     非PO模式举个栗子:有如下百度搜索脚本:

     

    如何把上述栗子改成PO模式呢?

    1、基础层BasePage

     2、PO层:封装百度页面元素定位,元素对象以及页面操作

    3、测试用例层:业务逻辑和数据驱动

    从上面的PO案例:让我们更加了解清晰PO的优点在于:

    1.POM把页面元素定位和业务操作流程分开。实现松耦合。

    2.UI元素的改变不需要修改业务逻辑代码。只需要找到对应的PO页修改定位即可,数据代码分离

    3.PO能使我们的测试代码提高代码的可读性,高复用性,可维护性。


    五、自动化测试框架和PO的关系

    自动化框架=po+各种封装(日志处理封装,全局配置文件的封装,数据库连接的封装,excel操作封装,数据驱动封装等)

    其实想要胜任UI自动化测试岗位还需要掌握以下内容:

    1.python或java

    2.selenium的API

    3.unittest/pytest单元测试框架

    4.htmltestrunner/allure测试报告

    5.数据驱动dtt(excel,yaml,mysql)或pytest中的fixtrue

    6.关键字驱动:公共类,方法封装,随机数,数据库连接,全局登录

    7.全局配置文件处理

    8.日志处理

    9.断言

    10.第三方库

    11.git和github或码云集成开发!

    12.jenkins持续集成

    六、总结

    如果您觉得对您有帮助,请点赞,收藏,分享三连!您的支持是笔者最大的动力!



  • 相关阅读:
    codeforces#1310B. Double Elimination(动态规划)
    codeforces#1300E. Water Balance(贪心)
    带权并查集
    codeforces#1295D. Same GCDs(数论/莫比乌斯)
    jsp实现图片换行显示
    codeforces#1257 F. Make Them Similar ( 经典中间相遇问题 )
    codeforces#1248D2. The World Is Just a Programming Task(括号匹配转化为折线处理)
    codeforces#1251E2. Voting (Hard Version)(贪心)
    codeforces#1249F. Maximum Weight Subset(树上dp)
    hdu6731 Angle Beats(ccpc秦皇岛A,计算几何)
  • 原文地址:https://www.cnblogs.com/www642830685/p/13236379.html
Copyright © 2011-2022 走看看