selenium之PO模式

selenium之PO模式selenium之PO模式PO模式的精髓:测试对象和测试用例的分离PageObject的设计思想上是把元素定位和元素操作进行分层,这样带来的最直接的好处是当元素发生变化时,只需维护page层的定位,而不需要关心在那些测试用例当中使用了这些元素。在编写测试用例时,也不需要关心元素是如何定位的。下边以百度搜索为例来通过代码来说明PO模式1.封装常用的元素操作base.pyimporttimefromseleniumimportwebdriverclassBasePage(object

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

selenium之PO模式

PO模式的精髓:测试对象和测试用例的分离
Page Object的设计思想上是把元素定位和元素操作进行分层,这样带来的最直接的好处是当元素发生变化时,只需维护page层的定位,而不需要关心在那些测试用例当中使用了这些元素。在编写测试用例时,也不需要关心元素是如何定位的。
下边以百度搜索为例来通过代码来说明PO模式
1.封装常用的元素操作
base.py

import time
from selenium import webdriver
class BasePage(object):
""" 基础Page层,封装一些常用方法 """
def __init__(self,driver):
self.driver = driver
#TODO 打开页面
def open(self,url=None):
if url == None:
self.driver.get(self.url)
else:
self.driver.get(url)
#TODO 八种定位元素方法
#TODO id定位
def by_id(self,id):
return self.driver.find_element_by_id(id)
#TODO name定位
def by_name(self,name):
return self.driver.find_element_by_name(name)
#TODO class定位
def by_class_name(self,class_name):
return self.driver.find_element_by_class_name(class_name)
#TODO tag_name定位
def by_tag_name(self,tag_name):
return self.driver.find_element_by_tag_name(tag_name)
#TODO link定位
def by_link_text(self,link_text):
return self.driver.find_element_by_link_text(link_text)
#TODO partial link定位
def by_partial_link_text(self,partial_link_text):
return self.driver.find_element_by_partial_link_text(partial_link_text)
#TODO xpath定位
def by_xpath(self,xpath):
return self.driver.find_element_by_xpath(xpath)
#TODO css定位
def by_css(self,css):
return self.driver.find_element_by_css_selector(css)
#TODO 获取title
def get_title(self):
return self.driver.title
#TODO 获取页面text,仅使用xpath定位
def get_text(self,xpath):
return self.by_xpath(xpath).text
#TODO 执行Javascript脚本
def js(self,script):
self.driver.execute_script(script)

创建BasePage类作为所有Page类的基类,在BasePage类中封装一些方法,这些方法是我们做自动化时常用到的。

  • open()方法用于打开网页
  • by_id()方法通过id定位
  • by_name()方法通过name定位
  • by_class_name()方法通过class_name定位
  • by_tag_name()方法通过tag标签定位
  • by_link_text()方法通过文本内容定位
  • by_partial_link_text()方法通过部分文本内容定位
  • by_xpath()方法通过xpath定位
  • by_css()方法通过css定位
  • get_title()和get_text()方法,是自动化测试经常用到的方法,get_text()方法需要接收元素定位
  • 执行Javascript脚本也是常用到的方法

2.封装元素定位
baidu_page.py

from baidu_web.base import BasePage
class BaiduPage(BasePage):
url="http://www.baidu.com"
#定位搜索框输入搜索数据
def search_input(self,search_key):
self.by_id("kw").send_keys(search_key)
#点击百度一下按钮搜索
def search_button(self):
self.by_id("su").click()

执行测试用例即代码
case.py

import unittest
from time import sleep
from selenium import webdriver
from baidu_web.baidu_page import BaiduPage
class TestBaidu(unittest.TestCase):
@classmethod
def setUpClass(cls):
cls.driver = webdriver.Chrome()
def test_baidu_search_case(self):
page = BaiduPage(self.driver)
page.open()
page.search_input("selenium ")
page.search_button()
sleep(2)
self.assertEqual(page.get_title(),"selenium_百度搜索")
@classmethod
def tearDownClass(cls):
cls.driver.quit()
if __name__ == '__main__':
unittest.main()

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/139780.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • php7.2调用curl_init()报错解决方案「建议收藏」

    php7.2调用curl_init()报错解决方案「建议收藏」使用PHP7.2运行代码的时候出现提示curl_init()调用失败:未定义的问题,即Calltoundefinedfunctioncurl_init()解决方法:1.在linux终端键入apt-cachesearchcurl|grepphpubuntu@VM-16-9-ubuntu:/etc/php/7.2/apache2$apt-cachesearc…

  • C# excel转换Json

    C# excel转换Json//如果要支持xlsx格式表格,请在本机电脑安装这个//http://download.microsoft.com/download/7/0/3/703ffbcb-dc0c-4e19-b0da-1463960fdcdb/AccessDatabaseEngine.exe参考案例:https://www.cnblogs.com/fengxiang/p/3551621.html使用的时候记得…

  • c#操作数据库(winform如何修改数据库设置)

    鉴于很多童鞋们对数据库操作不是很熟悉,这里对数据库操作的相关知识做个介绍。首先介绍ADO.NET中的几个常用的对象,介绍的很简单。1.SqlConnection 这是数据库连接对象,通过对其进行实例化来创建针对数据库的连接,其参数为数据库连接字符串。如下:S

  • navicat15.0.22激活码【在线注册码/序列号/破解码】

    navicat15.0.22激活码【在线注册码/序列号/破解码】,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • 数电课设 八路抢答器设计详解

    数电课设 八路抢答器设计详解设计一个八路竞赛抢答器,可同时供八名选手或八个代表队参加比赛,他们的选号分别是1、2、3、4、5、6、7、8,各用一个抢答按钮,按钮的编号与选手的编号相对应,分别是S1、S2、S3、S4、S5、S6、S7、S8。给节目主持人设置一个控制开关,用来控制系统的清零(编号显示码管灭灯)和抢答器的开始(开始倒计时)。抢答器具有数据锁存和显示的功能。抢答开始后,若有选手按动抢答按钮,编号立即锁存,并在LED数码管上显示出选手的编号,同时扬声器给出音响提示。此外,要封锁输入电路,禁止其他选手抢答,优先抢答选手的编号

    2022年10月20日
  • SpringBoot——spring-data-jpa之分页查询

    SpringBoot——spring-data-jpa之分页查询SpringBoot——spring-data-jpa之分页查询

发表回复

您的电子邮箱地址不会被公开。

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