web UI自动化之PO模式

web UI自动化之PO模式PO是什么:PO模式,PageObject的缩写,页面对象,设计框架的思想,分层思想在PO下,应用程序的每一个页面都有一个对应的pageclass每一个pageclass维护着该web页的元素集和操作这些元素的方法pageclass中的方法命名最好根据对应的业务场景进行,例如通常登录后我们需要等待几秒钟PO的优势:PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰页面对象与用例分离,使得我们更好的复用对象可复用的页面方法代码会变得更加优化更加有效的命名

大家好,又见面了,我是你们的朋友全栈君。

PO是什么:

  1. PO模式,Page Object的缩写,页面对象,设计框架的思想,分层思想
  2. 在PO下,应用程序的每一个页面都有一个对应的page class
  3. 每一个page class维护着该web页的元素集和操作这些元素的方法
  4. page class中的方法命名最好根据对应的业务场景进行,例如通常登录后我们需要等待几秒钟

PO的优势:

  1. PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰
  2. 页面对象与用例分离,使得我们更好的复用对象
  3. 可复用的页面方法代码会变得更加优化
  4. 更加有效的命名方式使得我们更加清晰的知道方法所操作的UI元素

主要的分层方式:

  • 两层:对象逻辑层+业务数据层
  • 三层:对象库层+逻辑层+业务数据层
  • 四层:对象库层+逻辑层+业务层+数据层

一般分为三层:

  1. 按照页面划分,把每个页面可能涉及到的步骤写下来 pageObject包,页面的配置信息写在这个包的__init__里面
  2. 把页面的步骤组合在一起形成一个业务 pageAction包
  3. 测试用例的书写,case层,跟单元测试框架结合使用,断言,参数化,报告 case包
    在这里插入图片描述
    普通模式:
import time
import page
from base.baseApi import Base
from base.driver import Driver


class Login(Base):
    def __init__(self):
        # 定义实例属性driver
        self.driver = webdriver.Chrome('E:\\chromedriver.exe')
        # 窗口最大化
        self.driver.maximize_window()

    # 打开首页
    def open_index(self):
        self.driver.get('链接地址')
        time.sleep(1)

    # 在首页点击登录链接
    def click_login_link(self):
        self.base_click(page.loc_login_link)   # 相同名字,只能找到第一个

    # 页面动作划分
    # 输入用户名
    def input_username(self):
        self.base_input(page.loc_username, 'xueqing')

    # 输入密码
    def input_password(self):
        self.base_input(page.loc_password, '123456')

    # 点击登录
    def click_login(self):
        self.base_click(page.loc_login)

    def login_business(self):
        # 点击登录链接
        self.click_login_link()
        # 输入用户名
        self.input_username()
        # 输入密码
        self.input_password()
        # 点击登录按钮
        self.click_login()

    # 断言
    def assert_business(self):
        # 页面加载速度比较快,代码运行速度比较快,所以有时候需要让代码等等页面
        time.sleep(5)
        assert 'xueqing' in self.driver.page_source

    # 退出浏览器
    def close_driver(self):
        self.driver.close()

PO模式:

页面操作page_login.py

import pageObject
import allure
from base.baseApi import Base

class PageLogin(Base):

    # 页面动作划分
    # 输入用户名
    @allure.step('输入用户名')
    def input_username(self, username):
        self.base_input(pageObject.login_username, username)

    # 输入密码
    @allure.step('输入密码')
    def input_password(self, password):
        self.base_input(pageObject.login_password, password)

    # 点击登录
    @allure.step('点击登录')
    def click_login_button(self):
        self.base_click(pageObject.login_button)

组合业务login_action.py

import time
from pageAction.action_manager import ActionManager

