目录
Python 自动化测试面试题目汇总
1、super 是干嘛用的?在 Python2 和 Python3 使用,有什么区别?为什么要使用 super?请举例说明。
2、阅读以下代码,推导最后结果:
3、快速编写前端 HTML、Javascript、Vue 代码。
4、L = [1, 2, 3, 11, 2, 5, 3, 2, 5, 3],用一行代码得出 [11, 1, 2, 3, 5]
5、L = [1, 2, 3, 4, 5],L[10:]的结果是?
6、L = [1, 2, 3, 5, 6],如何得出 '12356'?
7、列表和字典有什么区别?
8、如何结束一个进程?
9、进程、线程有什么区别?什么情况下用进程?什么情况下用线程?
10、什么是ORM?为什么要用ORM?不用ORM会带来什么影响?
11、写一段代码,ping 一个 ip 地址,并返回成功、失败的信息。
12、说说接口测试的流程,介绍一下request有哪些内容。
13、UI 自动化,如何做集群?
14、移动端 UI 自动化,经常会自动安装 2 个程序,你知道那两个程序是什么东西不?
15、说5个以上 Linux 命令。
16、介绍下你在这个项目中是如何使用 Jenkins 的。
17、说说你对敏捷模式的认识。
18、了解过 Docker 不?
19 如何去定位属性动态变化的元素?
23、黑盒测试的测试用例常见设计方法都有哪些?请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。
Python 自动化测试面试题目汇总
1、super 是干嘛用的?在 Python2 和 Python3 使用,有什么区别?为什么要使用 super?请举例说明。
答:
super 用于继承父类的方法、属性。
super 是新式类中才有的,所以 Python2 中使用时,要在类名的参数中写 Object。Python3 默认是新式类,不用写,直接可用。
使用 super 可以提高代码的复用性、可维护性。修改代码时,只需修改一处。
代码举例:
class sonClass(baseClass):
def test2(self):
super().test1(num)
son = sonClass()
son.test1(11)
2、阅读以下代码,推导最后结果:
def test():
for i in range(4):
yield i
g = test()
for n in [1, 10, 5]:
g = (add(n, i) for i in g)
print(list(g)) # 结果是 [15, 16, 17, 18]
答: 所有的结果都是生成器表达式,不调用它,不从里面取值,就不干活。附上我的推导过程:
n = 10
g = (add(n,i) for i in (add(n,i) for i in test()))
# print(list(g)) # [20, 21, 22, 23]
n = 5
g = (add(n,i) for i in (add(n,i) for i in (add(n,i) for i in test())))
g = (add(n,i) for i in (add(n,i) for i in (5,6,7,8)))
g = (add(n,i) for i in (10,11,12,13))
g = (15,16,17,18)
print(list(g)) # [15, 16, 17, 18]
3、快速编写前端 HTML、Javascript、Vue 代码。
答:
HTML、Javascript 代码:Vue 代码编写:
4、L = [1, 2, 3, 11, 2, 5, 3, 2, 5, 3],用一行代码得出 [11, 1, 2, 3, 5]
答: list(set(L))
5、L = [1, 2, 3, 4, 5],L[10:]的结果是?
答: 空列表(当时有点紧张,一直在“空列表”和“索引超出范围”两个答案之间徘徊)。
6、L = [1, 2, 3, 5, 6],如何得出 '12356'?
答: 注意,个人觉得这个题有坑,列表的元素不是字符串,所以不能 ''.join(L)。以下是过程:
7、列表和字典有什么区别?
答: 一般都是问列表和元组有什么不同。
(1)获取元素的方式不同。列表通过索引值获取,字典通过键获取。
(2)数据结构和算法不同。字典是 hash 算法,搜索的速度特别快。
(3)占用的内存不同。
8、如何结束一个进程?
答:
(1)调用 terminate 方法。
(2)使用 subProcess 模块的 Popen 方法。使用简单,具体用法,这里不展开。
9、进程、线程有什么区别?什么情况下用进程?什么情况下用线程?
答:
(1)区别:
① 地址空间和其它资源(如打开文件):进程之间相互独立,同一进程的各线程之间共享。某进程内的线程在其它进程不可见。② 通信:进程间通信 IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。③ 调度和切换:线程上下文切换比进程上下文切换要快得多。④ 在多线程操作系统中,进程不是一个可执行的实体。
(2)使用场景:同时操作一个对象的时候,比如操作的是一个全局变量,我用线程,因为全局变量是所有线程共享的。
10、什么是ORM?为什么要用ORM?不用ORM会带来什么影响?
答:
ORM 框架可以将类和数据表进行对应,只需要通过类和对象就可以对数据表进行操作。
通过类和对象操作对应的数据表,类的静态属性名和数据表的字段名一一对应,不需要写 SQL 语句。
ORM 另外一个作用,是根据设计的类生成数据库中的表。
11、写一段代码,ping 一个 ip 地址,并返回成功、失败的信息。
答: 使用 subProcess 模块的 Popen 方法(使用简单,具体用法,这里不展开)。
12、说说接口测试的流程,介绍一下request有哪些内容。
答:
(1)流程:获取接口文档,依据文档设计接口参数,获取响应,解析响应,校验结果,判断测试是否通过。
(2)request 内容:
① 封装了各种请求类型,get、post 等;
② 以关键字参数的方式,封装了各种请求参数,params、data、headers、token 等;
③ 封装了响应内容,status_code、json()、cookies、url 等;
④ session 会话对象,可以跨请求。
13、UI 自动化,如何做集群?
答: Selenium Grid。
14、移动端 UI 自动化,经常会自动安装 2 个程序,你知道那两个程序是什么东西不?
答: 守护精灵,和 Python 并发编程中的 daemon 原理一样,父进程/父线程的代码执行完毕,它就终止,要写在 start 方法前面。另外,要找到配置文件,注释掉两行代码。
15、说5个以上 Linux 命令。
答:一口气,劈里啪啦说了 10 多个。
16、介绍下你在这个项目中是如何使用 Jenkins 的。
答:用的不深入,说了基本操作,比如定时构建执行代码一。
17、说说你对敏捷模式的认识。
答:小步快跑,拥抱变化。测试中,可以通过行为驱动测试,有个框架 lettuce 可以用。
18、了解过 Docker 不?
答: 了解,没用过。然后说了下对 Docker 大概的认识、优势。
19 如何去定位属性动态变化的元素?
xpath或者css通过同级、父级、子级进行定位
或者
可以使用的方法有:
starts-with(以什么开始)
ends-with(以什么结束)
contains 包含
以contains 为例子:
比如我们在定位中使用的xpath定位一个使用下拉框中的某一项值,我们得到的xpath为
.//[@id=‘cascader-menu-3932’]/li[1]
目标下拉框元素中的3932是一个后台动态加载给前台的值,每次刷新网页都会变化,这个时候使用传统的xpath定位,一定是找不到该元素的,可以将上述标黄的部分改写成模糊匹配
[@id=‘cascader-menu-3932’]
[contains(@id,“cascader-menu”)]
其他的部分不改变,直接搬回来,然后就可以正常定位了
.//* + [contains(@id,“cascader-menu”)] + /li[1] = .//[contains(@id,“cascader-menu”)]/li[1]
23、黑盒测试的测试用例常见设计方法都有哪些?请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。
1)等价类划分: 等价类是指某个输入域的子集合.在该子集合中,各个输入数据对于揭露程序中的错误都是等效的.并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试.因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件,就可以用少量代表性的测试数据.取得较好的测试结果.等价类划分可有两种不同的情况:有效等价类和无效等价类.
2)边界值分析法:是对等价类划分方法的补充。测试工作经验告诉我,大量的错误是发生在输入或输出范围的边界上,而不是发生在输入输出范围的内部.因此针对各种边界情况设计测试用例,可以查出更多的错误.
使用边界值分析方法设计测试用例,首先应确定边界情况.通常输入和输出等价类的边界,就是应着重测试的边界情况.应当选取正好等于,刚刚大于或刚刚小于边界的值作为测试数据,而不是选取等价类中的典型值或任意值作为测试数据.
3)错误猜测法:基于经验和直觉推测程序中所有可能存在的各种错误, 从而有针对性的设计测试用例的方法.
错误推测方法的基本思想: 列举出程序中所有可能有的错误和容易发生错误的特殊情况,根据他们选择测试用例. 例如, 在单元测试时曾列出的许多在模块中常见的错误. 以前产品测试中曾经发现的错误等, 这些就是经验的总结. 还有, 输入数据和输出数据为0的情况. 输入表格为空格或输入表格只有一行. 这些都是容易发生错误的情况. 可选择这些情况下的例子作为测试用例.
4)因果图方法:前面介绍的等价类划分方法和边界值分析方法,都是着重考虑输入条件,但未考虑输入条件之间的联系, 相互组合等. 考虑输入条件之间的相互组合,可能会产生一些新的情况. 但要检查输入条件的组合不是一件容易的事情, 即使把所有输入条件划分成等价类,他们之间的组合情况也相当多. 因此必须考虑采用一种适合于描述对于多种条件的组合,相应产生多个动作的形式来考虑设计测试用例. 这就需要利用因果图(逻辑模型). 因果图方法最终生成的就是判定表. 它适合于检查程序输入条件的各种组合情况.
:以上总结就是我总结的部分面试题目,希望大家能用到。
感谢每一个认真阅读我文章的人!!!
我个人整理了我这几年软件测试生涯整理的一些技术资料,包含:电子书,简历模块,各种工作模板,面试宝典,自学项目等。如果在学习或工作中遇到问题可以直接进群询问,群里也会有大神帮忙解答,群号 198408628 备注333



