自动化测试面试题

1.取列表中的最后一个元素

a = [1,2,4,2,11,33,12]
print(a[-1])

2.反转列表中的元素

a = [1,2,4,2,11,33,12]
#反转方法一
a.reverse()
print(a)
#反转方法二
a[::-1]
print(a)

3.str常用方法

a = "abCDef"
a = ['a','b']
a = "#".join(a)
print(a)
a = "abCDef"
#转大小定方法
a.lower()
#是否是以f结束
a.endswith("f")
#是否是以a开头
a.startswith("a")
#格式化字符串
a.format("")
#a的索引,没有找到-1
a.find("a")
#a的索引。没有找到报异常
a.index("a")
#把字符串加#
a.join("#")
#切割字符串
a.split(",")
#去空格
a.strip()
#大写
a.upper()

4.动态参数

# *打包,打包成元组
def star(*args):
    print(type(args))
star(1,2,3)

# *解包成单个元素
def star(a,b,c):
    print(a,b,c)
a = (1,2,3)
star(*a)
#打包成字典
def star2(**kwargs):
    print(type(kwargs))
star2(a=1,b=2,c=3)

#解包成单个元素
def start22(a,b,c):
    print(a,b,c)
dic = {"a":"aa","b":"bb","c":"cc"}
start22(**dic)

5.装饰器

#在不改变代码的情况下,还给已有代码增加新功能
def a():
    print("a")

def b(fun):
    print("b")
    fun()
b(a)
def log(fun):
    '''
    增加了记日志的功能
    :param fun: 
    :return: 
    '''
    def wrapper(*prams,**kwargs):
        print("现在执行加法运算")
        return fun(*prams,**kwargs)
    return wrapper

def add(a,b):
    return a+b

#把函数作为变量名传过去。用时再调用。函数名()才是调用
a = log(add)
print(a(1,2))
def log(fun):
    '''
    增加了记日志的功能。用时再传参数
    :param fun:
    :return:
    '''
    def wrapper(*prams,**kwargs):
        print("现在执行加法运算")
        return fun(*prams,**kwargs)
    return wrapper

#加注解更方便调用。不会影响代码的逻辑
@log
def add(a,b):
    return a+b

s = add(1,2)
print(s)

 

6.unitest框架如何做测试?

管理测试用例。

测试用例类继承unittest.TestCase

unittest.main()运行所有测试用例

unittest.TestSuite()创建测试套

unittest.defaultTestLoader()运行测试ddu

跳过测试用例注解@unittest.skip(reason)

setup teardown 方法

断言方法

7.pytest框架?

在组织测试用例方面更灵活。它可以自定义标签来决定运行哪些用例。如果运行失败了再执行几次。

可以把公用的功能写在conftest.py文件中,一般把fixture函数写在这里面,如果是只执行一次的话,可以设置为session级别。

8.requests

它是第三方库。

可以发http协议的请求。各个方法的都支持。get,post。

get传参有两种方式:拼接在url后面传参,params方式传参。也可以携带请求头,cookie等。

post传参两种方式,data,json. data可以是字典。默认content-type为form。如果data是字符串,则还要在请求头中指明了application/json. json无论是json字符串还是json对象,默认content-type都是application/json

获取响应最常用的是j.json(),可以在这里面提取要断言的内容。如果响应为文件的话,响应这样获取j.content().其它一般情况下是j.text()

对于cookie的处理有两种。一种是直接获取cookie,携带cookie的方式。一种是用session的这种方式。

 

9.https协议403代表含义

    类别    原因短语
1XX    Informational(信息性状态码)    接受的请求正在处理
2XX    Success(成功状态码)    请求正常处理完毕
3XX    Redirection(重定向状态码)    需要进行附加操作以完成请求
4XX    Client Error(客户端错误状态码)    服务器无法处理请求
5XX    Server Error(服务器错误状态码)    服务器处理请求出错
 

2XX——表明请求被正常处理了

1、200 OK:请求已正常处理。

2、204 No Content:请求处理成功,但没有任何资源可以返回给客户端,一般在只需要从客户端往服务器发送信息,而对客户端不需要发送新信息内容的情况下使用。

3、206 Partial Content:是对资源某一部分的请求,该状态码表示客户端进行了范围请求,而服务器成功执行了这部分的GET请求。响应报文中包含由Content-Range指定范围的实体内容。

