软件测试理论基础总结

Posted turbogirllu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软件测试理论基础总结相关的知识,希望对你有一定的参考价值。

1.软件开发的生命周期?

  软件生命周期是指从软件产品的设想开始到软件不再使用而结束的时间;

2.软件生命周期的模型?

  ①瀑布模型

  特点:从上一项活动接受本项活动的工作对象,作为输入;利用这一输入实施本项活动应完成的内容;给出本项活动的工作成果,作为输出传给 下一项活动;

    技术图片

  瀑布模型的优缺点:

    技术图片

  ②螺旋模型

  特点:瀑布模型(系统化)+快速原型(迭代过程)+风险分析;

  一个螺旋式周期:

    确定目标,选择方案,选定完成目标的策略;

    风险角度分析该策略;

    启动一个开发阶段;

    评价前一步的结果,计划下一轮的工作;

    技术图片

  螺旋模型的优缺点:

    优点: 

    强调严格的全过程风险管理。

    强调各开发阶段的质量。 

    提供机会检讨项目是否有价值继续下去。

    缺点:

    引入非常严格的风险识别、风险分析和风险控 制,这对风险管理的技能水平提出了很高的要求。这需要人员、资金和时间的投入。

  ③V模型

  特点:

    V模型体现的主要思想是开发和测试同等重要,左侧代表的是开发活动,而右侧代表的是测试活动;

    V模型针对每个开发阶段,都有一个测试级别与之想对应;

    测试依旧是开发生命周期中的阶段,与瀑布模型不同的是,有多个测试级别与开发阶段对应;

    V模型适用于需求明确和需求变更不频繁的情形;

    技术图片

  V模型的优缺点:

    优点:

    包含了底层测试(单元测试)和高层测试(系统测试);

    清楚的标识了开发和测试的各个阶段;

    自上而下逐步求精,每个阶段分工明确,便于整体项目的把控;

    缺点:

    自上而下的顺序导致了,测试工作在编码之后,就导致错误不能及时的进行修改;

    实际工作中,需求经常变化,导致v模型步骤,反复执行,返工量很大,灵活度较低;

  ④W模型

  特点:测试的对象不仅是程序,需求、设计等同样要测试,测试与开发是同步进行的

  理解:第一个v是开发线,第二个v是测试线,开发与测试并行;

    第一个v:左边开发线没变,把编码作为黄金分割线;

    第二个v:右边测试线没变,把单元测试作为黄金分割线;

    用户需求(了解用户需求,为验收测试做准备);

    需求分析与设计(编写测试计划,对系统测试做准备);

    概要设计阶段(进一步细化测试计划,并为集成测试做准备);

    详细设计(搭建测试用例框架,并为单元测试做准备);

    编码阶段(测试用例编写,开发人员和白盒工程师进行单元测试)【单独进行编写】;

    集成阶段(开发人员和白盒人员进行集成测试)【集成阶段是从编码阶段的测试用例里提取出来的】;

    系统测试对应的是实施(环境搭建,数据准备,测试执行,缺陷管理,编写测试报告);

    交付 验收(协筑用户进行验收);

    技术图片

  W模型的优缺点:

    优点:

    有利于尽早地全面的发现问题;

    缺点:

    不能适用于需求变更频繁的项目;

    对有些项目,开发过程中没有文档的产生,所以W模型没法使用;

    对于需求和设计的测试技术要求高,实践起来很困难;

3. 软件测试的生命周期?

   测试计划 → 测试设计 、测试开发 → 测试执行→ 测试评估

4.软件测试针对软件开发生命周期的流程?

   需求阶段

      测试人员了解需求、对需求进行分解,得出测试需求,编写测试计划/测试方案;

   设计阶段

      测试人员适当的了解设计,对于设计测试用例是很有帮助的,测试人员可以根据需求和设计编写一部分测试用例;

   编码阶段

      测试人员一般是不需要编码的,但已经编码的模块,专业的白盒测试人员可以计划执行单元测试;

   测试阶段

      测试阶段是软件测试人员最为重要的工作阶段,这时候测试人员需要把测试用例进一步细化,根据测试用例和计划执行测试,在执行的过程中记录缺陷,测试完成后整理测试报告;

   实施

      测试人员需要参与项目的实施工作。测试人员对项目产品的业务和操作非常了解,加上测试人员的沟通表达能力一般都比较强,所以测试人员可以参与用户使用软件的培训,在试运行项目时收集问题并及时反馈给相关负责人;

