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

房和城乡建设委员会网站单页网站seo如何优化

房和城乡建设委员会网站,单页网站seo如何优化,网页制作电脑软件,做同性恋网站犯法吗数据驱动模式的测试好处相比普通模式的测试就显而易见了吧!使用数据驱动的模式,可以根据业务分解测试数据,只需定义变量,使用外部或者自定义的数据使其参数化,从而避免了使用之前测试脚本中固定的数据。可以将测试脚本…

数据驱动模式的测试好处相比普通模式的测试就显而易见了吧!使用数据驱动的模式,可以根据业务分解测试数据,只需定义变量,使用外部或者自定义的数据使其参数化,从而避免了使用之前测试脚本中固定的数据。可以将测试脚本与测试数据分离,使得测试脚本在不同数据集合下高度复用。不仅可以增加复杂条件场景的测试覆盖,还可以极大减少测试脚本的编写与维护工作。

下面将使用Python下的数据驱动模式(ddt)库,结合unittest库以数据驱动模式创建百度搜索的测试。

ddt库包含一组类和方法用于实现数据驱动测试。可以将测试中的变量进行参数化。

可以通过python自带的pip命令进行下载并安装:pip install ddt .

一个简单的数据驱动测试

为了创建数据驱动测试,需要在测试类上使用@ddt装饰符,在测试方法上使用@data装饰符。@data装饰符把参数当作测试数据,参数可以是单个值、列表、元组、字典。对于列表,需要用@unpack装饰符把元组和列表解析成多个参数。

下面实现百度搜索测试,传入搜索关键词和期望结果,代码如下:

import unittest
from selenium import webdriver
from ddt import ddt, data, unpack@ddt
class SearchDDT(unittest.TestCase):'''docstring for SearchDDT'''def setUp(self):self.driver = webdriver.Chrome()self.driver.implicitly_wait(30)self.driver.maximize_window()self.driver.get("https://www.baidu.com")# specify test data using @data decorator@data(('python', 'PyPI'))@unpackdef test_search(self, search_value, expected_result):search_text = self.driver.find_element_by_id('kw')search_text.clear()search_text.send_keys(search_value)search_button = self.driver.find_element_by_id('su')search_button.click()tag = self.driver.find_element_by_link_text("PyPI").textself.assertEqual(expected_result, tag)def tearDown(self):self.driver.quit()if __name__ == '__main__':unittest.main(verbosity=2)

在test_search()方法中,search_value与expected_result两个参数用来接收元组解析的数据。当运行脚本时,ddt把测试数据转换为有效的python标识符,生成名称为更有意义的测试方法。结果如下:

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036

使用外部数据的数据驱动测试

如果外部已经存在了需要的测试数据,如一个文本文件、电子表格或者数据库,那也可以用ddt来直接获取数据并传入测试方法进行测试。

下面将借助外部的CSV(逗号分隔值)文件和EXCLE表格数据来实现ddt。

通过CSV获取数据

同上在@data装饰符使用解析外部的CSV(testdata.csv)来作为测试数据(代替之前的测试数据)。其中数据如下:

接下来,先要创建一个get_data()方法,其中包括路径(这里默认使用当前路径)、CSV文件名。调用CSV库去读取文件并返回一行数据。再使用@ddt及@data实现外部数据驱动测试百度搜索,代码如下:

import csv, unittest
from selenium import webdriver
from ddt import ddt, data, unpackdef get_data(file_name):# create an empty list to store rowsrows = []# open the CSV filedata_file = open(file_name, "r")# create a CSV Reader from CSV filereader = csv.reader(data_file)# skip the headersnext(reader, None)# add rows from reader to listfor row in reader:rows.append(row)return rows@ddt
class SearchCSVDDT(unittest.TestCase):def setUp(self):self.driver = webdriver.Chrome()self.driver.implicitly_wait(30)self.driver.maximize_window()self.driver.get("https://www.baidu.com")# get test data from specified csv file by using the get_data funcion@data(*get_data('testdata.csv'))@unpackdef test_search(self, search_value, expected_result):search_text = self.driver.find_element_by_id('kw')search_text.clear()search_text.send_keys(search_value)search_button = self.driver.find_element_by_id('su')search_button.click()tag = self.driver.find_element_by_link_text("PyPI").textself.assertEqual(expected_result, tag)def tearDown(self):self.driver.quit()if __name__ == '__main__':unittest.main(verbosity=2)

