- 代码自动化测试知识:
Why 用工具/代码代替部分人工,节省人力资源,提高测试效率;
What 用脚本化语言控制自动化测试工具对软件进行测试(代码自动化)、工具自动化(jmeter rf, 别人开发好的,简单但有局限性);
When 项目稳定时(第一个版本通常不推荐),基本从第二个版本之后开始;
How:回归测试80%、冒烟测试30%
应用:接口、UI、App、小程序、性能、H5
UI和APP自动化涉及到界面,可变形太大,自动化维护成本太高;
接口测试相对稳定,所以接口自动化性价比更高;
面试回答:我工作中做过自动化测试,主要在回归测试阶段,因为回归测试工作特别繁琐而且重复,用自动化会节省很多时间和人力。
- Python简介
安装好python,cmd进入命令行,输入<python>检查python版本信息
输入<pip -V>;安装PyCharm
- Python 基础语法
标识符要求:1. 数字、字母、下划线组成;2. 不能以数字开头;3. 不能使用关键字
Python关键字:['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
语法规则:对缩进敏感、代码要顶格写(除非父子关系)、区分字母大小写、函数名可以作为标识符但不推荐;
数据类型:int、float、str、bool( True=1,False=0)、列表、字典、集合;
数据规则:int、float、str、bool、列表[]、元祖()、字典{}
字符串取值:通过索引取值;多个值通过切片(取头不取尾、默认值)
内置函数:print()打印内容到控制台, input(), len()判断数据长度, format(), type(), count(), index() 确定索引, find()等
eg:str1.count('F'), str1.find('pang')
运算符:算数运算、赋值运算、比较运算、逻辑运算(与或非)、成员运算(in, not in)
Python中单行注释以 # 开头,例如:
➡️# 这是一个注释
print("Hello, World!")
多行注释用三个单引号 ''' 或者三个双引号 """ 将注释括起来
Python的常用数据类型:整型、浮点型、字符串、列表list[]、元组tuple()、字典dic{}、集合set{}等;
- Python格式化输出:占位置的操作{} format()函数
如:
name='Lisa'
gender='girl'
print('''I am {}''' and is a {},format(name,gender))
or
print('''I am {0}''' and is a {1},format(name,gender))
or
print(F'''I am {name}''' and is a {gender})
or【%s万能填充, %d整型填充】
print('''I am %s''' and is a %s'''%(name,gender))
字符串取值:位置即索引,[索引值] str[0], str[-1]
取多个值:切片,头、尾、步长,字符串[头索引:尾索引:步长],取头不取尾;默认值:头为0,尾为不穷大,步长为1。 str[0:5:2], str[::]。
- 列表、元组、字典、集合
➡️#列表增
list1.append('nana')
list1.insert(1,'lala'), list1.insert(0,list2)
list1.extend(list2)
➡️#列表改,先找到赋值
list1[1]='niuniu'
➡️#列表删
list1.pop() 默认删除最后一个数据;list1.pop(-1)
list1.remove('nana') 删除第一个值
list1.clear() 清空所有数据
元组:不支持增删改,一定要操作,强制转换元组为列表,再转回。list(tuple1) , tuple(tuple1)
字典 键值对,{key:value},每个元素用逗号隔开,key不可重复、不可变,value可以增删改。场景:描述物品的特性;dict1['key'] 找不到报错, dict1.get('key'): 找不到返回None
字典增/修改,指明key赋值
dict1['gender']='female'
dict1.update({'city':changsha,'height':180})
字典删除:dict1.pop('key')
集合 无序,元素不可重复,去重 去除重复项: set(list1), list(list1)
控制流 if 判断 和 for循环----控制代码走向
break 终止循环,跳出循环体
continue 跳出本次循环,不会终止搜有循环
range(0,11,2) range()用来生成整数序列
- 函数学习
def 函数名(a,b,*args, **kwargs): ➡️#占位置的变量名叫做形参
函数体
return XXX
返回值(return):函数执行后有数据需要给到调用人使用,那么这个数据的变量设置成函数的返回值,return后面跟需要的返回值。
必备参数:定义了就必须传;返回值的特点:一定是在函数体的最后一行;
默认参数:如果你有一些参数大概率使用,可以设置一个默认值,默认参数在必须在必备参数后面;
不定常参数 *args:格式是元组,当传入的参数个数未知,且不需要知道参数名称时,参数写在后面;
关键字传参 **kwargs的用法:当传入的参数个数未知,但需要知道参数的名称时(键值对),参数写在后面;
选中函数中内容,按shift+3个双引号:函数注释
- Python接口测试思路:
- 请求方式确认
- 请求地址url
- 请求参数格式
- 请求头
- 是否需要依赖接口
注意⚠️: requests(HTTP库)里除了url,其余参数都是字典格式;
安装:pip install requests --user
两种调用方法:
法一:
import request
requests.post(url,param,header)
法二:
from requests import post
post(url,param, header)
jsonpath用来解析json数据使用的;
接口自动化测试思路:
读数据的函数
openpyxl 第三方库,实现数据的读取和写入;
import openyxl
wb=openpyxl.load_workbook('数据的文件名')
sheet=wb[sheet]
print(sheet(row=1,column=2).value)
read_data(filepath,sheet)执行接口函数,执行结果
res=requests.post(url=url,json=param,headers=header)
apitest(url,param,header)写数据的函数,与预期值做对比(即断言)
res=apitest(url,param,header)
if res['msg'] == expected['msg']:
finresult='Pass'
else:
finresult='Failed'
sheet.cell(row=1,column=1).value=finresult
write(filepath,sheet,finresult,row,colum)保存
wb.save(filepath)
excel数据是整型,python读取为整型;excel数据为字典/元组/列表,python读取为字符串;excel数据是浮点型,python读取为浮点型;
面试题汇总:
- 你能说说python列表、字典、元组的区别吗?
- 列表和元组的元素都是有序的,所以可以通过索引来取值;
- 元组的元素不可以被改变,而列表元素可以增删改查;
字典在python3.6之前都是无序的,不能通过索引取值,可以通过key来取value值;字典的key不能重复和修改、value可以修改,而且键值对可以增加、删除;
举例:list2=[‘男’,‘女’] dict1=dic( name=1,gender=list2[-1])
怎么去取出两个列表中相同的元素?
list3=[]
for i in list1:
for j in list2:
if i==j:
list3.append(i)能解释一下函数的args和*kwargs两种参数的区别?
这两个都是函数的不定长参数:函数调用的时候,可传可不传,也可以传1个or多个;
*args:当函数的必备参数和默认参数接受完后,剩下的参数都会被它接受,并且以元组的格式保存;传参方式通过位置传参;
**kwargs当函数的必备参数和默认参数接受完后,剩下的参数都会被它接受,但是这是以字典格式保存;而且这种需要用关键字传参;
前面位置传参,后面关键字传参,eg,show(‘zhangsan’,age=18);不可以前面关键字传参,后面位置传参
你们Python接口自动化测试用的什么库?如何发送接口请求?
requests库;
我们的接口协议都是Http协议,用的基本是get和post请求,request库有很多自带的方法,比如get、post。我哦们从开发人员那边得到接口的地址、需要传的参数、对应传参方法发送到服务器接口;(res=request.post(url,param,headers))
然后得到相应消息之后,可以直接通过相应的消息对应的方法,获取到对应的内容,比如页面内容、响应码、响应头、cookies等;将得到的信息与预期结果对比。(print(res.json()))说说你对函数的返回值的理解?
函数结束后,可以设置一个返回值,给调用这个函数的代码使用,这个返回数据叫做“返回值”。Python里面return来定义返回值;
return 可以返回一个值、或者多个;不需要返回值,就默认返回None;return语句标志着函数的结束,return语句后面的语句不再执行。你们做自动化测试的时候用什么操作的测试用例?具体步骤说明?
我们的测试用例都放在excel中,所以我们通过openpyxl库来实现excel的读写宫恩功能;把读取到的内容保存到列表、字典,方便后续使用。