WEB自动化-10-Page Object 模型

10 Page Object 模型

10.1 概述

在针对一个WEB页面编写自动化测试用例时,需要引用页面中的元素( 数据)才能进行操作( 动作)并显示出页面内容。如果编写的测试用例是直接针对WEB页面元素进行操作,则无法应对经常发生变化的WEB页面,增加日后自动化代码的维护成本。而Page Object模型就是针对WEB页面和元素细节的封装,并对外提供应用级别的API,从而摆脱对WEB页面的高耦合情况。示意图如下所示:

WEB自动化-10-Page Object 模型

针对以上示例,可以大概总结出大概做法,如下所示:

  • 以页面为单位,独立建立模型
  • 隐藏实现细节
  • 本质是面向接口编程

以上示例图片位置:https://martinfowler.com/bliki/PageObject.html

10.2 定义

Page Object模型(简称为PO模式)是一种设计模式,其核心是 分层,实现 松耦合,从而实现 代码复用和其 易维护性。利用PO模型,为每个网页建立两个类:

  • *Page类

将每个页面封装为Page类, 页面元素为Page类 成员变量页面功能为Page类 方法里面

  • *Test类

针对Page类定义的测试类,在测试类中调用Page类中方法完成测试。其使用Page类中的方法与页面UI元素进行交互操作。若UI发生变化,仅需要更新Page类,测试类无需要更改。

10.3 为什么使用Page Object模式

WEB由各种WEB元素(文本框、复选框、多选/单选按钮等)组成。测试代码与这些元素进行交互,如果不能正确管理定位器,则代码的复杂性将成倍增加。当测试代码和定位器的重复使用,将降低代码的可读性,从而进一步加大测试代码的维护成本。 随着项目和需求的不断变化,开发和测试代码的复杂性会不断增加,维护性也随之增加。因此,需要一种方法来解决这种问题,所以我们需要使用PO来尝试解决这一类问题。

10.4 Page Object模型优点

主要优点如下所示:

  • *提高代码可复用性

不同PO类中的Pabe Object方法可以在不同的测试用例中复用,极大提高代码的复用性。

  • *提高代码可维护性

因测试场景和定位器是代码分开,使代码更加清晰,极大提高代码的可维护性。

  • *减少UI对用例造成的影响

尽管UI经常发生变更,也仅需要修改少量代码来应对更改,从而减少其带来的影响。

10.5 Page Object示例

10.5.1 演示环境搭建

我们以官方提供的示例为演示,操作步骤如下所示:

npm install minimist morgan body-parser express-session express hbs --save-dev
npm start server.js
  • 4、在浏览器中访问

WEB自动化-10-Page Object 模型

默认正确的用户名和密码,在 server.js中,可以自行修改,如下所示:

WEB自动化-10-Page Object 模型

10.5.2 演示代码

本代码仅仅是演示在Cypress中的Page Object模式(注意与Selenium的区别),主要示例代码如下所示:

  • 1、 新建定位器文件loginPageLoctor.json,用于存储元素定位器
{
   "loginPage":{
       "username":"input[name=\"username\"]",
       "passwd":"input[name=\"password\"]",
       "submit":"button[type=\"submit\"]",
       "loginFailedPrompt":".error"
   }
}
  • 2、 新建Page类loginPage.js,用于封装对象和定位元素
///

import LoginPageLocator from "./loginPageLoctor.json"

export default class LoginPage{
    constructor(visitUrl){
       this.url=visitUrl;
    }

    get username(){
        return cy.get(LoginPageLocator.loginPage.username);
    }

    get passwd(){
        return cy.get(LoginPageLocator.loginPage.passwd);
    }

    get submit(){
        return cy.get(LoginPageLocator.loginPage.submit);
    }

    get errorPrompt(){
        return cy.get(LoginPageLocator.loginPage.loginFailedPrompt);
    }

    get successUrl(){
        return cy.url();
    }

    visit(){
       cy.visit(this.url);
    }

    login(name,pwd) {
        if ( name !="" && pwd !=""){
            this.username.type(name);
        }

        if(pwd!=""){
            this.passwd.type(pwd);
        }

        this.submit.click();
    }

}
  • 3、 新建数据文件loginData.json,用于存储登录的数据和数据驱动
{

    "success": [
        {
            "caseTitle": "正确的用户名和密码,登录成功",
            "user": "jane.lane",
            "pwd": "password123",
            "checkpoint": "/dashboard"
        }
    ],

    "failed": [
        {
            "caseTitle": "错误的用户名和正确的密码,登录失败",
            "user": "Surpass",
            "pwd": "password123",
            "checkpoint": "Username and/or password is incorrect"
        },
        {
            "caseTitle": "正确的用户名和错误的密码,登录失败",
            "user": "jane.lane",
            "pwd": "Surpass",
            "checkpoint": "Username and/or password is incorrect"
        },
        {
            "caseTitle": "错误的用户名和错误的密码,登录失败",
            "user": "Surpass",
            "pwd": "Surpass",
            "checkpoint": "Username and/or password is incorrect"
        }
    ]

}
  • 4、 新建测试类testLogin.spec.js,测试用例代码
///

import LoginPage from "./loginPage"
import UserData from "./loginData.json"