# 继承ActionsManager,做到了页面对象类实例化的最大复用性
class Login(ActionManager):
    ''' 组合业务 1. 登录业务需要哪几个页面的哪几个步骤 2. 登录页面 3个步骤 3. index页面 1个步骤 '''

    def login_success(self):
        # 点击登录链接
        self.pageindex.click_login_link()
        # 输入用户名
        self.pagelogin.input_username('xueqing')
        # 输入密码
        self.pagelogin.input_password('123456')
        # 点击登录按钮
        self.pagelogin.click_login_button()
        time.sleep(1)

    def login_business(self, username, password):
        # 点击登录链接
        self.pageindex.click_login_link()
        # 输入用户名
        self.pagelogin.input_username(username)
        # 输入密码
        self.pagelogin.input_password(password)
        # 点击登录按钮
        self.pagelogin.click_login_button()

测试用例test_login.py

import pytest
import allure
import time
from base.driver import Driver
from pageAction.login_action import Login
from tool.readData import ReadData
from base.baseApi import Base

data = ReadData().get_yaml('test_login', 'login_data.yml')

@allure.feature('登录功能的测试用例')
class TestLogin():

    def setup_class(self):
        ''' 初始化chrome对象 :return: '''
        # 创建driver对象
        self.driver = Driver().get_dirver()
        # 创建login的业务对象
        self.login = Login(self.driver)
        # 创建base对象,调用page_source方法
        self.base = Base(self.driver)

    @pytest.mark.parametrize('args', data)
    @allure.title('登录功能的正向与逆向用例')
    def test_login(self, args):
        self.login.login_business(args['accounts'], args['pwd'])
        time.sleep(2)
        assert args['assert'] in self.base.base_page_source

    def teardown_class(self):
        ''' 所有测试用例执行完毕,关闭浏览器 :return: '''
        Driver().close_driver()
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136431.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 杭电子科技大学_god ls a girl神翻译

    杭电子科技大学_god ls a girl神翻译godisagirlTimeLimit:2000/1000MS(Java/Others)    MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):1337    AcceptedSubmission(s):618ProblemDescriptionOneday,whenIwa

    2022年10月8日
    0
  • aop实现原理面试_aop ioc 面试怎么回答

    aop实现原理面试_aop ioc 面试怎么回答作用——用于处理系统中分布的各个模块的横切关注点(如:事务管理、日志、缓存等),是使用动态代理实现,在内存中临时为增强某个方法生成一个AOP对象,该对象含有目标对象的所有方法,在特定的切入点做了增强处理,并回调原来的方法。P:咋眼一看,不能直接理解很正常。动态代理的实现——主要分两种方式实现1、JDK动态代理原理说明——JDK动态管理通过反射接收被代理的类,该代理的类必须实现接口,核心是InvocationHandler和Proxy类。2、Cglib动态代理原理说明——Cglib通过.

    2022年9月2日
    2
  • 第一范式、第二范式和第三范式「建议收藏」

    第一范式、第二范式和第三范式「建议收藏」数据库的范式概念:设计数据库是,需要遵循的一些规范,要遵循后边的范式要求,必须遵循前边的所有范式要求设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈梯次规范,越高的范式数据库冗余越小目前关系型数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、BC范式、第四范式(4NF)、第五范式(5NF)。…

    2022年5月23日
    40
  • R语言与统计分析[通俗易懂]

    R语言与统计分析[通俗易懂]R语言与统计分析汤银才主编高等教育出版社二○○八年五月内容介绍本书以数据的常用统计分析方法为基础,在简明扼要地阐述统计学基本概念、基本思想与基本方法的基础上,讲述与之相对应的R函数的实现,并通过具体的例子说明统计问题求解的过程.本书注重思想性、实用性和可操作性.在内容的安排上不仅包含了基础统计分析中的探索性数据分析、参数的估计与假设检验,还包括的非参数统计分

    2022年5月12日
    122
  • 使用()命令来启用FTP服务_windows播放ftp

    使用()命令来启用FTP服务_windows播放ftp首先是win10控制面板–》程序–》启用或关闭windows功能找到Internetinformationservice(信息服务),并选中“FTP服务”、“FTP扩展性”和“IIS管理控制台”前的复选框,点击“确定”在C盘创建一个FTP共享文件夹,名字自定义接下来是控制面板–》系统和安全–》管理工具–》InternetInformationServices(IIS)管理器如下图所示,鼠标右键红框地方添加FTP站点站点名称自定义,路径选择先前创建的文件夹,

    2022年9月15日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号