请选择行业
请选择职位
请选择省份
请选择城市

软件测试面试题·JMeter篇

时间: 2024-01-26 15:12   作者: 程序员馨馨   点击次数: 
 
  近期,有很多粉丝在催更关于Jmeter的面试题,索性抽空整理了一波,以下是一些高频JMeter面试题,拿走不谢~
  一、JMeter的工作原理
  JMeter就像一群将请求发送到目标服务器的用户一样,它收集来自目标服务器的响应以及其他统计数据,这些统计数据通过图形或表格显示应用程序或服务器的性能。
  二、用JMeter怎么做接口测试的
  1、根据开发提供接口文档,编写接口测试用例
  2、利用JMeter做接口测试,添加线程组和HTTP请求,在HTTP请求中,添加对应的ip,port,url,请求参数等
  3、添加响应断言
  4、添加查看结果树
  5、执行用例
  6、查看结果,验证接口返回与预期是否一致
  三、JMeter是怎么实现接口之间关联的
  有两种方式,即正则表达式提取器和json提取器,比如说我们要获取一个Token,可以把获取到的Token值赋予一个变量,在下一个接口调用这个变量即可,如果需要提取的文本是页面上某元素的属性值,建议使用json提取器,如果需要提取的文本在页面上的位置不固定,或者不是元素的属性,建议使用正则表达式提取器
  四、性能测试流程
  主要分五个阶段:
  1、需求调研
  进行需求调研和需求分析,输出性能测试需求表和性能测试计划书
  2、测试准备
  构建测试模型,制定测试方案,设计性能测试案例,准备压测的数据和脚本,输出性能测试方案和测试用例文档
  3、用例执行
  执行测试用例,记录性能测试结果,做好性能测试的监控,对测试结果进行分析,输出性能测试的执行日志
  4、测试报告编写
  编写性能测试报告,包含测试结果,出现的缺陷和问题,结果分析和性能测试的结论,输出性能测试分析报告
  5、测试总结
  对本次压测过程进行总结和复盘
  五、JMeter中如何设置断言
  鼠标右击请求---断言---响应断言---响应断言,输入要检查比对的项,设置好断言后,执行接口用例,查看结果树,如果通过,不会有任何报错提示,如果断言失败,就会有红色报错。
  如果接口返回的数据是Json格式的,也可以添加Json断言.
  六、JMeter添加http请求默认值元件的作用
  相当于给其范围内的所有http请求取样器都设置了默认值,比如协议,主机地址、端口、编码等,将这些参数统一管理,减少了接口的维护成本,取值的顺序(优先级)是:
  HTTP请求本身设置的值
  HTTP请求下的HTTP请求默认值设置的值
  线程组下的HTTP请求默认值设置的值
  七、JMeter参数化的方式有哪些?
  主要有4种方式:
  1、CSVDataSetConfig
  在配置元件中添加,适合场景参数范围较大的场景,方便用户随时修改参数数据,使用较多的就是参数化用户名和密码的场景
  2、函数助手
  是Jmeter自带的函数,适合生成随机数的场景,例如生成随机字符串,随机日期,随机数字等
  3、用户自定义变量
  在配置元件中添加,适用于在测试计划中参数不经常变化的场景,例如设置host、端口号、url等
  4、用户参数
  在前置处理器中添加,适用于参数取值范围很小的场景,一般会将登录的用户账号和密码作为用户参数
  八、JMeter常用断言方法有哪些?
  主要有四种:
  1、响应断言(ResponseAssertion)
  响应断言是最常用的一种断言方法,主要是对响应结果中的文本内容进行断言,比如响应结果是否包含指定的值,或者是否等于指定的值。
  响应断言可以适用各种返回类型的响应结果,如Test、html、application/json、application/xml等
  2、JSON断言
  它一般用于断言某个字段值是否等于指定的值。
  JSON断言只能针对响应结果为applicaton/json格式的进行断言操作,如果是其他类型(如:Test、xml),则无法使用这种方式
  3、断言持续时间(DurationAssertion)
  通常用于做性能测试,一般用于检查HTTP请求的响应时间是否超过预期值
  4、beanshell断言
  使用BeanShell脚本来执行断言检查,可以用于更复杂的个性化需求,使用更灵活,功能更强大,但是要能够熟练使用beanshell脚本。
  九、JMeter测试元件的执行顺序
  配置元件->前置处理器->计时器->取样器->后置处理器->断言->监听器
  十、如何减少JMeter的资源需求
  1、使用非GUI模式进行测试,例如jmeter-n-ttest.jmx-ltest.jtl
  2、使用尽可能少的监听器
  3、不要在负载测试期间使用“查看结果树”或“在表中查看结果”监听器,仅在脚本编写阶段使用它们来调试脚本
  4、在循环中对于相似的请求,最好使用同一个采样器,结合CSVDataSetConfig来改变样本,而不是使用多个相似的取样器
  5、不要使用功能模式
  6、使用CSV输出而不是XML
  7、仅保存需要的数据
  8、使用尽可能少的断言
  9、使用性能最佳的脚本语言

打印本页 | 加入收藏

上一篇:10年软件测试经验,该有什么新的职业规划     下一篇:5年测试开发工程师感悟:写给还在迷茫中的

关闭  
主要城市: 北京 上海 杭州 广州 南京 武汉 长沙
全部城市: