目录
- 在公司的测试流程是什么?
- 你提一个bug,开发不认同的话怎么办?
- 熟悉数据库吗,出道SQL题写出来?
- 熟悉Linux吗?常用的命令有哪些?
- 熟悉adb命令吗?常用的有哪些?
- 如何判断一个bug是前端还是后端的
- 测试用例的设计方法有哪些?
- 给你一个用户名 密码,还有登录按钮,如何设计测试用例?
- Charles抓包工具的请求头?
- HTTP的状态码?
- jmeter做性能或者压力测试需要关注的有哪些内容?
- APP的专项测试:中断测试,弱网测试,兼容性测试怎么做?
- 白盒测试和黑盒测试的区别?
- GET请求与POST请求有什么区别?
- 对于加班可以接受吗?
1.公司的测试流程怎样的?
产品经理确认本次版本的需求,召开需求评审会,进行估时排期,需求和时间都确定之后,UI出设计图,开发人员进行开发,测试人员编写测试用例,召开用例评审会议,制定测试计划,包括准备一些测试数据,等到开发提测,先进行冒烟测试,然后进行单元测试,集成测试以及系统测试(测试内容:功能、界面、可靠性、易用性、性能、兼容性、安全性等),测试人员确认没有问题后进行验收测试,由开发人员部署到预生产环境,进行一轮回归测试,最后部署到生产环境,进行版本对比测试,确认线上用户的正常使用。
2.你提一个bug,开发不认同的话怎么办?
根据需求文档,产品说明二次进行确认,提供bug的证据,或者与产品经理进行确认,等待产品经理最终决定,若还有问题,向上级领导进行反映。
3.熟悉数据库吗,出道SQL题写出来?
代码语言:javascript复制增:insert into 表 values(value1,value2...)
删:delect from 表 where 值
改:update 表 set 字段=新值 where
查:select * from 表 where ....
like :select * from 表 where 值 like '%字段%'
in:允许在where中规定多个值 select * from 表 where 字段 in(value1,value2...)
between:select * from 表 where 字段 between 最小值 And 最大值
inner join:select * from 表1 inner join 表2 on 表1.id =表2.id
left join 与right join:
left join 是罗列出左表中的所有数据,然后找出右表中满足条件的所有数据,右表数据不足的地方用NULL填充
right join 是罗列出右表中的所有数据,然后找出左表中满足条件的所有数据,左表数据不足的地方用NULL填充
平均值avg():select avg(字段) from 表 where 条件
求行数量count():select count(字段) from 表 where 条件
累计之和sum():select sum(字段) from 表
最大值max():select max(字段) from 表
最小值min():select min(字段) from 表
4.熟悉Linux吗?常用的命令有哪些?
代码语言:javascript复制cat:查看文件内容,-n 显示行号
tail:输出尾部文件,-n 显示行号
head:输出头部文件,-n 显示行号
grep:查找文件里符合条件的字符串,- o,只输出匹配的内容,- n,显示行号,- v,取反,- i,不区分大小写,- w,按单词位单位过滤
find:查找目录下文件,- name,按文件名查找,- type,按文件类型查找,- exec,对搜索结果在处理,- mtime,按修改时间查找
tar:压缩打包,- z,压缩,- c,创建,- v,输出打包过程,- f,文件,- t,查看文件,- C,指定解压路径,- x,解压,- h,跟随软连接
which:查询所在路径
pwd:查询所在位置路径
cd:切换目录
mkdir:创建目录文件
rm:删除
touch:更新文件时间戳
hostname:修改主机名
echo:打印输出,-h 不换行,- e 支持转义,t 代表top,n 代表回车
5.熟悉adb命令吗?常用的有哪些?
代码语言:javascript复制adb devices:查询当前设备列表
adb connect IP:连接模拟器
adb install APK:将电脑上的安装包安装到手机上
adb uninstall 包名:卸载APK
adb shell pm clear 包名:清楚应用缓存
adb shell cat :查看内存信息
adb shell monkey -p 包名 -v 次数:进行压力测试
adb shell monkey -p 包名 --throttle 时间(毫秒):插入固定延迟
adb logcat -v time :抓取实时日志
adb logcat *.E:抓取APP崩溃日志
adb logcat -c :清楚旧日志信息
adb version:查询adb版本
6.如何判断一个bug是前端还是后端的?
接口查看法
- 请求接口的URL是否正确,若错误,为前端bug
- body的传参是否正确,若错误,为前端bug
- 响应的状态码是否正确,若错误,为后端bug
- 响应的内容是否正确,若错误,为后端bug
- 求和响应都正确时,前端是否跳转、渲染,若错误,为前端bug
日志查看法 :们发现一个bug,并不确定这个bug属于前端还是后端,可以查看后端服务的日志,复现bug时,查看日志中有没有相关信息,基本可以认为,如果日志没有输出,很可能这个功能并没有与后端交互,也就不存在后端的问题。反之,如果日志有输出,可以进一步查看有无错误日志信息,进一步分析。
经验法:工作中慢慢积累,负责的项目多了,自然对功能的实现过程有了解,也就明白如何分类bug了。在平常的工作和实践中慢慢总结,不要只是一味的点点点测测测,总结复盘很重要。
7.测试用例的设计方法有哪些?
- 划分法:适用于测试数据量过大,且数据操作可以分类,例如给三角形三个边赋值,三角形的3个边长是要输入的3个参数,定义取值范围(0-100);
- 分析法:边界值分析法是作为等价类的补充方法,其测试数据取自等价类的取值范围边界,如上输入参数取值0到100的开区间,即有效边界就是1和99;
- 断法:在测试程序时,人们可以根据经验或直觉推测程序中可能存在的各种错误,从而有针对性地编写检查这些错误的测试用例的方法;
- 法:又称为策略表,基于策略表的测试,是功能测试中最严密的测试方法。该方法适合于逻辑判断复杂的场景,通过穷举条件获得结果,对结果再进行优化合并,会得到一个判断清晰的策略表;
- 验法:简单说,就是在各因素互相独立的情况下,设计出一种特殊的表格,找出能以少数替代全面的测试用例;
- 试:在APP或者网页中随意点击,没有任何逻辑章法,确保不会出现问题。
- 的:因果图法、场景法
8.给你一个用户名 密码,还有登录按钮,如何设计测试用例?
一、功能
- 名与密码均不输入的情况下,点击提交,看toast提示信息
- 确的用户名及密码,点击登录,验证是否可以正常登录
- 功之后是否跳转相对应的页面
- 确的用户名 错误的密码,点击登录,是否可以正常登录
- 误的用户名 正确的密码,点击登录,是否可以正常登录
- 及密码为空格时,点击登录,是否有toast信息提示
- 及密码在头部,中部,尾部有空格时,点击登录,是否有toast信息提示
- 及密码输入英文大小写和特殊符号及表情时,能否支持输入,支持登录
- 功之后是否有记住密码的功能提示,下次登录就不需要再次输入,方便用户体验
- 码时,密码是否自动加密,出现遮挡
- 误时,点击登录,会不会自动记住密码
- 的快捷键及Tab键是否支持切换
二、UI
- 入框与按钮是否对齐
- 的高度,长度是否符合要求
- 有没有错别字
- 计风格与全局设计风格是否统一
- 及密码是否有默认文字提示
- st提示的文字时间是否符合要求
三、性能
- 录页面,需要多久
- 录,接口的响应时间为多久
- 0个人同时使用登录,接口响应时间为多久
四、安全
- L注入
- 及密码是否通过加密的方式传输给服务器
- 在服务器验证还是前端JavaScript验证
- 录的cookie后,是否还能再次登录
- 户在不同设备上进行登录
- 户使用同一IP进行登录
五、安全
- 浏览器内能否正常打开(谷歌,火狐,IE,Safari)
- 电脑系统下,能否正常打开(Windows、Mac)
- 备下,能否正常打开(安卓、苹果、iPad)
- 幕不同分辨率下,打开是否显示正常
9.Charles抓包工具的请求头?
- 请求行:请求方法(get,post,put,delete) URL 协议(HTTP、HTTPS) 回车符
- 消息头:host 主要用于指定被请求资源的Internet主机和端口号
- User-Agent用户代理,现在浏览器的详细信息
- Accept-Language :能够接受的回应内容的自然语言列表
- Content-Type :请求体的多媒体类型(用于POST和PUT请求中)
- 报文体:它将一个页面表单中的组件值通过param1=value1¶m2=value2的键值对形式编码成一个格式化串,它承载多个请求参数的数据。
10.HTTP的状态码?
- 200:表示客户端请求成功
- 301:永久重定向
- 302:临时重定向
- 304:客户端发送了一个带条件的GET 请求且该请求已被允许,而文档的内容并没有改变,则服务器应当返回这个304状态码
- 400:表示客户端请求有语法错误,不能被服务器端解析
- 401:表示请求未经授权,该状态码必须与WWW-Authenticate报文头一起使用
- 404:请求的资源不存在,例如输入了错误的url
- 500:表示服务器发生了不可预期的错误,导致无法完成客户端的请求
- 503:表示服务器当前不能处理客户端的请求,在一段时间后服务器可能恢复正常
11.jmeter做性能或者压力测试需要关注的有哪些内容?
Jmeter中需要关注的聚合报告:
- 线程数:并发用户数
- 请求数Samples:发出了多少个请求,例:模拟10个用户,每个用户迭代10次,就是100次
- 平均响应时间Average:单个请求平均响应时间(毫秒)
- 中位数Median:50% 用户的响应时间(毫秒)
- 90% Line:90% 用户的响应时间。
- Min:最小响应时间(毫秒)
- Max:最大响应时间(毫秒)
- 错误率Error%:出现错误的请求的数量/请求的总数
- 吞吐量Throughput:表示每秒完成的请求数(Request per Second)
12.APP的专项测试:中断测试,弱网测试,兼容性测试怎么做?
- 中断测试:
- 收到电话、短信、通知栏信息、电量不足弹出框、第三方警告框,切换后台应用
- 弱网测试:
- 使用Charles进行APP代理,在Charles中点击proxy,throttle settings,选择启用限制,enable throttling,可以选择56kb/s、256kb/s、512kb/s、2M/S、8M/S等
- 兼容性测试:
- 系统:Android5.0,Android6.0,Android7.0,Android8.0,Android9.0,Android10.0,Android11.0,Android12.0,IOS12,IOS13,IOS14.4,IOS15。
- 机型:华为,小米,vivo,OPPO,三星,iPhone 8 plus,iPhone X,iPhone 11,iPhone 12,iPhone 13。。。
- CPU:高通,联发科,麒麟,苹果
- 屏幕:曲面屏,刘海屏,直面屏
- 分辨率:1280720 标清,19201080 高清。
- 网络:2G/3G/4G/5G/Wifi,弱网、断网时
13.白盒测试和黑盒测试的区别?
白盒测试:是指实际运行被测程序,通过程序的源代码进行测试而不使用用户界面。这种类型的测试需要从代码句法发现内部代码在算法、溢出、路径和条件等方面的缺点或者错误,进而加以修正。白盒测试把测试对象看作一个打开的盒子。
黑盒测试:又称功能测试、数据驱动测试或基于规格说明的测试,是通过使用整个软件或某种软件功能来严格地测试,,而并没有通过检查程序的源代码,或者很清楚地了解该软件的源代码程序具体是怎样设计的。测试人员通过输入他们的数据看输出的结果,从而了解软件怎样工作,应该更适合测试网页游戏。黑盒测试把程序看作一个不能打开的黑盒子。
区别一:从定义上:白盒测试需要从代码句法发现内部代码在算法,溢出,路径,条件等等中的缺点或者错误,进而加以修正。而黑盒测试着重测试软件功能,它并不涉及程序的内部结构和内容特性。黑盒测试并不能取代白盒测试,它与白盒是互补的测试方法,它很可能发现白盒测试不易发现的其他类型错误。
区别二:从测试目的上:黑盒测试的目的是检测是否有不正确或遗漏的功能;数据或者参数上,输入能否正确接收;是否有数据结构错误或外部信息访问错误;性能上是否能够满足要求;是否有初始化或终止性错误。而白盒测试的目的是通过在不同点检查程序的状态,确定实际的状态是否与预期的状态一致,而不顾它的功能。
区别三:检测方式上:白盒测试是穷举路径测试,黑盒测试是穷举输入测试,这两种方法是基于完全不同的观点,反应了事物的两个极端,它们各有侧重和优势,但不能彼此替代。在现代的测试理念中,这两种测试方法不是截然分开的,而是交叉使用。
14.GET请求与POST请求有什么区别?
- GET 请求可被缓存
- GET 请求保留在浏览器历史记录中
- GET 请求可被收藏为书签
- GET 请求不应在处理敏感数据时使用
- GET 请求有长度限制,最大长度是2048个字符
- GET 请求只应当用于取回数据
- POST 请求不会被缓存
- POST 请求不会保留在浏览器历史记录中
- POST 不能被收藏为书签
- POST 请求对数据长度没有要求
15.对于加班可以接受吗?
对于我一个新入职公司的员工来说,需要对公司的环境,业务,代码在短期内提高熟悉度,自己也会主动加班,另一方面来说,加班可能会加快我和公司同事之间的相处,在公司需要加班时,比如产品需要上线,那么会和大家一起加班,这样也是保证项目进度和项目质量的要求。