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

les做ml网站百度关键词优化多少钱一年

les做ml网站,百度关键词优化多少钱一年,做一个美食网站怎么做,个人建立网站要多少钱概念 PO(Page Object)设计模式是一种面向对象( 页面对象)的设计模式,将测试对象及单个的测试步骤封装在每个Page对象以page为单位进行管理。 优点 可以使代码复用降低维护成本提高程序可读性和编写效率。可以将页面定位和业务操…

概念

PO(Page Object)设计模式是一种面向对象( 页面对象)的设计模式,将测试对象及单个的测试步骤封装在每个Page对象以page为单位进行管理。

优点

  1. 可以使代码复用
  2. 降低维护成本
  3. 提高程序可读性和编写效率。
  4. 可以将页面定位和业务操作分开,测试对象(元素对象)和测试脚本(用例脚本)
  5. 提高用例的可维护

 

非PO模式PO模式
面向过程的线性脚本POM把页面元素定位和业务操作流程分开,实现松耦合
复用性性差UI元素的改变不需要修改业务逻辑代码,只需要找到对应的PO页修改定位即可,数据代码分离
维护性差PO能使代码更具有可读性,高复用性、可维护性

PO三层模式:

主要分三层:
1.base层(对象库层):page页面一些公共的方法。如:初始化、元素定位、点击、输入、获取文本、截图等方法;
2.page层(操作层):封装对元素的操作。将每个涉及的元素操作单独封装一个操作方法,然后根据需求组装操作步骤,如登录方法=输入帐号+输入密码+点击登录三个操作进行组装;
3.scripts层(业务层):导包调用 page页面,使用单元测试框架对业务逻辑进行封装测试。如:实现登录,直接调用page组装的登陆方法即可。
三者的关系:page层继承base层,scripts层调用page层

 

案例:

项目结构介绍:

创建项目,如下图

1. 构建基础的 BasePage 对象层

创建driver,浏览器驱动封装

# encoding='UTF-8'
# 浏览器启动
from selenium import webdriver
def browser():driver=webdriver.Chrome()# driver.get("http://www.baidu.com")return driver

 

创建myuni.py文件,初始化封装,

定义一个继承自unittest.TestCase的测试用例类

定义setUp和tearDown,这两个方法与junit相同,即如果定义了则会在每个测试case执行前先执行setUp方法,执行完毕后执行tearDown方法。

# encoding='UTF-8'
import unittest
from driver import *
class StartEnd(unittest.TestCase):def setUp(self):self.driver=browser()self.driver.implicitly_wait(10)self.driver.maximize_window()def tearDown(self):self.driver.quit()

创建function.py文件,截图功能

# encoding='UTF-8'
import os
from selenium import webdriver# 截图
def insert_img(driver,filename):func_path=os.path.dirname(__file__)# print(func_path)base_dir=os.path.dirname(func_path)# print(base_dir)# 将路径转化为字符串base_dir=str(base_dir)# 对路径的字符串进行替换base_dir=base_dir.replace("\\","/")# print(base_dir)# 获取项目文件的要目录路径base=base_dir.split('/Website')[0]# print(base)# 指定截图存放路径(注意路径最后要加/)filepath=base+'/Website/test_report/screnshot/'+filenamedriver.get_screenshot_as_file(filepath)if __name__=='__main__':driver=webdriver.Chrome()driver.get("http://www.sogou.com")

2. 构建首页的 Page 层(操作层)

创建BasePage.py文件,判断打开的页面是否是预期的页面

# encoding='UTF-8'
from time import sleepclass Page():def __init__(self,driver):self.driver=driverself.base_url="http://localhost"self.timeout=10def _open(self,url):url_=self.base_url+url# print("这个页面url是:%s"%url_)self.driver.maximize_window()self.driver.get(url_)# sleep(2)assert self.driver.current_url==url_,'这不是我们想要的地址'def open(self):self._open(self.url)def find_element(self,*loc):return self.driver.find_element(*loc)

创建LoginPage.py文件,页面元素定位封装

# encoding='UTF-8'
from BasePage import *
from selenium.webdriver.common.by import Byclass LoginPage(Page):url='/news/'username_loc=(By.NAME,'username')password_loc=(By.NAME,'password')submit_loc=(By.NAME,'Submit')def type_username(self,username):self.find_element(*self.username_loc).send_keys(username)def type_password(self,password):self.find_element(*self.password_loc).send_keys(password)def type_submit(self):self.find_element(*self.submit_loc).click()def login_action(self,username,password):self.open()self.type_username(username)self.type_password(password)self.type_submit()loginPass_loc=(By.LINK_TEXT,'我的空间')loginErr_loc=(By.LINK_TEXT,'加入收藏')def type_loginPass_hint(self):return self.find_element(*self.loginPass_loc).textdef type_loginErr_hit(self):return self.find_element(*self.loginErr_loc).text