3XX——表明浏览器需要执行某些特殊的处理以正确处理请求

4、301 Moved Permanently:资源的uri已更新,你也更新下你的书签引用吧。永久性重定向,请求的资源已经被分配了新的URI,以后应使用资源现在所指的URI。

5、302 Found:资源的URI已临时定位到其他位置了,姑且算你已经知道了这个情况了。临时性重定向。和301相似,但302代表的资源不是永久性移动,只是临时性性质的。换句话说,已移动的资源对应的URI将来还有可能发生改变。

6、303 See Other:资源的URI已更新,你是否能临时按新的URI访问。该状态码表示由于请求对应的资源存在着另一个URL,应使用GET方法定向获取请求的资源。303状态码和302状态码有着相同的功能,但303状态码明确表示客户端应当采用GET方法获取资源,这点与302状态码有区别。

当301,302,303响应状态码返回时,几乎所有的浏览器都会把POST改成GET,并删除请求报文内的主体,之后请求会自动再次发送。

7、304 Not Modified:资源已找到,但未符合条件请求。该状态码表示客户端发送附带条件的请求时(采用GET方法的请求报文中包含If-Match,If-Modified-Since,If-None-Match,If-Range,If-Unmodified-Since中任一首部)服务端允许请求访问资源,但因发生请求未满足条件的情况后,直接返回304.。

8、307 Temporary Redirect:临时重定向。与302有相同的含义。

4XX——表明客户端是发生错误的原因所在。

9、400 Bad Request:服务器端无法理解客户端发送的请求,请求报文中可能存在语法错误。

10、401 Unauthorized:该状态码表示发送的请求需要有通过HTTP认证(BASIC认证,DIGEST认证)的认证信息。

11、403 Forbidden:不允许访问那个资源。该状态码表明对请求资源的访问被服务器拒绝了。(权限,未授权IP等)

12、404 Not Found:服务器上没有请求的资源。路径错误等。

5XX——服务器本身发生错误

13、500 Internal Server Error:貌似内部资源出故障了。该状态码表明服务器端在执行请求时发生了错误。也有可能是web应用存在bug或某些临时故障。

14、503 Service Unavailable:抱歉,我现在正在忙着。该状态码表明服务器暂时处于超负载或正在停机维护,现在无法处理请求。
 

10.正则表达式 match与 search 的区别

import re

#search可以不从位置0开始匹配。match必须从位置0开始匹配,否则就返回None
# username = '#jerry_friend'
username = 'jerry_friend'
m = re.match(r'\w{8,20}', username)
print(m)
print(m.span())
print(m.group())

username = '#jerry_friend'
m = re.search(r'\w{8,20}', username)
print(m)
print(m.span())
print(m.group())

11.linux创建文件?

touch

vi 文件名  :x 保存

12.获取查看动态日志

tail -f

13.防火墙

开启关闭端口号

14.jmeter性能测试

先进行性能需求分析,主要要考虑的问题是:要不要做,用什么工具做。具体的性能指标是什么,哪些功能需要做性能测试。然后开会评审性能指标是否正确,目前是否有环境可供做性能测试。

然后写设计测试用例。主要考虑的是单业务和综合业务的负载测试,压力测试,基准测试。稳定性测试。测试用例写清楚各个接口的步骤,场景,要不要加集合点,并发数是多少,思考时间是什么。

开发脚本。一般情况下录制脚本。然后优化脚本,进行参数化,加思考时间,集合点等。调试脚本,设置并发数等。

15.测试流程,测试设计

测试流程:需求评审,提取需求点,设计测试用例,准备测试环境,执行测试。提bug,回归bug。定版

测试用例常用设计方法:场景法。边界值分析,等价类划分,错误推测法。正交法

16.需求分析时要考虑的点,如何做?

是否符合用户的显性的及隐性的需求。

功能要求,性能要求,安全性要求,可靠性要求。数据的定义,接口的定义

17.需求评审有没参加过?

遗漏的需求,错误的需求,异常的需求。各种组合条件下的需求

18.web应用组件?apach http有没用过。nginx

做反向代理服务器和负载均衡服务器

19.shell脚本?echo?if格式?while?

num1=100
num2=100
if test $[num1] -eq $[num2]
then
    echo '两个数相等!'
else
    echo '两个数不相等!'
fi

for loop in 1 2 3 4 5
do
    echo "The value is: $loop"
done

 

 

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值