当前位置: 首页 > news >正文

做搜狗网站seo诊断

做搜狗网站,seo诊断,中国建设监理协会官方网站,日本室内设计网站推荐做过web自动化测试的同学,对Page object设计模式应该不陌生。 Page object库应该根据以下目标开发: Page object应该易于使用 清晰的结构 PageObjects 对于页面对象 PageModules对于页面内容 只写测试,而不是基础。 在可能的情况下防止…

做过web自动化测试的同学,对Page object设计模式应该不陌生。

Page object库应该根据以下目标开发:

Page object应该易于使用

清晰的结构

PageObjects 对于页面对象

PageModules对于页面内容

只写测试,而不是基础。

在可能的情况下防止样板代码。

不需要自己管理浏览器。

在运行时选择浏览器,而不是在类级别。

不需要直接接触selenium。

这只是一种设计模式,只要遵循它有思想,不借助第三方库,我们一样可以实现这种设计模式。

创建baidu_page.py 文件,实现page层封装。

 
class BasePage:"""基础Page"""def __init__(self, driver):self.driver = driverdef get(self, url):self.driver.get(url)def id_(self, id_):return self.driver.find_element_by_id(id_)def xpath(self, xpath):return self.driver.find_element_by_xpath(xpath)class BaiduPage(BasePage):"""百度首页Page"""@propertydef search_box(self):return self.id_("kw")@propertydef search_button(self):return self.xpath("//*[@id='su']")

我们本质上要将元素的定位和元素的操作分开,page层用来定义元素的定位。

接下来创建,test_baidu.py文件,用来实现自动化测试。

from selenium import webdriver
from baidu_page import BaiduPagedr = webdriver.Chrome()
page = BaiduPage(dr)
page.get("https://www.baidu.com")
page.search_box.send_keys("page object")
page.search_button.click()dr.close()

这里你将看不到元素的定位,分层的好处就是,当元素的定位发生改变时,只需要维护好page层即可,对于测试用例来说不需要关心元素怎么定位,只要专心设计好用例即可。

可是,Page层的编写并不太简便,本质上它的作用只是定义一些元素的定位。那我告诉你,只需要4行代码也可以实现上面baidu_page.py的功能,你会不会太简单了?

from page_objects import PageObject, PageElementclass BaiduPage(PageObject):search_box = PageElement(css='#kw')search_button = PageElement(id_='su')

是的,就这么简单,专注于元素的定位的编写,几乎没有多月的东西。而且还可以添加超时时间哦!

from page_objects import PageObject, PageElementclass BaiduPage(PageObject):search_box = PageElement(css='#kw', time_out=2)search_button = PageElement(id_='su', time_out=10)

这样再也不用写恶心的显式等待了,是不是很爽!?

定位一组元素也是非常简单的说。

from page_objects import PageElementsclass BaiduPage(PageObject):……# 百度搜索结果search_result = PageElements(xpath="//div/h3/a")

啥? 项目地址? 别急!别急!

GitHub地址:
GitHub - SeldomQA/poium: Page Objects design pattern test library, support selenium、appium、playwright, etc

原项目已经不再维护,我阅读了原项目代码,虽然只有100多行,但设计非常精妙。可惜缺少元素的等待,这将有助于定位元素的稳定性,所以,在原有项目的基础上增加的该功能。

下载安装:

$ python setup.py install

通过pip命令安装:

$ pip install -i https://testpypi.python.org/pypi selenium-page-objects

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

 

http://www.ritt.cn/news/740.html

相关文章:

  • 网站设计培训成都哪家好金华seo扣费
  • 开发app成本seo赚钱吗
  • 网站建设丨选择金手指排名15品牌推广策略与方式
  • 可以做笔记的网站站长之家统计
  • 网站设计的国际专业流程包括刷排名的软件是什么
  • 开发动态网站有哪些技术百度手机网页
  • 北京如何做网站关键词排名批量查询
  • 网站搭建免费视频教程北京网站推广机构
  • 上海注册公司注册资本整站seo排名要多少钱
  • 统计后台网站有哪些优化关键词排名外包
  • 俄语免费网站制作网络科技有限公司
  • 做任务刷王者皮肤网站营业推广方案
  • 织梦模板首页logo修改海淀区seo多少钱
  • 淘宝网站的建设目标google官方下载安装
  • 网站怎么做视频的软件网络广告一般是怎么收费
  • 贵州遵义企业公司网站建设文军seo
  • 南阳网站设计企业网站建设案例
  • 江苏 网站备案中国免费网站服务器主机域名
  • 做豆腐交流经验的网站企业网站营销的典型案例
  • 做纪录片卖给视频网站企业seo顾问
  • 西安网站建设项目南宁seo外包要求
  • 相册网站怎么做软文代写费用
  • 网站怎么做虚拟连接百度搜索排行榜前十名
  • 一个主机建多少个网站广西壮族自治区在线seo关键词排名优化
  • jsp和php哪个做网站快网络推广外包哪家好
  • wordpress下载安装是英文咸宁网站seo
  • 重庆公司注册费用是多少南京seo公司
  • 邢台网站改版开发长沙网站推广seo
  • 太原建站培训网站推广入口
  • 中小学建设网站爱情链接