接口自动化测试怎么一步步学、按照我的方式、你不可能学不会-第二集

第14节 logging日志模块封装

logging模块介绍

logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级、日志保存路径、日志文件回滚等

1.日志的基本用途:

a.记录程序运行过程中的错误,方便跟踪定位问题,减少调试和维护成本;

b.通过日志能还原整个程序的执行过程,能了解程序的整体状态;

c.对用户行为分析和数据统计,知晓信息来自于哪个模块;

d.在设计测试框架的时候,也可以通过设计日志来记录框架的整个测试流程,捕捉测试结果

2.logging日志框架的组成

Logger:日志,暴露函数给应用程序,基于日志记录器和过滤器级别决定哪些日志有效

LogRecord :日志记录器,将日志传到相应的处理器处理

Handler :处理器, 将(日志记录器产生的)日志记录发送至合适的目的地

Filter :过滤器, 提供了更好的粒度控制,它可以决定输出哪些日志记录

Formatter:格式化器, 指明了最终输出中日志记录的布局

3.logging函数中的具体参数

filename:指定的文件名创建FiledHandler,这样日志会被存储在指定的文件中;

filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“w”还可指定“a”;

format:指定handler使用的日志显示格式;

datefmt:指定日期时间格式;

level:设置rootlogger的日志级别;

stream:用指定的stream创建StreamHandler;

常见日志格式

控制台基本log输出日志方式

封装一个公共logging日志方法,方便框架调用

基本用例调用,不过这个只是一个简单的实例,框架更加完善

第十五节 使用config.ini环境配置封装

一些公关配置信息独立出来方便好维护

例如:数据库连接(一般都写到配置文件里面)

开发过程中,连接数据的一些配置信息都会写到配置配置,方便处理

安装:pip install configparser

官网:

configparser​pypi.org

1.python工程创建一个config.ini文件,配置如下:

#接口自动化配置信息

接口环境、部分公共信息配置参数

封装读取config方法

实例坑爹调用,妥了

第十六节  实现excel管理不同项目用例基础封装

自动化用例管理采用EXCEL管理、方便业务人员随时上手、扩展用例组装易用性....

使用xlrd模块、paramunittest、pytest(参数化)

安装:

pip install paramunittest  APi文档:

ParamUnittest​pypi.org

pip install xlrd  API文档:

API Reference - xlrd 1.1.0 documentation​xlrd.readthedocs.io

1.excel读取热身

开胃菜excel读取先来个汤暖胃

2.接口自动化用例组装部分

用例实现开胃菜样子

开胃菜封装过程

3.用例很多如果想把excel用例都执行,那就就参数化(参数化unittest&pytest都有实现方式,下面是unitest.pytest后面讲)

unittest参数化咋搞的,先上demo,别直接开始,容易不理解

接口中的实现小部分,会就行了

pytest来一个,调用跟unittest一样的,写法小差异

第十七节 断言、请求库、公共模块抽离封装

断言:

框架中用的断言,截取部分

框架中用到的请求库封装,细节还有很多,慢慢看吧,一两句说不清楚

公共模块部分吧,例如:登录、cookie、session

第十八节 框架搭建

接口自动化pytestv2.0版本(本来附加导图,时间关系就这样吧,别来虚的)

#目录说明

  common 公共方法

      Assert 封装assert方法

      public 读取excel用例公共方法封装

      publicLoin 登录等公共封装

      publicrequest封装请求、配置信息

      Log  封装记录log方法,分为:debug、info、warning、error、critical

            日志方法封装输出(err.log&log.log日志)

      cookie&session公共方法封装

      Shell 封装subprocess方法CASE执行结束进程操作(优化性能)


  conf 配置文件公共方法封装

      config.ini  域名/端口/超时环境配置

      readconfig  读取ini配置信息封装方法

  Log  日志输出   


  Report 1.pytestcase执行报告生成

        2.environment.properties配置报告显示环境


  TestCase XX版本CASE实现

      1.单项目/多项目case实现

      2.jsonpath使用快捷获取节点值

  TestFile 

      excel case单接口&多接口组装

      img 请求图片/文件存放地址

  pytest.ini 

      #参考官方处理错误方法:https://docs.pytest.org/en/stable/warnings.html

      #处理pytest执行结果警告信息-过滤

  run

    #执行所有CASE方法

      命令执行(#执行所有用例文件pytest --alluredir=report  allure generate report)

第十九节 企业实战运用场景展示、讲解

小demo,别说自私,关键写不完太多了

environment.properties报告环境配置

environment=on-line

host=https://selectcar.yiche.com

version=v2.0

tester=student

展示一下就行,过把干瘾

第二十节  gitlab基本使用搭建使用

企业目前大多用git、svn管理代码(接口代码一样,我们要跟上时代的部分,用仓库管理代码,因为公司代码不可能你一个人写,放自己电脑吧!得管理)但是为了演示方便,俺找了个

gitee管理代码,跟你们公司自己搭建的一样,我就图方便,为了给大家演示,那来吧.go go

Gitee 提供免费的 Git 仓库,还集成了代码质量检测、项目演示等功能

哥哥姐姐、老铁们,我和你们心在一起....先注册!

不过这玩意,不能上传你们公司代码机密呀!我只是模拟演示git怎么用 

地址:https://gitee.com/

Gitee - 基于 Git 的代码托管和研发协作平台​gitee.com

1.git仓库怎么用,基本命令得会,上菜

Git常用操作命令收集:

1) 远程仓库相关命令