测试执行时,@data将调用get_data()方法读取外部数据文件,并将数据逐行返回给@data。执行的结果也同上~
如果对软件测试、接口测试、自动化测试、面试经验交流。感兴趣可以加软件测试交流:1085991341,还会有同行一起技术交流。

通过Excel获取数据

测试中经常用Excle存放测试数据,同上在也可以使用@data装饰符来解析外部的CSV(testdata.csv)来作为测试数据(代替之前的测试数据)。其中数据如下:

接下来,先要创建一个get_data()方法,其中包括路径(这里默认使用当前路径)、EXCEL文件名。调用xlrd库去读取文件并返回数据。再使用@ddt及@data实现外部数据驱动测试百度搜索,代码如下:

import xlrd, unittest
from selenium import webdriver
from ddt import ddt, data, unpackdef get_data(file_name):# create an empty list to store rowsrows = []# open the CSV filebook = xlrd.open_workbook(file_name)# get the frist sheetsheet = book.sheet_by_index(0)# iterate through the sheet and get data from rows in listfor row_idx in range(1, sheet.nrows): #iterate 1 to maxrowsrows.append(list(sheet.row_values(row_idx, 0, sheet.ncols)))return rows@ddt
class SearchEXCLEDDT(unittest.TestCase):def setUp(self):self.driver = webdriver.Chrome()self.driver.implicitly_wait(30)self.driver.maximize_window()self.driver.get("https://www.baidu.com")# get test data from specified excle spreadsheet by using the get_data funcion@data(*get_data('TestData.xlsx'))@unpackdef test_search(self, search_value, expected_result):search_text = self.driver.find_element_by_id('kw')search_text.clear()search_text.send_keys(search_value)search_button = self.driver.find_element_by_id('su')search_button.click()tag = self.driver.find_element_by_link_text("PyPI").textself.assertEqual(expected_result, tag)def tearDown(self):self.driver.quit()if __name__ == '__main__':unittest.main(verbosity=2)

与上面读取CVS文件一样,测试执行时,@data将调用get_data()方法读取外部数据文件,并将数据逐行返回给@data。执行的结果也同上~

如果想从数据库的库表中获取数据,同样也需要一个get_data()方法,并且通过DB相关的库来连接数据库、SQL查询来获取测试数据。

以上就是本文的全部内容,希望对大家的学习有所帮助。有被帮助到的朋友欢迎点赞,评论。

http://www.hrbkazy.com/news/2791.html

相关文章:

  • 武汉企业网站制作百度推广一般要多少钱
  • 如何对网站的文件和资源进行优化?网络营销策略的特点
  • 最权威的做网站设计哪家好百度客服怎么转人工
  • 西安东郊网站建设公司网络销售都是诈骗公司吗
  • 专做婚纱店设计网站东莞网站建设优化排名
  • vs能建设网站吗谷歌seo和百度seo区别
  • 网站开发属于什么软件如何发布自己的网站
  • 亚马逊官方网站的建设电脑优化软件哪个好用
  • 采集wordpress文章上传福州百度快速优化排名
  • 绍兴网站开发全球网站排名查询
  • 哪做网站便宜怎么做seo关键词优化
  • axure 做网站原型图saas建站平台
  • 做外贸大大小小的网站有哪些百度seo查询
  • 盐城网站建站市场调研报告800字
  • 网站建设公司简介模板网络销售面试问题有哪些
  • 博彩网站开发逻辑情感营销案例
  • 一般建站需要多少钱广州网络推广策划公司
  • 免费手机网站平台注册seo服务商
  • 网站制作 wordpress网站建设的方法有哪些
  • 烟台网站设计制作公司电话网站seo推广员招聘
  • 企业商务网站有哪些5118站长网站
  • 如何上传安装wordpress流程优化四个方法
  • 做网站意义和目的佛山seo教程
  • 学校如何建设网站首页山东自助seo建站
  • 专做正品的护肤品网站推广效果最好的平台
  • 建设银行网站怎么下少儿编程
  • 公众号如何做网站百度手机助手下载2022新版
  • php开源企业网站系统百度指数怎么分析
  • 5g云网站建设营销方案怎么写?
  • 江苏做网站价格杭州网络整合营销公司