您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 招聘面试 > 软件测试第7章-系统非功能性测试-2017
软件测试第2版第7章系统非功能性测试第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.8安全性测试7.9容错性测试7.10可靠性测试系统性能问题系统太慢了,我泡了一杯茶回到座位,还没有看到响应软件系统安全性受到挑战1983战争游戏(电影)MatthewBroderick)是一个疯狂的电脑游戏迷,一次他不经意地闯入了五角大楼的一个绝对机密的电脑系统中……更多例子各种系统非功能性测试什么是系统非功能性测试?用户的需求可以分为功能性需求和非功能性需求,而非功能性的需求被归纳为软件产品的各种质量特性,如安全性、兼容性和可靠性等系统非功能性测试就是针对这些非功能特性展开的,就是验证软件产品符合这些质量特性的要求,从而满足用户和软件企业自身的非功能性需求。所以,系统测试分为负载测试、性能系统、容量测试、安全性测试、兼容性测试和可靠性测试等系统非功能特性系统非功能性测试的内容详见表8-1第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.8安全性测试7.9容错性测试7.10可靠性测试7.2概念:负载测试、压力测试和性能测试7.2.1背景及其分析7.2.2定义背景及其分析系统性能的改善是测试、调整、再测试、再调整、……一个持续改进的过程——性能调优性能调优需要借助负载测试方法的帮助负载测试和性能测试有较多相似之处,例如,测试方法比较接近、都关注系统的性能,而且多数情况下使用相同的测试工具负载测试可以看作是性能测试所采用的一种技术压力测试可以被看作是负载测试的一种,即高负载下的负载测试容量测试也采用负载测试技术来实现定义负载测试是通过模拟实际软件系统所承受的负载条件、改变系统负载大小和负载方式来发现系统中所存在的问题压力测试是在强负载情况下(如大数据量、大量并发用户连接等)稳定性进行测试,查看应用系统在峰值(瞬间使用高峰)使用情况下的行为表现,更有效地发现系统稳定性的隐患和系统在负载峰值的条件下功能隐患等,确认系统是否具有良好的容错能力和可恢复能力。性能测试是为了获取或验证系统性能指标、或为了发现性能瓶颈而进行的测试辨析第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.8安全性测试7.9容错性测试7.10可靠性测试7.3负载测试技术7.3.1负载测试过程7.3.2输入参数7.3.3输出参数7.3.4场景设置7.3.5负载测试的执行7.3.6负载测试的结果分析负载测试过程确定所要模拟的角色及其对应的关键业务操作路径确定输入/输出参数,制定负载测试方案准备测试环境,并完成相应的测试脚本的开发设计具体的测试场景,如负载水平、加载方式等执行测试,监控输出参数,如数据吞吐量、响应时间、资源占有率等对测试结果进行分析结果不满意,需要调整测试场景,进入下一个循环负载测试的构成输入参数并发用户数、并发连接数等。思考时间(thinktime),用户发出请求之间的间隔时间加载的循环次数或持续时间每次请求发送的数据量。加载的方式或模式,如均匀加载、峰值交替加载等负载测试是通过模拟用户的操作方式来考察系统的行为,所以人们肯定会问:如何模拟用户的行为?参数实例负载RPS(RequestPerSecond)并发连接数(SimultaneousBrowserConnections)最大数据容量思考时间(ThinkingTime)RPS+SBC+ThinkingTime=Concurrentusers加载模式负载模式举例动态模式全天模式队列模式验证模式负载模式递增恒值动态整天队列DemoJMeter输出参数数据传输的吞吐量(Transactions)数据处理效率(Transactionspersecond)数据请求的响应时间(Responsetime)内存和CPU使用率连接时间(ConnectTime)、发送时间(SentTime)处理时间(ProcessTime)、页面下载时间第一次缓冲时间每秒(SSL)连接数每秒事务总数、每秒下载页面数每秒点击次数、每秒HTTP响应数每秒重试次数举例图8-7JMeter性能测试结果示意图场景设置启动(Rampup)持续期间(Duration)结束(Rampdown)在性能测试执行前,以什么样方式启动负载方式、如何持续进行负载测试直至负载测试结束,这个过程的负载大小和方式、负载启动和结束以及各种检查点、验证点等设计,被称为场景设置。场景类型可以分为静态和动态两部分。静态部分是指设置模拟用户生成器、用户数量、用户组等,动态部分主要指添加性能计数器、检查点、阀值等,从而获得负载测试过程中反回来馈的数据——系统运行的动态状态。可以依据业务模式变化、随时间段变化来进行设置也可分为手工场景和面向目标的场景举例依据业务模式变化来设计负载模式(来源MSDN)同步点同步点(或称集合点)用于同步虚拟用户恰好在某一时刻执行任务,确保众多的虚拟并发用户更准确、集中地进行某个设定的操作,达到更理想的负载模拟效果负载测试执行大量的虚拟用户要运行在多个客户端,并由控制器管理、代理(agent)驱动负载测试的执行,需要针对不同维度的变化进行,包括时间维、负载维和系统维监控、详细的记录和适当的分析是十分重要的时间维:尝试观察系统在一段较长时间上的行为变化负载维:尝试在系统上改变负载来进行对比分析系统维:负载测试也可以针系统的不同组件、不同配置等进行结果分析要善于捕捉被监控的数据曲线发生突变的地方——拐点第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.8安全性测试7.9容错性测试7.10可靠性测试7.4性能测试7.4.1如何确定性能需求7.4.2性能测试类型7.4.3性能测试的步骤7.4.4一些常见的性能问题7.4.5容量测试示例确定性能需求最终用户的体验,如2-5-10原则商业需求,如“比竞争对手的产品好”技术需求,如CPU使用率不超过70%标准要求只有具备了清楚而量化的性能指标,性能测试才能开始实施响应时间是用户的关注点,容量和数据吞吐量是(产品市场团队)业务处理方面的关注点,而系统资源占用率是开发团队的技术关注点性能测试类型性能验证测试,验证事先已定义的系统性能指标、系统能否满足系统的性能需求性能基准测试,在系统标准配置下获得有关的性能指标数据,作为将来性能改进的基准线性能规划测试,在多种特定的环境下,获得不同配置的系统的性能指标,从而决定在系统部署时采用什么样的软、硬件配置容量测试可以看作性能的测试一种,因为系统的容量可以看作是系统性能指标之一性能测试的步骤确定性能测试需求;计划和设计测试;包括确定关键业务流程、测试类型和测试方法、选择合适的测试工具、设计测试场景等测试工具的选择;配置测试环境,尽量接近实际运行环境,即建立仿真环境作为性能测试环境,测试结果才能可信;实现测试设计(开发测试脚本);执行测试;分析测试结果;重复上述(4)~(6)步骤,直至测试计划完成,结果满意;提交性能测试报告。示例加载结果分析一些常见的性能问题资源泄漏,包括内存泄漏资源瓶颈,内部资源(线程、放入池的对象)变得稀缺CPU使用率达到100%、系统被锁定等线程死锁、线程阻塞等数据库连接成为性能瓶颈查询速度慢或列表效率低受外部系统影响越来越大容量测试容量测试(Capacitytest),通过负载测试或其它测试方法,预先分析出反映软件系统应用特征的某项指标的极限值(如最大并发用户数、数据库记录数等),在其极限值状态下系统主要功能还能保持正常运行容量测试属于性能测试中的一种,一般采用逐步加载的负载测试方法,也可以先采用逐步加载方式,获得一个基本的容量值或容量范围,然后再考虑用一次性加载方式,来决定实际可支持的容量值。第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.8安全性测试7.9容错性测试7.10可靠性测试压力测试压力测试是在系统(如CPU、内存和网络带宽等)处于饱和状态下,测试系统是否还具有正常的会话能力、数据处理能力或是否会出现错误,以检查软件系统对异常情况的抵抗能力,找出性能瓶颈、功能不稳定性等问题。压力测试的类型稳定性压力测试,高负载下持续运行24小时以上的压力测试破坏性压力测试,通过不断加载的手段,快速造成系统的崩溃,让问题尽快地暴露出来渗入测试(soaktest),通过长时间运行,使问题逐渐渗透出来,从而发现内存泄漏、垃圾收集(GC)或系统的其他问题,以检验系统的健壮性峰谷测试(peak-resttest),采用高低突变加载方式进行,先加载到高水平的负载,然后急剧降低负载,稍微平息一段时间,再加载到高水平的负载,重复这样过程,容易发现问题的蛛丝马迹,最终找到问题的根源。第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.8安全性测试7.9容错性测试7.10可靠性测试7.6性能测试工具7.6.1特性及其使用7.6.2开源工具7.6.3商业工具特性及其使用能模拟实际用户的操作行为,记录和回放多用户测试中的事务处理过程,自动生成相应的测试脚本能针对脚本进行修改,增加逻辑控制、完成参数化和数据关联可以设置不同的应用环境和场景,通过虚拟用户执行相应的测试脚本通过系统监控工具获得系统性能的相关指标的值JMeter-1JMeter-2JMeter-3开源工具nGrinder()是一个基于Grinder开发的、易于管理和使用的、分布式性能测试系统。Flood()是人们经常使用的一个Web性能测试工具Siege()是一个开源的Web压力测试和评测工具。OpenSTA,可以模拟大量的虚拟用户来完成性能测试,并通过scrīpt来完成丰富的自定义设置。详见。DBMonster是一个生成随机数据、用来测试SQL数据库的压力测试工具,详见。LoadSim——网络应用程序的负载模拟器。更多的性能测试工具,可访问商业工具HPLoadRunnerIBMRationalPerformanceTesterRadviewWebLoadCompuwareQALoadQuestBenchmarkFactory微软WAS(WebAccessStresstest)PaesslerWebserverStressToolMINQPureLoadHPLoadRunnerLoadRunner系统架构第7章内容7.1非功能性的系统测试需求7.2概念:负载测试、压力测试和性能测试7.3负载测试技术7.4性能测试7.5压力测试7.6性能测试工具7.7兼容性测试7.
本文标题:软件测试第7章-系统非功能性测试-2017
链接地址:https://www.777doc.com/doc-4214126 .html