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

建筑公司网站制作郑州网站建设鹏之信

建筑公司网站制作,郑州网站建设鹏之信,网站制作学校,腾讯服务器做网站思想#xff1a; 1、基本目录的搭建 report:静态输出目录(报告或者日志) data#xff1a;静态输入目录(可以存放Excel数据#xff0c;被读取的一些数据) utils:实用方法层(这里存放的是项目的公共方法#xff0c;一般拿到别…思想     1、基本目录的搭建         report:静态输出目录(报告或者日志)                  data静态输入目录(可以存放Excel数据被读取的一些数据)                  utils:实用方法层(这里存放的是项目的公共方法一般拿到别的项目可以直接使用列如读取Excel中的数据连接数据库)                  apis:接口请求层(这里封装的方法一般都是和项目有关系列如发送post请求发送get请求登录接口注册接口支付接口加入购物车接口)                  testcases:用例目录(用来存放项目中涉及到的用例用例即包含单接口用例也包含关联接口用例管理目录时也可以通过目录分层结构管理)                  conftest:这里存放的是fixture只对文件的所在目录生效如果只是单目录用例那么可以在根目录下创建如果分为分层目录结构的用例那么为了                                    满足当前目录的用例可以在该目录下创建一个conftest用来存放fixturefixture是pytest框架的根髓                  pytest.ini:是pytest的配置文件可用来存放一些运行配置项如-v -s 或者配置日志输出渠道该文件的具体配置可百度学习              2、接口框架的重要思想》金字塔的配置                  ①reportdata---》utilsapis---》conftest---》pytest.ini---》testcases                  ②以上相当于金字塔结构从左至右为从底部到顶部的过程                  ③金字塔精髓之处在于(上部依赖底部底部不依赖于上部)举一个列子(testcases中的用例需要调用apis目录中的接口请求方法而apis不会去主动调用testcases)所以                      在工作中我们如果修改了某一个文件需要往上找看看谁调用了这个文件相对应的进行修改 ##########################utils中的db.py的封装 import pymysql# # # 1. 连接数据库 # conn pymysql.connect( # host服务器地址, # port3306, # user用户名, # password密码, # db数据库名 # ) # # 2. 建立游标 # cur conn.cursor(pymysql.cursors.DictCursor) # 没有s 有括号 # # # 3. 执行sql # # 3.1 执行查询 # cur.execute(SELECT * FROM cardInfo WHERE cardNumberhzc_00011;) # conn.commit() # # 获取结果 # result cur.fetchall() # # result cur.fetchone() # 取一条少一条 # # cur.fetchmany(3) # print(result) # # # 3.2 执行修改 # # cur.execute(DELETE FROM cardInfo WHERE cardNumberhzc_00011;) # # conn.commit() # # # 4. 关闭 # cur.close() # conn.close()class DB(object):def __init__(self):self.conn pymysql.connect(host服务器地址,port3306,user用户名,password密码,db数据库名,autocommitTrue)self.cur self.conn.cursor(pymysql.cursors.DictCursor) #添加此配置项默认commit了即建立游标def do_sql(self, sql):print(执行sql, sql)self.cur.execute(sql) #执行sql语句# self.conn.commit() return self.cur.fetchall() #返回查询到的所有结果class FuelCardDB(DB): #继承DB执行具体的sql语句def del_card(self, card_number):执行删除语句self.do_sql(fDELETE FROM cardInfo WHERE cardNumber{card_number})def check_card(self, card_number):执行查询语句result self.do_sql(fSELECT * FROM cardInfo WHERE cardNumber{card_number};)if result:return Truereturn Falsedef add_card(self, card_number):执行添加语句result self.check_card(card_number)if not result:self.do_sql(fINSERT INTO cardInfo (cardNumber) VALUES ({card_number});) #######################api文件的封装 思想该文件可以将不同的请求方法不同的请求地址接口封装成一个类然后在用例层用到了哪一个就去调取哪一个 以下实列是添加加油卡项目 import requestsDATA_SOURCE_ID bHRzclass Api(object):def __init__(self, base_url):self.url base_url /gasStation/processself.session requests.session()def add_fuelcard(self, card_number):json_data {dataSourceId: DATA_SOURCE_ID, methodId: 00A, CardInfo: {cardNumber: card_number}}res self.session.post(self.url, jsonjson_data)print(res.text)return resdef bind_card(self, user_name, id_type, id_number, card_number):json_data {dataSourceId: DATA_SOURCE_ID,methodId: 01A,CardUser: {userName: user_name,idType: id_type,idNumber: id_number},CardInfo: {cardNumber: card_number}}res self.session.post(self.url, jsonjson_data)print(res.text)return resdef query_card(self, user_id, card_number):#dataSourceIdbHRjczExuserId1039cardNumber1111111111methodId02Aparams {dataSourceId: DATA_SOURCE_ID,methodId: 02A,userId: user_id,cardNumber: card_number}res self.session.get(self.url, paramsparams)print(res.text)return res 思想该文件下主要封装的是fixtures方法即为了简化用例层步骤可以将操作前提步骤和过程步骤在此文件下完成在该文件下 有一个base_url,这个是安装的插件安装方法为pip install pytest-base-url import pytest from utils.db import FuelCardDB from apis.fuelcard_api import Apipytest.fixture(scopesession) def db():#实例化一个对象return FuelCardDB()pytest.fixture(scopesession) def api(base_url):#实例化一个对象并将配置文件中的base_url传给Api层的方法return Api(base_url)pytest.fixture def del_card(db):def _del_card(card_number):db.del_card(card_number)yielddb.del_card(card_number)return _del_card #######################pytest.ini文件的封装 思想上述已说明该文件为pytest框架的配置文件即运行用例时会默认执行该文件操纵注意表达格式conftest文件和api文件中 都用到了base_url,就是这里的base_url目的是当服务器地址变了之后不用去接口层去一一修改服务器地址只需要修改这里的地址就行但是 如果接口的请求地址变了就要去一一修改了毕竟针对不同的请求地址封装了不同的方法 [pytest] addopts -s --htmlreports/report.html --self-contained-html testpaths testcases base_url http://***.***.***.***:***#######################总结 ①接口的主要框架基本已经出来了当我们需要其他方法时可以再去相对应的添加例如读取excel表格数据的方法可以再封装到utils目录下 ②如果需要公共的方法时可以去百度查一下别人写好的模块说实话自己写半天也不如人家封装好的实用性更高我们的目标就是会使用别人封装好的方法就OK了 ③如果涉及到自己的业务模块就要自己去封装了例如上面所说的api文件conftest文件都是和业务相关的 ④对于初级的自动化测试人员最主要的不是去写框架而是去运用好别人写好的框架来设计用例写用例 ⑤一条用例的基本流程测试环境准备、测试数据准备、发送数据、获取数据响应结果、设置断言、环境清理
http://www.w-s-a.com/news/627179/