检出仓库:$ git clone git://github.com/jquery/jquery.git

查看远程仓库:$ git remote -v

添加远程仓库:$ git remote add [name] [url]

删除远程仓库:$ git remote rm [name]

修改远程仓库:$ git remote set-url --push[name][newUrl]

拉取远程仓库:$ git pull [remoteName] [localBranchName]

推送远程仓库:$ git push [remoteName] [localBranchName]

2)分支(branch)操作相关命令

查看本地分支:$ git branch

查看远程分支:$ git branch -r

创建本地分支:$ git branch [name] ----注意新分支创建后不会自动切换为当前分支

切换分支:$ git checkout [name]

创建新分支并立即切换到新分支:$ git checkout -b [name]

删除分支:$ git branch -d [name] ---- -d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项

合并分支:$ git merge [name] ----将名称为[name]的分支与当前分支合并

创建远程分支(本地分支push到远程):$ git push origin [name]

删除远程分支:$ git push origin :heads/[name]

我从master分支创建了一个issue5560分支,做了一些修改后,使用git push origin master提交,但是显示的结果却是'Everything up-to-date',发生问题的原因是git push origin master 在没有track远程分支的本地分支中默认提交的master分支,因为master分支默认指向了origin master 分支,这里要使用git push origin issue5560:master 就可以把issue5560推送到远程的master分支了。

    如果想把本地的某个分支test提交到远程仓库,并作为远程仓库的master分支,或者作为另外一个名叫test的分支,那么可以这么做。

$ git push origin test:master        // 提交本地test分支作为远程的master分支 //好像只写这一句,远程的github就会自动创建一个test分支

$ git push origin test:test              // 提交本地test分支作为远程的test分支

如果想删除远程的分支呢?类似于上面,如果:左边的分支为空,那么将删除:右边的远程的分支。

$ git push origin :test  // 刚提交到远程的test将被删除,但是本地还会保存的,不用担心

3)版本(tag)操作相关命令

查看版本:$ git tag

创建版本:$ git tag [name]

删除版本:$ git tag -d [name]

查看远程版本:$ git tag -r

创建远程版本(本地版本push到远程):$ git push origin [name]

删除远程版本:$ git push origin :refs/tags/[name]

4) 子模块(submodule)相关操作命令

添加子模块:$ git submodule add [url] [path]

如:$ git submodule add git://github.com/soberh/ui-libs.git src/main/webapp/ui-libs

初始化子模块:$ git submodule init ----只在首次检出仓库时运行一次就行

更新子模块:$ git submodule update ----每次更新或切换分支后都需要运行一下

删除子模块:(分4步走哦)

1)$ git rm --cached [path]

2) 编辑“.gitmodules”文件,将子模块的相关配置节点删除掉

3) 编辑“.git/config”文件,将子模块的相关配置节点删除掉

4) 手动删除子模块残留的目录

5)忽略一些文件、文件夹不提交

在仓库根目录下创建名称为“.gitignore”的文件,写入不需要的文件夹名或文件,每个元素占一行即可,如

target

bin

*.db   

2.创建仓库

创建的样子,直接按照图填写就行

3.提交代码(前提你想用命令行、windows&linux装环境,否则提交辣子)

Git 全局设置:

git config --global user.name "dazhuangjiekou"

git config --global user.email "772487091@qq.com"

创建 git 仓库:

mkdir inter

cd inter

git init

touch README.md

git add README.md

git commit -m "first commit"

git remote add origin https://gitee.com/dazhuangjiekou/inter.git

git push -u origin master

已有仓库?

cd existing_git_repo

git remote add origin https://gitee.com/dazhuangjiekou/inter.git

git push -u origin master

很多细节,时间有限不能一一道来

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容