5.软件测试活动?

   测试计划 → 测试设计 、测试开发 → 测试执行→ 测试评估

6.一个项目的整个测试流程?

  ①需求提取

    整体流程图:需求提取-->需求分析-->需求评审-->更新后的测试需求跟踪

    分析流程:

      需求提取:

        分析依据(包括:需求矩阵、产品交互图、需求说明书);

        获取需求的纬度;

          客户价值

            可以为客户带来哪些价值?

            可以解决哪些问题?

            根据以上问题定位功能是否合理?

          UI功能--展示功能

          模块关联--历史模块

            新功能模块关联

            考虑是否关联?耦合部分是否需要支持?

          客户使用场景--部署方式

            网络特性

            客户使用服务器常见外设

          性能参数--性能要求

            网卡最低速率

          硬件支持

        输出(提取最原始的测试需求);

  需求分析

    分析依据(五维分析):

      用户场景;

        功能是否和场景强关联

        网络拓扑是否满足客户需求

        和竞争对手比较差异

        功能是否能满足客户实际应用场景

        是否考虑了用户的实际操作

      明确性;

        范围明确性(参数、类型长度范围)

        清晰性限制等范畴

        无法预知影响 需求提出进行确定,风险

      二义性;

        概念模糊(大概念、第三方支持、与上个版本相同)

        支持与不支持等范畴

        一个需求描述能出现多种理解

      完整性;

        需求一致性【用户需求、需求规格、需求矩阵三者是否同意】

        需求完整【隐形需求】

        关联性【与新老功能、与外置软件设备】

      可测试性;

        实现测试需要的工具、方法【调试、接口命令】

        定位方法【日志等形式观察】

        复杂环境、容量边界、操作时过程不可见

    输出

      测试需求跟踪

      缺陷预防bug

      工具需求

      整理出明细需求点

      测试地图

    分析思路误区:需求和实现的区别【现有需求才有代码实现,不能把代码实现当做需求】

    需求分析的意义

      明确产品给客户带来的意义

      明确产品支持和不支持的功能

      明确产品各个功能的约束力

      知道开发实现功能

      知道测试分析和产出测试点

  ②测试设计

    测试分析:

      我们需要做什么?

        把明确的需求点转换成测试项

        缺陷预防

      我们需要做什么?

        整体模块分析

        逻辑分析【这一点主要是从产品实现的原理上分析可能的影响】

           怎么做?

             开发的设计文档

               补充和挖掘测试点

                 全部服务的异常监控、服务重启

                 各类存储对空间的占满、是否需要做存储的接口测试

                 所有类型的管理员、操作权限测试、支持的管理员并发测试

                 对流程图的挖掘--流程图全部流程测试、流程图重要的节点异常测试

                 对状态的挖掘--所有状态的相互转化需要覆盖全,状态转化是否合理,每一个状态下哪些操作可做哪些不可做,多个状态是否可以共存

                 对关联项的挖掘--流程进展到那一步关机重启/服务重启、和备份配置的关联、和操作日志的关联等等

                 任务的并发操作测试、是否可配置、是否会出现性能不足、是否符合用户场景

                 异常处理机制测试、异常处理机制是否完善

                 修正不合理的需求

           如何分析

             逻辑原理:

               该模块是否涉及到一些全新的概念(比如我们的 bbc 全量包),需要明确?

               该模块包括哪些服务?

               该模块涉及到哪些存储技术(如 mysql、dap、redis)?具体怎么存储的?占用大小如何?

               该模块的操作流程有哪些?是否有子流程图?

               该模块是否有多个状态的转化?是否有明确的状态转化图?

               该模块对多个管理员是否区分,管理员权限如何设计?

               该模块是否有一些特殊的操作限制?操作限制是否有明确的表格?

               该模块的任务是否有并发需求?并发的设计?

               该模块的所有指标如何?

               该模块是否有异常处理机制?在设备各种异常时,该模块的设计是否满足能稳健运行?

             场景分析

               从用户的使用习惯和使用方法去分析影响

               检查当前案例是否覆盖到用户场景

             关联测试分析:

               考虑你的模块所在整个系统的地位,分析上下游的影响

               对老功能的影响

             经验补充分析

               版本分析

               模块分析

             输出

               测试项

               补充测试地图

    测试设计

      需要做什么?

        把测试项细化成测试点

        缺陷预防

      需要做什么?

        基本设计方法

         等价类划分法【将输入域和输出域划分为不同的等价类,等价类之内的操作结果相同】,使用范围:显示输入框输入

         边界值法【需要结合等价类划分法方法,在划分出来的等价类选取有代表性的值】

         正反对比【一般会放到同一个用例里覆盖】

         字符多样性【考虑不同字符的输入】

         测试类型

        产品专项测试

        正交组合设计【正交矩阵,覆盖各个参数间的组合情况】

        业务逻辑设计【根据业务设计测试点】

      输出:

        基本测试点

    用例设计:

      需要做什么?

        把测试点用文字完整表述出来

      怎么做?

        功能用例框架:

           模块框架模板

             需求类

               UI测试【如果UI用例可以被功能用例覆盖,这里可以不写】

                 公共测试类:

                   链接

                     选中会有高亮显示

                     点击跳转到对应页面

                     当前页面对应的名称下有区别显示

                   翻页

                   按钮

                   输入框【这个功能用例一般可以覆盖】

                   下拉框

                   排序

                   条目选择【这个很重要,第一次集成测试一定要保证每个选项都是有效的】

                   搜索

                     所有字符类型验证

                     为空验证

                     模糊搜索

                     精确搜索

                     搜索不存在的关键词

                   刷新

                     验证自动刷新

                     验证手动刷新

                     验证持续刷新

                   拖动

                   移动

                     点击下移,往下移动一行

                     点击上移,往上移动一行

                     最上面的行,上移不能点击,图标灰色

                     最下面的行,下移不能点击,图标灰色

               功能测试

                 测试点:

                   功能基本流程逻辑覆盖

                   业务流程多样性覆盖

                   用户操作习惯的多样性

                   模块配置的多样性

                   数据流的多样性覆盖

                 测试目录

                   平级分类相对独立

                   上下级分类有关联

                   下级从上级细化而来

             关联类:

               模块与模块之间的

               模块与功能之间

               模块与硬件之间

             场景类

               建模思路

                 部署方式【比如用户一般使用2主机还是3主机部署集群】

                 数据流

                 业务流【用户是怎么使用申请工单,是怎么样的完整流程】

                 操作顺序【创建云主机的顺序之类的】

                 配置方法【用户一般怎么配置使用静态路由】

                 使用时间【用户会不会连续长时间开启云主机】

                 用户角色【一般那些角色做什么操作】

                 用户操作的设计方向

                 最常用的功能

                 最容易出现网上问题的功能

                 典型客户使用的功能

                 版本的性能验证

             专项类

               兼容性

               可靠性【测试产品在异常情况下能否正常工作或者是恢复正常工作,可靠性重点测试对模块自身处理的覆盖】. 补充:容错性测试【测试系统在非正常操作、非正常的外部环境下是否能够处理错误和正常运行】

                 eg:

                   针对数据库的测试:【磁盘空间不足、数据库文件损坏、无读写数据权限、写数据时断电、写数据时强制关闭mysql、读写速度】

                   针对网络设备:【网络中有攻击数据、丢包时延大、IP冲突、网络线路断开、同时掉电】

                   针对程序:【 客户端进程被手动停止、设备后台资源cpu、内存占满】

                   安全性【主要是验证程序有哪些缺陷可能会造成安全方面的问题】

                 eg:

                   密码加密方式【什么时候用明文,什么时候用密码显示】

                   隐私数据隐藏【用户的隐私显示】

                   设备的完整目录【完整的目录会增加后台被攻击的危险】

                   文件上传功能【检查上传的文件类型;限制上传文件的权限】

                   防暴力破解【对于连线认证之类的操作要冻结、禁用其连续错误尝试操作】

               脚本测试

           使用注意细节

             文件夹以01-xx,02-xx区分开

             每个文件夹下不能超过10个用例

             每个测试用例一个测试点

             在02-功能测试的描述中,备注说明功能测试框架的思路

        用例整体规范

           用例标题【好的标题需要准确的表达你的测试目的、要测试的测试点】

             eg:

               测试。。。

               验证。。。

               。。。的测试

               与。。。的关联测试

               。。。的异常测试

               。。。的兼容性测试

           用例属性

             测试环境【默认的前置条件可以不用写;写的前置条件要准确,不要写的模糊】

             测试方法

             优先级

               BVT【最最最基本的功能】-BVT(10%):模块最基本的功能验证(含常用部署、基本关联),推荐1级用例的20%左右

               level1【基本操作、基本场景】-Leve1(30%):基本需求点,基本逻辑,基本可靠性,基本关联,基本用户场景

               level2【比较少见的正常操作】-Leve2(40%):常见功能/逻辑细化点/专项细化点,常见关联/容错/边界值/用户场景

               level3【异常操作;后续不需要再执行】-Leve3(20%):错误提示、极少测试的用例、非常见部署方式/用户场景/容错/边界值等

           用例格式

             前置条件

             测试步骤【单个用例全部步骤不能超过8步】

             后置条件【不是必填的】

             预期结果

             备注【不是必填的】

           语言规范

             语言简练

             不能出现模糊的形容词【比如说大概、可能、很多、差不多】

           可维护性

             灵活运用模块备注

           设计原则

             目的明确【一个用例对应一个测试点;测试步骤和测试目的一致】

             用例效率

               保证设计出来的用例10分钟内可以执行完成;

               用例需要的环境可以整理出来,然后写到模块备注中,让执行者先准备好环境一次性执行全部用例;

               执行的时候按照测试集方式来执行;

               有工具可以实现的用例不要采用脚本方式实现

             测试步骤:

               用户角度

                 设计的用例要符合用户的操作顺序和操作习惯

                 符合用户的使用环境

                 符合用户的配置

               可执行

                 不要出现那种用例设计没有错,但是执行起来很复杂或者是依赖环境很夸张的用例

               正反对比

                 这一点很重要,很多时候我们会把有正反操作的用例分开写,其实是可以合在一个用例里面写

               强弱关联

                 对于强关联的步骤一定要写清楚

                 对于弱关联的可以备注或者是不写

               测试用例不能出现操作步骤

                 直接写需要做的操作就可以了

             预期结果

               用户角度:

                 反思用户期望操作完会有什么结果

                 反思客户最关注的测试点

               可检查

                 预期结果要可以观察到,不要写的很模糊

                 把重点检查的检查点覆盖到

           用例编写口诀

             强弱正反之业务

             重点突出之效率

             目的明确之语言

             框架覆盖之检查

             逻辑场景之经验

  ③用例执行和回归

    用例执行标准

      执行优先级

        建议用例级别执行顺序【bvt、leve1、leve2、leve3】

        建议用例区域执行顺序【基本功能、高风险区域、复杂逻辑优先测试】

    用例执行状态

       Not Complete:用例无效、用例错误、无测试环境等过程状态

       Passed:执行通过

       No Run:默认状态,未执行

       N/A:无须执行,需填写备注,需处理;

       Failed:执行失败,需填写BUGID

       Blocked:被其他问题阻塞

       Not Modify:由Failed状态而来,用例发现的bug不修改,bug为halt、Won‘t Fix

    自动化用例

       覆盖全部bvt用例

       大部分level1(基本的功能一定要覆盖)

    执行技巧总结

       执行前:

          首先要看执行备注(模块备注、文件夹备注、用例备注),了解这个模块是做什么的,需要注意哪些点和执行的辅助命令和工具

          然后把一个模块下的所有用例大概过下,能一起执行的可以一起执行

       执行时:

          增改查删顺序执行用例

          一类的用例一并执行,比如说测试多种不同的nfv设备的授权之类操作,虽然每个nfv设备都是一个用例,但是都可以一起操作

          执行UI限制的用例,可以把限制条件整理出来,做成模版,直接套用

          执行的时候关注的测试点,遇到测试点很简单但是测试步骤很复杂的,可以以测试点测试为主,和用例编写的人协商优化一些执行步骤,或者是先自己优化再备注,后面统一和用例执行人讨论可不可以这样优化

          不理解的用例可以问执行过的人或者是写用例的人

          耗时或者是异常的用例【可以在别人休息吃饭的空闲时间去执行,不要影响公共测试环境】

       执行后

    bug回归标准

      bug分类:

        low【UI问题、体验问题】

        medium【基本功能问题】

        high【性能问题】

        urge【宕机、无法使用、数据丢失、业务无法使用】

    补充用例

        在执行用例或者是回归bug的时候遇到level1级别的用例没有覆盖的一定要补充用例覆盖

        用例覆盖点过多,把几个级别的用例覆盖了,需要拆分用例

    质量分析

      Bug的类型主要是哪几类?

        包括:功能问题,性能问题,稳定性,可靠性,关联,兼容性,需求方案等改进,易用体验性,异常容错; 分析出主要类别后,在进一步分析各个类别产生的根本原因,比如用例编写问题(测试步骤达不到测试目的,用例有歧义等);改动引发(是需求、方案变动带来的还是纯粹的改一个bug引发另一个?)

      模块质量分析

        缺陷分析

        用例质量分析

        测试漏侧分析

        需求变更分析

        模块改动分析

        发散测试分析

        重点难点分析

        开发人员评价

        回归测试分析

  ④bug定位

    前端定位:

      工具

        谷歌浏览器

           network

             检查参数【是否准确、是否有缺少】

             检查响应时间【查看加载时间】

             检查响应内容【查看响应内容是否有缺少{缺少的话是后端返回的问题;如果没有缺少的话有可能是前端处理的问题}】

           source【在测试用例的时候可以打开source调试,有一些页面的错误可以被俘获到】

        postman【模拟请求发送是否正常】

    后端定位:

       后台报错日志

        方法一:

           cd日志文件所在的目录 | grep -rn "关键词"

           根据行号查看异常日志内容 :tail -n +203915 文件名 | head -n 200行 (显示文件中第203915行之后的200行)

        方法二:

           less 具体的目录文件 #进入指定的目录文件

           然后 /关键词

       数据库【mysql】

    非技术方法

       对比法【比如说acmp上私有云的功能都是沿用acloud的功能,想判断acmp上的问题可以对比查看acloud上是不是有也有这个问题,如果有很可能是acloud引入的问题】

       客户导向法【对于一些新功能,我们可以根据用户场景去判断这个功能实现是属于正常的操作还是不合理的设计】

       逻辑分析【有时候开发自己设计的产品实现原理不一定是合理的,可以分析下实现步骤,看看是不是有问题】

     总结下排除思路

       判断是否是必现问题【先查看是否是必现的【到别的环境去试下问题是否能必现】;非必现的问题【排查网络问题;资源不足的问题】】

       判断是我们平台本身的问题

       判断是前端的问题还是后端的问题【抓包查看请求,请求中的返回数据是否显示完整。显示完整,那么一般就是前端没有处理好数据显示,找前端看看;如果返回数据有空缺或者是不完整,那就找后端看看】

以上是关于软件测试理论基础总结的主要内容,如果未能解决你的问题,请参考以下文章

软件测试理论基础总结

性能测试总结---基础理论篇

软件测试理论基础总结 --21个故障模型

性能测试基础理论总结(学习笔记)

性能测试总结---基础理论篇

性能测试总结---基础理论篇