相关文章:

  • 酒庄企业网站app制作多少钱一个
  • 西安模板建网站网站如何做直播轮播
  • 网站功能需求表百度怎么投放自己的广告
  • 如何免费制作网站网站icp备案费用
  • 网站建设最新教程wordpress表白墙
  • android电影网站开发网站建设与设计实习报告
  • 公司汇报网站建设方案烟台seo网站推广
  • 文章网站哪里建设好找素材的网站
  • 怎么做自己的彩票网站公司建设网站价格
  • 国外比较好的设计网站网站后台无法上传图片
  • 帮别人做网站的公司是外包吗用户登录
  • 关于我们网站模板小莉帮忙郑州阳光男科医院
  • 上海门户网站怎么登录永州网站制作
  • 微信网站模版下载做销售的去哪个网站应聘
  • 好看的个人博客主页长安网站优化公司
  • 企业网站关站大型综合新闻门户网站织梦模板
  • 网站优化排名易下拉效率查企业网站
  • 网站建设湛江关于汽车的网站
  • 南宁模板建站多少钱企业黄页名单
  • 企业网站的建设一般要素有网站定制公司地址
  • 婚纱摄影网站设计案例四川省城乡建设厅官方网站
  • 怎么做海淘网站wordpress首页表单
  • 大连网站优化技术长沙高端网站建设服务
  • 郎创网站建设做的网站 v2ex
  • 广东网站建设教程江西城乡住房建设网站
  • 做ppt卖给网站wordpress insert
  • 文化传媒公司网站模板wordpress转typecho
  • 网站建设设计视频郑州 服装网站建设
  • 网站建设什么公司好织梦cms默认密码
  • 大型网站 空间网上商城官网入口