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

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

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

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

更多书籍,敬请期待

背景说明

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

1作业内容

题目2:获取xml文件中TestedParam和TestedObj标签的值

初探接口测试框架--python系列3
<?xml version="1.0" encoding="UTF-8" ?><!--测试配置按需扩展-->

<AutoTestConfig shelf="myshelf">                      <!--自动化测试配置-->

<TestedObject p="0.01"><!--被测对象性质 -->

<TestedName>ifr</TestedName><!--被测对象名称,会带入结果数据表-->

<TestedObj>HTTP</TestedObj><!--被测对象类型,会带入结果数据表-->

<TestedVersion>5.0</TestedVersion><!--被测对象版本,会带入结果数据表-->

<TestedFile></TestedFile><!--被测对象msc文件位置-->

<TestedParam>172.161.116.29:8081/</TestedParam>

<TestedLogLevel>2</TestedLogLevel><!--被测对象msc日志记录级别位置-->

<TestedLogDir>Result</TestedLogDir><!--被测对象msc日志位置 -->

<TestedType>发布版1.0</TestedType> <!--被测对象类型(如现网、灰度环境、测试环境等),会带入结果数据表-->

</TestedObject>

<TestedObject><!--被测对象性质 -->

<TestedName>ifr</TestedName><!--被测对象名称,会带入结果数据表-->

<TestedObj>HTTP</TestedObj><!--被测对象类型,会带入结果数据表-->

<TestedVersion>5.0</TestedVersion><!--被测对象版本,会带入结果数据表-->

<TestedFile></TestedFile><!--被测对象msc文件位置-->

<TestedParam>172.161.116.52:8080/</TestedParam>

<TestedLogLevel>2</TestedLogLevel><!--被测对象msc日志记录级别位置-->

<TestedLogDir>Result</TestedLogDir><!--被测对象msc日志位置 -->

<TestedType>发布版2.0</TestedType> <!--被测对象类型(如现网、灰度环境、测试环境等),会带入结果数据表-->

</TestedObject>

</AutoTestConfig>

2相关知识点

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

【设计思路】

Python有三种方法解析XML: SAX,DOM,以及ElementTree:

SAX是一种基于事件驱动的API

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

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

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

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

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

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

综上,本例选用ElementTree来实现

同事的分享 PPT(周莹)

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

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

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

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

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

原件获取地址: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系列3

推荐的文章

历史精彩分享,目录清单

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

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

Fiddler录制jmeter脚本,干货分享

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

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

接口测试实战--SoapUI Pro5.1.2

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

移动性能测试工具iTest4.1

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

上一篇:JSON字符串与Map互转


下一篇:如何使用git 跟进项目进程