3.构建业务层

  • 创建test_login.py文件
  • 导包:function、myunit、LoginPage
  • 创建LoginTest类,继承myunit.StartEnd,初始化方法
  • 定义测试用例,名字以test开头,unittest会自动将test开头的方法放入测试用例集中
  • 实现登录,调用LoginPage组装的登陆方法,输入用户名、密码、点击登录、断言,截图

 

# encoding='UTF-8'
import unittest
from model import function,myunit
from page_object.LoginPage import *
from time import sleepclass LoginTest(myunit.StartEnd):def test_login1_normal(self):print("test_login1_normal测试开始")po=LoginPage(self.driver)po.login_action("yuruyi","12345678")sleep(5)self.assertEqual(po.type_loginPass_hint(),'我的空间')function.insert_img(self.driver,"login_normal.png")print("test_login1_normal执行结束")def test_login2_PasswdError(self):print("test_login2_PasswdError测试开始")po=LoginPage(self.driver)po.login_action("yuruyi","1234567")sleep(5)self.assertEqual(po.type_loginErr_hit(),'加入收藏')function.insert_img(self.driver,"login_Err.png")print("test_login2_PasswdError执行结束")def test_login3_empty(self):print("test_login3_empty测试开始")po = LoginPage(self.driver)po.login_action("", "")sleep(5)self.assertEqual(po.type_loginErr_hit(), '加入收藏')function.insert_img(self.driver, "login_empty.png")print("test_login3_empty执行结束")if __name__=='__main__':unittest.main()
常用断言方法:

4. 构建用例集,执行文件,输出自动化测试报告

在测试用例、测试文件比较多的时候,使用统一的主测试执行文件进行测试用例的执行非常方便,这就需要结合discover方法和TextTestRunner进行。

# encoding='UTF-8'
import unittest
# 测试报告模板
from HTMLTestRunnerCN import HTMLTestRunner
import timereport_dir='./test_report'
test_dir='./test_case'print("start run test case")
discover=unittest.defaultTestLoader.discover(test_dir,pattern="test_login.py")now=time.strftime("%Y-%m-%d %H_%M_%S")
report_name=report_dir+'/'+now+'result.html'print("start write report..")
#使用runner运行器运行测试集
with open(report_name,'wb')as f:runner=HTMLTestRunner(stream=f,title="Test Report",description="localhost login test")runner.run(discover)f.close()
print("Test end")

 

测试报告模板

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

 

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取 

 

http://www.zhongyajixie.com/news/39066.html

相关文章:

  • 济南建网站多少钱seo怎么刷排名
  • 安装配置wordpress优化搜索点击次数的方法
  • 如何 html5 网站在线识别图片
  • 厚街手机网站建设成品视频直播软件推荐哪个好用
  • 企业网络安全管理制度和应急预案西安网站seo服务
  • 咨询公司属于什么行业类别整站优化工具
  • 昆山城市建设网站无限制访问国外的浏览器
  • 学做内账的网站什么叫营销
  • 帮人做彩票网站有事吗sem是什么的缩写
  • 皇马logo做网站网上推广平台
  • 如何查看网站是否被做跳转公司网站推广
  • 代理小程序真的赚钱吗天津seo培训机构
  • 攻击jsp网站搜索网站大全
  • filetype ppt 网站建设推广什么app佣金高
  • 深圳平湖网站建设公众号推广合作平台
  • 沂南县建设局网站数据分析软件哪个最好用
  • 固始城乡建设局的网站怎么打不开了现在推广什么app最挣钱
  • 做竞价网站服务器多少钱今天济南刚刚发生的新闻
  • 陕西西安网站建设外贸网站推广服务
  • 一诺互联网站建设公司裂变营销
  • 远离有害不良网站应该怎么做培训机构网站设计
  • 沙坪坝网站建设登录百度账号注册
  • 餐饮公司的网站建设semiconductor
  • 做网站用了别人公司的图片可以吗东莞百度搜索网站排名
  • 长春求推荐好的网站优化推广国际婚恋网站排名
  • 电子商务网站建设与管理第二版答案seo资源咨询
  • 阿里云网站全部清空怎么做如何做好产品网络推广
  • 珠海网站建设 骏域网站百度app登录
  • 新建网站如何推广广东seo推广公司
  • 网站公安备案网站的推广方式有哪些