当前位置: 首页 > news >正文

怎么更改网站域名解析ui设计师是什么意思

怎么更改网站域名解析,ui设计师是什么意思,请问有重庆有做网站吗,网站懒加载怎么做文章目录 安装JMeter和Groovy为什么选择Groovy#xff1f; 压测需求以及思路准备JMeter脚本以及脚本正确性验证使用Test Script Recorder来获取整条业务线上涉及的接口为什么使用Test Script Recorder#xff1f; 配置Test Script Recorder对接口进行动态化处理处理全局变量以… 文章目录 安装JMeter和Groovy为什么选择Groovy 压测需求以及思路准备JMeter脚本以及脚本正确性验证使用Test Script Recorder来获取整条业务线上涉及的接口为什么使用Test Script Recorder 配置Test Script Recorder对接口进行动态化处理处理全局变量以及命名各接口接口请求前、请求后的脚本处理使用JSR233 PreProcessor读取商品ID请求接口使用Regular Expression Extractor Post-Processors来处理接口响应并为下一个接口设置变量使用Debug Sampler或Debug PostProcessor来调试脚本继续下一个接口在提交表单项时存在多个值的动态处理 撤销JMeter的某些改动结语 安装JMeter和Groovy Mac OS下使用Homebrew安装 brew install jmeter brew install groovy安装完毕之后确保jmeter和groovy没问题 直接启动JMeter jmeter查看groovy版本 groovy -v为什么选择Groovy 在JMeter中使用脚本语言有BeanShell和Groovy因为Groovy和Java更相近所以选择Groovy。虽然以前没接触过Groovy但是靠着IDE和官方文档、Google上手还算顺利。 压测需求以及思路 因为是需要对整条业务流程进行压测所以各个接口之间的请求、响应需要相互依赖做起来有点像自动化测试的流程只不过自动化测试专注于验证测试流程结果是否准确而这里的压测专注于某些接口是否有问题。 由于我不属于自动化测试团队所以在我接到这个需求的时候第一个想法就是如何准备测试数据 因为压测的是用户购买的流程但是在用户购买之前商家需要创建商品、根据不同的业务再给商品设置一些特殊的属性例如商品显示设置、购买限制、折扣等。这些其实就是准备数据了。 毕竟压测还是想做成自动化的如果做成自动化的话那么准备数据的脚本也要写但是这一部分其实是和自动化测试重复了。经过考虑之后决定做成半自动化。也就是准备数据来自于自动化测试先运行自动化测试生成基础准备数据在基础准备数据之上再手动做一些配置例如给商品加很多库存等。因为我们的自动化测试对于商品不会有很多库存而压力测试必须运行在很多库存的前提下所以这一步通过手动配置最后再运行压力测试。大概思路就是这样虽然不是尽善尽美但是能基本保证工作重心在压力测试的脚本准备以及测试上而不是准备数据上。 准备JMeter脚本以及脚本正确性验证 由于整条业务线涉及到N个接口所以我这里只拿几个接口来举例子每个接口的配置思路以及调试方式基本类似。 使用Test Script Recorder来获取整条业务线上涉及的接口 为什么使用Test Script Recorder 不知道Test Script Recorder的同学建议先去读一遍官方文档。一句话概括就是它会把你在页面上各种点点点的动作设计到的请求都记录下来生成一个集合。 现实情况可能是这样 开发团队没有接口管理工具或者即使有但是当前测试的这条业务线涉及的都有哪些接口写压测脚本的人不一定很清楚。即写压测的人和开发的人不是一拨人。这种情况下不太可能花太多时间再去了解其业务、接口传参、接口返回等等。整体业务线接口多、复杂各种情况都有这在现实中很常见而我们要测的这条线的某种场景可能并不需要传某些参数或者处理某些响应这样我们也不需要花太多时间去搞清楚到底什么该传什么。方便不需要自己一个接口一个接口的去建相关的HTTP Request Sampler只需要进行一些参数动态处理即可。大大减少了我们的工作量。 我们只需要使用Test Script Recorder像功能测试一样按照我们要测试的流程一路在页面上点下来正常完成业务流程即可就可以拿到该测试流程上的所有请求接口了。 配置Test Script Recorder 直接参考JMeter官方Test Script Recorder一节即可。 注意浏览器要使用官方文档中提到的Iceweasel/Firefox我一开始也看到了文档但是天真的以为是个浏览器就行在尝试了Google和Edge之后无果后乖乖地下载了一个Firefox浏览器。 对接口进行动态化处理 到这一步你本地应该已经成功运行了Test Script Recorder并拿到了相关接口集合如果没有的话建议阅读上面提到的官方文档确保拿到接口集合之后再阅读这部分。 处理全局变量以及命名各接口 对于每个接口都会用到的scheme、host、port、contextPath,放在User Defined Variables中 并在HTTP Request Defaults中引用 对于每个接口最好重命名每个Http Request Sampler使其能体现出该Sampler对应的功能这样做不仅见名知义对于以后更复杂的压力测试我们可能会使用多个Test Fragment来完成也有助于以后我们拆分或重构压力测试脚本。不会因为各种奇葩命名而去花费时间再去搞清楚该脚本到底是干嘛用的。 接口请求前、请求后的脚本处理 每个接口的请求数据都是动态的我们使用Test Script Recorder得到的接口集合里面的数据是静态的这一步我们就是要把数据变成动态的。完成这一工作的是Pre Processors和Post-Processors。 我们前面说过压力测试的基础数据来自于自动化测试好在自动化测试团队将测试过程中生成的关键信息例如商家ID、商品ID写入某个文件 所以在请求接口之前我们需要读取该文件拿到商品ID列表并随机获得一个商品ID 使用JSR233 PreProcessor读取商品ID 在显示商品接口请求之前使用Groovy读取文件来随机获得商品ID和后续用来购买的邮件地址并通过vars.put将其放到对应的变量中去以便后续可以读取。 关于vars支持的方法以及用法请参考JMeter官方文档最佳实践一节以及用户手册中的Function一节 请求接口 这里通过${itemId}引用刚刚在PrePocessor中设置的值 使用Regular Expression Extractor Post-Processors来处理接口响应并为下一个接口设置变量 由于我们这里的业务流程是MVC而不是REST所以返回的是个HTML页面所以通过正则表达式后置处理器来获取页面中的元素 这里对要获取的页面元素使用正则表达式的捕获组,也就是要用()$1$代表第一个捕获组以此类推。 Match No. (0 for Random) Indicates which match to use. The regular expression may match multiple times 这里会把正则表达式的结果赋值给onSale和vars.put一样以便后续接口可以引用 使用Debug Sampler或Debug PostProcessor来调试脚本 在对整条业务线的接口进行动态化处理的时候我建议是 一个接口一个接口来即改完一个接口验证一个没问题再继续下一个。如果是中间的接口则是该接口没问题之后还要和前面已验证的接口一起再验证一遍确保接口本身动态化没问题确保整条业务线到该接口处是正确的。在修改接口的过程中将在该接口后面的接口先暂时Disable掉。 验证脚本 Thread Group 右键 Validate 如果有问题了例如没参数是空、或者请求失败等我们需要知道是否正确地读取了数据和正确地处理了响应数据。这时我们就需要知道在整个脚本运行过程中那些动态参数到底是什么 Debug Sampler和Debug PostProcessor二者作用类似都是将脚本运行中的参数打印出来我一般使用Debug Sampler放在最后面如上面的几张截图一样。 继续下一个接口 这里使用If Controller来判断上一个接口响应设置的onSale是否不为空如果不为空则进入该controller的里面的接口。这里的接口动态化和验证和上面的类似 按照上述原则这个接口验证没问题了就可以下一个下一个没问题再下一个直到整条业务线接口都覆盖到。不再赘述。 在提交表单项时存在多个值的动态处理 如果表单中每一项的HTML元素只对应一项那么使用上面的流程没什么问题。有时候我们一个元素可能会提交多项正常的HTML表单提交上来的是 itme_id_1: 1 item_id_2: 2 item_id_3: 3这种如何处理这种情况的呢举个例子在Pre Processor中使用如下脚本即可 def idPrefix item_id_ for(i in 1..30) {var key idPrefix idef value vars.get(key)if(value){sampler.addArgument(item_ids, value)} else {break} }有关该问题可参考stackoverflow更详细的回答 撤销JMeter的某些改动 一般在写脚本的时候保存之前 Command Z就可以撤销但是保存之后就撤销不了了。平时没什么问题但是有些极特殊情况下在保存之后想要撤销怎么办呢 我在写脚本期间由于JMeter不能开多个窗口导致我有时候会频繁切换jmx文件有一次把整体业务线的压力测试接口都已调整好了但是我此时在JMeter中又使用Test Script Recorder中玩了一遍其他流程然后保存了…当我反应过来之后我直接傻了相当于之前所有的工作白做了…慌得要死… 经过调查幸好JMeter有backup机制默认最大备份文件是10个文件路径是JMeter安装路径下的backups目录。不过这些都可以修改。也算是虚惊一场了。 结语 本博文没有对JMeter中的各个组件及其概念做过多介绍我认为这些基础的东西看看官方文档自己多配置几个脚本就基本知道这些组件到底是干嘛的了官方文档已经是最精华的教学文档了我就不必在这里再次赘述了。 希望想要学习JMeter的同学多读官方文档遇到概念不清楚、配置不清楚的问题按图索骥即可。刚上手的同学建议多读FAQ以及Best Practices部分。 下一篇将介绍如何搭配Jenkins Job来实现半自动化压力测试以及使用Grafana可视化压测结果以及使用其他工具来分析压测过程中是否存在性能瓶颈。
http://www.zqtcl.cn/news/197495/

