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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 菜鸟实战UML——活动图

    菜鸟实战UML——活动图活动图活动图(activitydiagram)是阐明了业务用例实现的工作流程。业务工作流程说明了业务为向所服务的业务主角提供其所需要的价值而必须完成的工作,业务用例由一系列活动组成,他们共同为业务主角生成某些工件。工作流程通常包括一个基本的工作流程和一个或多个备选工作流程。工作流程的结构使用活动图来进行说明。用途活动图是UML用于对系统的动态行为建模的另一种常用工具,它描述活动的顺序,展现…

    2022年6月7日
    30
  • Windows键失灵的三种处理方式「建议收藏」

    Windows键失灵的三种处理方式「建议收藏」对于经常使用电脑学习或者工作的我们来说,特别是搞编程的小伙伴们。Windows键的失灵将会导致我们的工作效率大大降低,比如:Win+E快速打开我的电脑;Win+R快速打开命令行等,许多组合键都不能使用,好烦躁。不要急,先看看这篇文章,可能有惊喜哦!

    2022年5月4日
    100
  • 哈佛结构与普林斯顿结构_普林斯顿大学和哈佛大学哪个更厉害

    哈佛结构与普林斯顿结构_普林斯顿大学和哈佛大学哪个更厉害1. 冯·诺依曼结构   冯·诺依曼结构,又称为普林斯顿体系结构,是一种将程序指令存储器和数据存储器合并在一起的存储器结构。取指令和取操作数都在同一总线上,通过分时复用的方式进行;缺点是在高速运行时,不能达到同时取指令和取操作数,从而形成了传输过程的瓶颈。由于程序指令存储地址和数据存储地址指向同一个存储器的不同物理位置,因此程序指令和数据的宽度相同,如英特尔公司的8086中央处理器的程序指

    2022年10月5日
    0
  • stringtokenizer类的hasmoretokens_java string equals

    stringtokenizer类的hasmoretokens_java string equalsStringTokenizer:字符串分隔解析类型属于:java.util包。1、构造函数。1.StringTokenizer(Stringstr):构造一个用来解析str的StringTokenizer对象。java默认的分隔符是“空格”、“制表符(‘\t’)”、“换行符(‘\n’)”、“回车符(‘\r’)”。2.StringTokenizer(Stringstr,Stringde…

    2022年9月19日
    0
  • [和管子对话] 1 2007-4-5/对面向对象的你言我语

    [和管子对话] 1 2007-4-5/对面向对象的你言我语

    2021年7月24日
    59
  • js文件上传的几种方式_java执行js文件

    js文件上传的几种方式_java执行js文件工作中用到了Ajax上传文件的情景之前自己不知道ajax可以传通过文档发现XHR2.0已经支持了但需要集合ForData目录结构test一级files二级index.html二级saveFiles.php二级示例(根据上传文件的进度生成进度条)代码如下HTML部分

    2025年7月4日
    0

发表回复

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

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