6年测试老鸟经验分享:21条自动化测试常见问题及解决思路!

提起自动化测试,可谓仁者见人,智者见智,心中五味杂陈啊!你从任何一个招聘渠道来看最近两年对测试岗位的要求,几乎都要求会自动化测试。而不少人一直认为手工测试才是王道,工作中有的时候也用不到程序,干嘛在面试的时候要求写代码呢?明明自己的测试能力不错,做了多年的功能测试,为什么面试的时候四处碰壁呢?很是想不明白,难道业界最近几年有点儿盲目推崇自动化测试了吗?

虽然我不能说完全明白这些问题的产生的根源,不过以我这五六年从事测试工作的经验来分析一下这些问题的来龙去脉,可能也不是十分准确,希望能给迷茫的同学带来一些思考。

null

一、那什么是自动化测试?

自动化测试是一种使用自动化工具编写和执行测试人员测试脚本和案例的技术。

自动化测试的主要目标是减少手动运行的测试用例数量,而不是完全取消手动测试。

二、什么时候自动化测试?

在以下情况下首选自动化

重复性任务

烟雾和理智测试

使用多个数据集进行测试

回归测试用例

通常,决定基于ROI(投资回报率)

三、自动化测试常见问题和解决思路

1、找不到元素,脚本报“NoSuchElementException:Unable to find element”,或者"定位到了,不能操作,点击无效"

1) 首先查看自己的“属性值”是否写正确

2) 元素的标签不唯一,默认找到第一个

3)向上查看,元素是否在frame或iframe框架中

4) 查看元素是否在新打开的页面中,需要切换到新窗口

5) 换其它的定位方式:id/name/class name/tag name/link text/xpath/css selector

6) 检查元素属性是否是会变动的、是否是隐藏的

7)添加等待时间sleep(),implicitly_wait(),WebDriverWait(driver, 10, 1).until(定位的元素, messages)

8) 查看标签的属性是否有“style=’display:none’->。元素不显示。属性改为block

9) 查看标签的属性是否有‘onclick=return false’->。取消点击。属性改为false(在百度首页,登陆的属性就是这个)

10) 针对于9和8这两种情况,我在网上搜到的结果是:执行js修改属性(这种方法我没有试过,不知道有没有效果)

js=”document.getElementById(‘title‘).style.display=’block’”

driver.execute_script(js)

2、出现“object is not iterable”

1) 首先查看脚本,测试用例出现问题

2) 组织用例时出现错误(我开始是用for循环遍历y,加入测试集合中,返回集合,老是会出现错误,最后改成下方代码,直接返回y,解决问题)

3、出现“Indentation Error”: 是语法问题,脚本代码没有正确对齐

4、使用PO设计模式封装的页面元素类,都有初始化函数“__init__”

5、页面元素调用Page类时候,Page函数,后面括号的“self”不用写

6、Page的初始化包含(self,driver)两个元素,在页面封装类中,初始化中调用方式为Page.__init__(self,driver)

7、类中定义变量,比如x=“hello”,调用使用:self.x

8、在测试用例调用自己页面封装的类时,经过实例化后po=Lzsp(driver),定义函数时候, 不需要再括号中写self

9、提示在页面封装类中没有basePage.py文件中定义好的函数问题

1) 新建名字为module_basePage.pth文件,内容为“basePage.py文件”存放路径:例如(“d:\\test\\page”)

2) 进入python的安装目录,将文件放到python3\lib\sit-packages文件夹下

3) 在测试用例中导入其他文件夹模块引入:import sys

4) sys.path.append(“..”)

5) from .... import ...

10、页面元素封装时候,定位方式一定要写正确,否则会出错

11、进行参数化的时候,读取数据的文件里面代码:“使用绝对地址,加双斜线”

12、运行自动化脚本时候将鼠标放到屏幕中间或者下方,(有可能切换窗口时定位不到)

13、出现”parater must be str“:使用参数有问题,(我的是因为二次定位写的方式有问题)

1) 在封装页面元素定位方式时,经常会会遇到二次定位

2) 第一次定位调用基础类的方法,第二次定位就正常写就行了,例子如下:

3) 我是使用:x=self.find_element(locator).find_element_by_id(locator)

4) 因为我在页面封装中将把定位方式和元素都放到列表中,第二次的元素不写定位方式,只写元素

14、在window命令界面下使用:”python 文件名.py >>report/log.txt 2>&1”命令把结果写入文本中

15、在页面封装中,类的初始化使用如下样式

def __init__(self,driver):

Page.__init__(self,driver)

16、打印输出时显示“not all arguments curerted during string format”是说明前后参数不对应:%前面是一个“%s”,而后面的参数是(“xy”,“xy”)两个

17、同一个模块中的两个类,第二个调用第一个类的方法,直接使用“继承”,2继承1,

def __init__(self,driver):

Logger.__init__(self,’OA’)

self.log=self.getlog()

self.driver=driver

18、Python对文件进行“复制”和“改名”

1) 首先引入os模块:import os

2) 复制:os.system(“copy 文件名.txt 新文件名.txt”)

3) 改名:os.rename(“文件名.txt”,”新文件名.txt”

19、读取txt文件中的汉字和字符打印却是一串编码,像这种:(b'\xef\xbb\xbf\xe5\xa5\xbd\xe7\x9a\x84\r\n')

解决代码如下:

x=open(“2.txt”,”rb”)

y=x.readlines()

for i in y:

j=i.decode(‘utf-8’):在原有代码增加一句

Print (j)

x.close()

20、出现“str object is not callable”的问题

原因是:使用定义的变量名字与内置模块名字相同,(我的原因是:在basePage.py文件中,“得到文本的函数,element.txt后面多加了一对括号”,取消就好了)。针对自己的脚本,检查变量的名字,相同的更改一下

21、在编写自动化用例中,会打开多个窗口,经常会遇到,第一次得到的句柄列表为a=[1,2],第二次得到的句柄列表是b=[1,3,2],偶尔不会

按照顺序排序(一般都是按顺序排的),要切换到句柄3,

可以使用如下方法得到句柄3:

c=list(set(b)-set(a))=[3] :先把a和b变成集合,再取b不同于a的元素

最后再转换为列表赋值给变量c

driver.switch_to.window(c[0]) :切换到新窗口c

四、总结:

以后测试设计时记住两个定律:

●应该自动化的部分就100%的自动化

●需要人工验证的部分就100%的采用人工

测试的目标不是自动化,我们的目标甚至不是测试。目标应该是帮助我们的团队尽可能高效的提供高质量的软件!为达到这个目标而创建测试自动化,才是优质的!

打开APP阅读更多精彩内容