软件测试流程分享

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

软件测试流程分享目录整体流程各阶段质量评审方式和标准Bug分布CodeReview单元测试测试用例设计•功能测试•性能测试•异常测试1.整体流程测试沟通沟通纪要测试设计测试设计文档测试执行测试报告2.各阶段质量评审方式和标准阶段评审方式通过标准启动MRD需求设计评审项目相关人员达成一致,预判能实现项目目标。编码阶段CodeReview代码走查核心模块和逻辑复杂模块走查。单元测试由程序开发人员完成函数覆盖率90%行覆盖率80%分支覆盖率60%全面测试阶段集成测试性能测试异常测试场景化测试与开发人员共同review确认达成项目设计目标。预上线阶段线上监控设计灾备、预案小流量上线确认稳定性。上线线上回归测试逻辑BUG代码做了错误的事情,例如条件语句写错,变量未赋值等衔接BUG对象之间衔接时候出现错误,例如接口之间传递参数出错等渲染BUG能够用眼睛看出来的错误,出现在UI例如页面布局与MRD不一致典型的BUG分布情况逻辑BUG衔接BUG渲染BUG逻辑衔接渲染出现概率高中低发现难度难一般容易修复代价高中低最理想的测试方法单元测试接口测试系统测试3.Bug分布DAODataServicePageServiceAction模板UTST,针对渲染和衔接BUGIT,针对衔接BUGhttp请求http应答UT针对逻辑BUGUTUTUT3.Bug分布并非所有的类都要做UT4.CodeReview何时进行开发人员每次提交代码前,都应通过本地单测并将代码提交team间及测试人员Review,Reveiw通过后才能入库。优点•保持项目整体代码风格一致•团队间互相熟悉代码•提前发现错误CodeReview要点•遵守代码规范,保持项目整体代码风格一致•逻辑错误•异常条件考虑不足5.单元测试单元测试开发原则•短:一般在10行以内•平:基本上都是顺序执行,没有分支语句,没有循环语句•快:一个用例执行时间在毫秒级别•一致性:测试用例多次执行,结果一致•原子性:测试用例的执行结果,要么是PASS,要么是FAIL•独立性:测试用例之间独立,即测试用例的执行顺序不影响结果单元测试架构工具•c++单测框架:Gtest•c++覆盖率分析:Lcov•python单测框架:unittest,nose•java单测框架:Junit•java覆盖率分析:cobertura6.测试用例设计输入•细化的测试需求•测试的方法•相关的资源输出•完成测试需求的数据设计•完成测试步骤•完成测试预期•可选:标识别用例的优先级•可选:和测试需求绑定•用例间的执行顺序测试分类:功能测试性能测试异常测试6.1功能测试对产品的各功能进行验证,检查产品是否达到用户要求的功能。构造输入(正常/异常)测试数据(正常数据)配置文件(正常配置)测试环境(正常环境)测试步骤针对系统功能进行验证检查输出数据:正确性、新旧diff功能:正确性针对namespace、database的增删改查功能的系统测试。测试输入•测试数据:系统对外部数据没有强依赖,测试使用数据可以进行构造•测试环境:单点server、后台数据库•系统配置:使用线上配置测试步骤针对namespace、database的增删改查,及交叉功能应用常用测试设计方法进行测试设计。测试输出检查增删改查的功能是否实现,数据是否正确。6.1功能测试–举例6.2性能测试-基本概念极限性能稳定性能预期负载性能性能压力常态负载极限负载压力评估通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。基本概念稳定性压力负载CPUIO内存带宽成功率超时率响应时间并发用户数资源指标产品指标资源指标与硬件消耗直接相关。本质反映的是成本问题。产品指标与场景需求直接相关。本质反映的是效果问题。6.2性能测试–关键指标14step1分析对象设计原理•确认资源消耗类型•确认具体关注指标性能测试场景设计•架构部署方案设计•性能预期设计(稳定、极限)•压力方案设计step2step3step4step5环境、数据与工具选择•环境(超时、线程、日志、硬件资源等)•数据(大小、读写方式、cache机制)•工具选择(线程池、连接方式、通信方式、压力增加方式)执行方案•执行轮次优化(对比方案)结果指标分析•指标组合判断•性能指标评估•瓶颈判断•优化方案设计6.2性能测试–测试方案设计6.2性能测试–举例消息发送平台接口测试测试目的:测试线上单台机器消息发送接口的发送能力(系统入口接受外部请求的能力)期望值:系统入口:2000QPS,单机500QPS(线上共四台机器);CUP_IDLE:30以上。性能测试过程:(1)搭建性能测试环境,准备线上测试机器并构造压测数据(2)起压线程,从10~300,依次增加,遇到瓶颈后,寻找临界届值的点(3)发送请求数:随着线程的增加,请求数略有增加,保证压测时间不低于200s6.2性能测试–举例性能测试结果分析:线程数总请求数压测时间s入口平均QPS接口平均响应时间Min响应时间Max响应时间ErrCPU_IDLE平均值CPU_IDLE最低值(min)备注11010w427234.142354740.00%98.3959125010w92.41082.144356760.00%98.0094压力时间太短,后续增加请求数。3100100w9571044.9943521060.00%98.12595QPS负增长。压测时间过长,减少数据量。410050w4231181.3833511580.00%98.54895可以继续开大线程数尝试。520050w1702934.9653512110.00%94.83387QPS增长明显。但压测时间偏短630090w2883127.4903530010.34%(3056)36.96629Cpu_idle降至28接口部分请求丢失。CPU_IDLE也低至30左右。考虑需要调低线程数,减少发送频率。725075w2443072.4763513750.00%(7)31.96029发送75w个请求,丢失7个。错误率接近0。接近临界点。构造系统的异常场景,检查系统的稳定性、正确性构造输入测试数据(异常数据)配置文件(异常配置)测试环境(异常环境:CPU、内存、磁盘、网络、依赖系统异常)测试步骤构造各种异常场景检查输出数据:是否正常,是否与正常场景存在diff性能:性能是否有波动日志:查看系统内部是否走进异常分支,异常处理是否正确功能:是否与预期一致6.3异常测试6.3异常测试–举例Id1标题请求字段异常步骤构造请求字段缺失、为空的情况,查看接口返回。参数{“flightno”:”5J110”,”token”:”12345”}预期接口会有相应的错误提示执行结果通过1.当flightno取值为空或flightno参数缺省时,返回错误码-1,提示参数错误{status:-1,msg:paramserror}2.当token异常时,返回错误码-1,提示token校验失败{“status”:-1,“msg”:“tokenchecksumfailed”}某接口异常测试结果分析:Q&A?

1 / 19
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功