describe('登录测试', () => {
    let baseUrl = "http://localhost:7077/login";
    let login = new LoginPage(baseUrl);
    beforeEach(() => {
        login.visit(baseUrl);
    });

    UserData.success.forEach((item)=>{
       it(item.caseTitle, () => {
           login.login(item.user,item.pwd);
           login.successUrl.should("contain",item.checkpoint)
       });
    });

    UserData.failed.forEach((item)=>{
       it(item.caseTitle, () => {
        login.login(item.user,item.pwd);
        login.errorPrompt.should("contain",item.checkpoint)
       });
    });
});

最终的运行结果如下所示:

WEB自动化-10-Page Object 模型

原文地址:https://www.jianshu.com/p/f6749544d6f8

本文同步在微信订阅号上发布,如各位小伙伴们喜欢我的文章,也可以关注我的微信订阅号:woaitest,或扫描下面的二维码添加关注:

WEB自动化-10-Page Object 模型

Original: https://www.cnblogs.com/surpassme/p/16729294.html
Author: Surpassme
Title: WEB自动化-10-Page Object 模型

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/581621/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • NRF24L01双向无线通信

    最近闲来无事,利用手头资源研究了一下基于nrf24L01的双向通信实验,整个系统如下图所示。原理:nrf24L01本身是一种单向通信的无线模块,但是,当nrf24L01工作在增强型…

    Linux 2023年6月14日
    085
  • 视图层

    目录 虚拟环境 django路由层版本区别 视图函数返回值 JsonResponse对象 上传文件 request方法 FBV与CBV CBV源剖析 模板语法传值 内容 虚拟环境 …

    Linux 2023年6月7日
    068
  • IOC容器模拟实现

    运用反射机制和自定义注解模拟实现IOC容器,使其具有自动加载、自动装配和根据全限定类名获取Bean的功能。 1-1 IOC容器的本质 IOC容器可理解为是一个map,其中的一个en…

    Linux 2023年6月8日
    084
  • 小文件、nginx、Redis、Moosefs

    现在有3KW的数据,单条数据都很小的,如果按key-value来看的话,key就是32位的MD5字符串,value按平均算大概是100字节左右。 现在需要将这些数据做缓存以在高并非…

    Linux 2023年5月28日
    0108
  • 数据分析业务知识

    1.电商和消费模型 所谓的电商和消费模型是以商品的交易、零售、购买搭建而起。包括客单价、复购率、回购率、退货率、购物篮大小、进销存等商品概念。 2.市场营销模型 市场营销模型是以传…

    Linux 2023年6月6日
    0114
  • 小程序字节转GBK及UTF8

    前段时间在Android原生搞的BLE扫码枪又要移植到小程序上来。本以为小程序不支持BLE的,结果一搜,还真支持-_-|| 。 蓝牙部分问题不大,遇到的主要问题是, 小程序环境如何…

    Linux 2023年6月13日
    0176
  • shell生成指定长度的随机数

    生成指定长度是随机数 8位纯数字的随机数 tr -cd ‘0-9’ 使用/dev/urandom而不是/dev/random是因为后者比较慢。 Original: https://…

    Linux 2023年5月28日
    099
  • ETCD分布式存储部署

    一、ETCD 概述 ETCD 是一个分布式一致性k-v存储系统,可用于服务注册发现与共享配置。具有一下优点: 简单: 相比于晦涩难懂的paxos算法,etcd基于相对简单且易实现的…

    Linux 2023年6月14日
    089
  • 域控制器所需的DNS SRV记录没有在DNS中注册的解决方法

    搭建完AD和DNS之后,发现在DNS的正向查找区域没有SRV记录,并且客户端无法加入到AD中,如下 解决方法 删除正向查找区域下的目录 然后选择”正向查找区域&#822…

    Linux 2023年6月14日
    094
  • Spring事务(二)-事务传播行为

    在Spring里,一个事务方法被另外一个事务方法调用时,两个方法的事务应该如何进行,说白话一点,就是说当出现异常需要回滚时,各个方法的数据操作是否要全部回滚,事务传播行为就是决定了…

    Linux 2023年6月6日
    071
  • 对比nushell和powershell

    2021-07-17 第一版 有些对比领域缺失,这篇文章会持续更新。 这是一篇对比powershell和nushell的文章。我是powerhsell专家,又是nushell新手,…

    Linux 2023年6月14日
    096
  • Django_渲染详解

    Django_render 模板语法 模板引擎是一种可以让开发者把服务端数据填充到html网页中完成渲染效果的技术。它实现了把前端代码和服务端代码分离的作用,让项目中的业务逻辑代码…

    Linux 2023年6月7日
    0118
  • [LINUX] Arch Linux 硬盘拷贝式装系统+新增 home 分区

    前言 1. 实操 1.1 整个磁盘拷贝 1.2 创建 home 分区 1.3 修改 fstab 实现自动挂载 2. 涉及到的知识点 2.1 fstab 2.2 dd 命令 2.3 …

    Linux 2023年5月27日
    0173
  • SpringBoot-swagger

    SpringBoot整合swagger SpringBoot-swagger 13.1 导入相关依赖 io.springfox springfox-swagger-ui 2.9.2…

    Linux 2023年6月14日
    085
  • 在Windows下使用CodeBlock使用libiconv第三方库

    在 Windows 下使用 CodeBlock 使用 libiconv 第三方库 1、 选择在Project—>Build options下: 2、 如下图添加libicon…

    Linux 2023年6月6日
    079
  • Linux Centos7.5 vsftp 的安装与配置

    安装及配置 安装 sudo yum install vsftpd -y 服务管理 启动服务 service vsftpd start 关闭服务 service vsftpd sto…

    Linux 2023年6月14日
    072
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球