相关文章:

  • 织梦网站地图样式中国品牌网站
  • 上海金山区建设局网站临淄信息港发布信息
  • 保定外贸网站建设学生网站建设首页
  • 商城网站备案要求wordpress插件 手机版
  • 北京市网站备案查询石家庄建设信息网必须交费吗
  • 北京优化网站方法四川省建设局网站
  • 怎么做网站能快速赚钱重庆快速建站
  • 河南专业网站建设公司首选培训心得简短200字
  • 销售网站开发业务高端建网站多少钱
  • 几个做ppt的网站知乎青岛高品质网站制作
  • 网站seo插件wordpress模板中文版
  • 夹江移动网站建设手机网站微信登陆
  • 浏阳做网站网易企业邮箱注册官网
  • 东莞网站建设是什么意思自己怎么做企业网站建设
  • 免费的网站申请泰州网站整站优化
  • 毕业设计做企业门户网站过期域名网站
  • 网站建设和风险分析简单网页制作代码模板
  • 照片展示网站那个网站可以做攻略
  • 优秀网站设计赏析万网网站备案多久
  • 网站维护服务有哪些电商网站
  • 部门网站建设总结鼎城网站建设
  • 制作网站的模板下载大型商城购物平台开发
  • wordpress 分类文章置顶整站优化推广品牌
  • 网站手机验证码如何做官方网站在家做兼职
  • 东莞三合一网站制作网站建设 千助
  • 114网站做推广怎么样江苏建设培训网站
  • 如何让网站做网页适配网站上的产品五星怎样做优化
  • 怎么做网站排名优化免费jq网站模板
  • 源码时代培训机构官网自己建网站怎么做seo
  • 宜都网站制作济南比较大的网站制作公司