爱游戏全站app官网入口-爱游戏官网

初探接口测试框架-爱游戏全站app官网入口

2023-09-06,,

点击标题下「微信」可快速关注

坚持的是分享,搬运的是知识,图的是大家的进步,没有收费的培训,没有虚度的吹水,喜欢就关注、转发(免费帮助更多伙伴)等来交流,想了解的知识请留言,给你带来更多价值,是我们期待的方向,有更多兴趣的欢迎切磋,我们微信订阅号,爱游戏官网的联系方式如下:

更多书籍,敬请期待

背景说明

我们清楚的知道自动化测试包含ui自动化、接口自动化、单元自动化,其中接口自动化测试可以说是性价比比较高的,我们今天不讲如何开展接口自动化测试,而是来看看接口测试框架的神秘。小怪带领着大家一起简单轻松的完成接口测试框架,只需要完成6次python(2.7版本)作业,就好了。这些课程是在内部经过实践的,0基础掌握的关键看你是否action起来,我会分为6次,逐步分享出来,想学的就往下看吧,本期是第3课。

1作业内容

题目2:获取xml文件中testedparam和testedobj标签的值

                     

ifr

http

5.0

172.161.116.29:8081/

2

result

发布版1.0

ifr

http

5.0

172.161.116.52:8080/

2

result

发布版2.0

2相关知识点

此外提供同事(沈军)的总结知识:

【设计思路】

python有三种方法解析xml: sax,dom,以及elementtree:

sax是一种基于事件驱动的api

优点:sax流式读取xml文件,比较快,占用内存少。

缺点:需要用户实现回调函数(handler)

dom一次性读取整个文档将xml数据在内存中解析成一个树,通过对树的操作来操作xml

优点:使用dom的好处是你不需要对状态进行追踪,因为每一个节点都知道谁是它的父节点,谁是子节点.

缺点:dom需要将xml数据映射到内存中的树,一是比较慢,二是比较耗内存,使用起来也比较麻烦!

elementtree就像一个轻量级的dom,具有方便友好的api。代码可用性好,速度快,消耗内存少。

综上,本例选用elementtree来实现

同事的分享 ppt(周莹)

原件获取地址:https://yunpan.cn/cv5rygcyc9ifp  访问密码 687e

3参考例子一

代码较长,获取地址:https://yunpan.cn/cv5rygcyc9ifp  访问密码 687e

4同事(李沁)的感悟

作业内容

这次作业要求获取xml文件中testedparam和testedobj标签的值。

本来觉得比较简单,没想到在读取中文名文件这里就花了一点时间。我以前写简单的脚本都是用英文名,所以竟然是第一次遇到这个坑。调试一番,最后是使用了encodefilename= os.getcwd() "\\" xmlfile.decode("utf-8").encode("gbk")获取当前目录,然后先将文件名进行uft-8解码再按照gbk编码。

后面就好说了,使用xml.dom这个包,很容易就得到想要的tag标签的内容。仍需要gbk编码一次。将查询到的内容保存在字典里,选择字典是因为字典本身和标签一样具有成对的特性,最后输出。

字符编码处理

找到一篇很好的python-进阶-编码处理小结很好地说明了关于python处理字符编码的问题。作者对于整个项目,提出的建议是规范统一编码,对于具体的一个文件内的处理顺序,他提出的原则如下,我觉得挺好的。

1. decode early

2. unicode everywhere

3. encode later

关于本次作业,在头部定义#coding=utf-8后,在这个py文件内部,编码是utf-8的。而控制台默认编码是gbk。如果直接使用xmlfile在控制台输出是浣滀笟2.xml所以需要先用utf-8解码,再用gbk编码告诉控制台,完整语句如下:

realfilename= os.getcwd() "\\" xmlfile.decode("utf-8").encode("gbk")
在写作业小结时,我又发现了新的情况。如果目录不含中文,那么第二步gbk编码可以不需要,也能输出正确结果。os.getcwd()的部分不应该影响后面的编码的,这里又不是很理解了。

以及,在与周莹探讨这个问题时,发现如果将文件保存编码修改为gb2312,在头处声明为 #coding=gbk(声明为utf-8也一样),就可以在直接使用 xmlfile = “作业2.xml”了。即编译器进行编译运行时,是根据文件保存时的编码来的,而不是头部声明。(eclipse保存文件时会根据声明来保存为不同编码的文件,notepad 默认保存为utf-8格式)

不同的字符编码

ascii编码(美国信息交换标准代码)

1967年提出,使用一个字节(8位),从00000000到11111111表示256个字母或符号。实际定义使用的是128个,其中33个不可显示(多数是废除使用的控制字元),95个可以显示。这95个包括在键盘上直接能按出来的大小写英文字母、数字、符号。

非ascii编码

某些欧洲国家使用一些奇特的编码体系,将ascii编码没有定义那些位置拿来定义成é之类的字母,仍然使用一个字节来表示。
亚洲国家字太多了,一个字节无论如何也放不下,就有一些其他编码方式。我们熟悉的汉字编码,比如gbk、gb2312都算这类。

unicode字符集(万国码)

unicode本身不是一种编码,而是一个大集合,把所有的字母符号都纳入其中。unicode只规定了每个字符对应的编码号,但并没有给出存储方法(所以百花齐放了)。比如在word里输入674e,按键盘的alt x,就可以变成李。这是因为在word里,是采用unicode(十六进制),就是utf-16来存储的。点开符号也看得到如下的列表。
utf-8编码

utf-8是unicode的实现方式之一,类似的utf-16(一个字符采用两个字节或四个字节表示)、utf-32(一个字符采用四个字节表示)都是对unicode字符集的实现方式。utf-8使用最为广泛。utf-8是变长编码方式,可以根据需要使用一到四个字节表示一个字符。

utf-8的编码规则很简单,只有二条:

1)对于单字节的符号,字节的第一位设为0,后面7位为这个符号的unicode码。因此对于英语字母,utf-8编码和ascii码是相同的。

2)对于n字节的符号(n>1),第一个字节的前n位都设为1,第n 1位设为0,后面字节的前两位一律设为10。剩下的没有提及的二进制位,全部为这个符号的unicode码。

ansi编码

在windows自动notepad记事本保存时可以选择ansi编码。这其实是windows给中文用户提供的一种默认混合编码,对于英文文件是ascii编码,对于简体中文文件是gb2312编码(只针对windows简体中文版,如果是繁体中文版会采用big5码)。

大端和小端存储方式

上面保存选择编码的页面也看到了unicode big endian(对应另一种就是小端)。大端和小端就是在需要两个字节存储一个字符时(比如utf-16),按照本身样子存就是大端,两个字节倒过来就是小端。比如674e是utf-16的李字,67 4e 的存法是大端,4e 67 是小端。
对此unicode规定在文件头要加入表示编码顺序的字符,就是fe ff两个字节,fe ff是大端,ff fe是小端。

到此,我们第2次作业,需要的知识点和参考的样例全部奉献出来了,action起来!

推荐的文章

历史精彩分享,目录清单

接口测试框架--python系列1

初探接口测试框架--python系列2

fiddler录制jmeter脚本,干货分享

jmeter随笔(12)--定制json响应结果断言

jmeter接口自动化,你敢想,我敢玩

接口测试实战--soapui pro5.1.2

测试路上,聊聊思路,谈谈手段

移动性能测试工具itest4.1

↓↓↓ 点击"阅读原文" 【查看更多信息】

初探接口测试框架--python系列3的相关教程结束。

网站地图