开发者学习笔记【阿里云DevOps助理工程师认证(ACA)课程:软件测试与质量保证基础】
课程地址:https://edu.aliyun.com/course/3112069/lesson/18995
软件测试与质量保证基础
内容介绍:
一、软件测试定义和分类
二、软件测试活动与设计方法
三、探索式软件测试
四、分层自动化
一、软件测试定义和分类
软件测试的定义
软件测试是使用人工或自动的手段来运行或测定某个软件系统的过程,其目的在于检验它是否满足规定的需求或弄清预期结果与实际结果之间的差别。
软件测试类型
软件测试可以按照测试目的、阶段和方法分成不同的测试类型。
按照测试目的,软件测试可以分为功能测试和系统测试。系统测试是指验证软件在性能、容量、稳定性、可靠性、易用性、兼容性、安全性等方面的非功能需求。
按测试目的,软件测试还可以分为冒烟测试和回归测试。冒烟测试是指在开始正式测试之前对软件进行简单的验证,其目的在于确认软件基本功能正常,可以进行后续的正式测试工作。
回归测试是指在修改软件代码后重新运行测试,以确认修改没有引入新的错误或导致其他代码产生错误。
按测试阶段,软件测试可以分为单元测试、模块测试、集成测试、系统测试和验收测试。
按测试方法,软件测试可以分为静态测试和动态测试。
静态测试方法是指无需运行被测代码而进行的测试活动,包括评审软件文档或程序度量程序静态复杂度、检查软件是否符合编程标准等。动态测试方法是指通过运行被测程序,检查运行结果与预期结果的差异,并分析运行效率、正确性和健壮性等内容。
按测试方法,软件测试还可以分为白盒测试和黑盒测试。
二、软件测试活动与设计方法
软件测试活动与设计方法。无论是瀑布开发模式还是敏捷开发模式,软件测试都包括下面四个测试活动,测试规划、测试设计、测试执行和测试报告。测试规划活动的输入是需求,也就是需求确定以后就可以开始测试规划活动。测试规划活动要确定测试范围、时间、人员以及测试内容的优先级,同时还要按照项目需要设计测试阶段以及每个阶段需要使用的测试方法和环境。最后还要评估项目的测试风险,并提出应对风险的行动方案。 测试用例设计的目的,使用尽可能少的测试用例,覆盖尽可能多的需求。测试执行包括准备测试执行需要的环境和数据,创建和执行测试执行计划。通常执行计划指一主测试用例,更新测试执行结果报告所发现的缺陷,验证已修复的缺陷。在验证与修复的缺陷时,要同时执行一定的回归测试,以保证该缺陷修复没有引入新的问题,没有影响之前正常的功能或者软件的性能等。其他非功能属性。测试执行的过程中以及执行完毕后均可以查看测试报告,以了解软件测试的进度以及通过缺陷报告和趋势了解软件的质量情况。
下面我们介绍两种软件测试的设计方法,等价类和边界池。
第一种方法,等价类。等价类是指某个输入域的子集合,在该子集合中,各个输入数据对于接入程序中的错误都是等效的,或者进行相同的处理,测试某个等价类的一组数据就等于对这一类数据的测试。等价类可以划分为有效等价类和无效等价类。无效等价类是指应该被系统拒绝的数据。等价类方法的难点在于划分和确认等价类。等价类的划分要符合 MECE messy 原则,也就是划分出的等价类要相互独立,完全穷尽,等价类的确认就是要确保划分出来的子集合中的所有输入数据都是等项的。这常常需要测试人员了解软件的内部实现,才能准确判断程序是否对子集合里面的每个输入都进行了相同的处理。
第二种方法,边界值
人们从长期的测试工作经验得知,大量的错误是发生在输入或输出范围的边界上,而不是在输入范围的内部。因此,针对各种边界情况设计测试用例可以查出更多的错误。边界值也可以分为有效边界值和无效边界值。
三、探索式软件测试
探索式软件测试是一种测试风格,它强调个体测试人员的个人自由和责任,通过把测试相关的学习、设计、执行和结果解释当做项目中并行执行且相互支持的活动来不断优化工作价值。在探索式软件测试之中,仍然需要进行测试规划、测试设计、测试执行和测试报告四个活动,但这四个活动将不再是依次顺序执行一遍,而是不断迭代,以达到不断优化测试的目的。
探索式软件测试有以下三个价值:
第一是它可以帮助我们更好地学习和理解对测软件。
第二是它能强迫软件展现所有的功能。
第三它能帮助我们更快速地发现重要的缺陷。
四、分层自动化
为了降低自动化的成本,提高自动化的覆盖率和稳定性,我们建议在实施自动化的时候进行分层处理。根据软件的架构,我们可以将软件分层。底层服务包括数据访问对象、远程接口和底层服务。业务层包括服务和业务对象,以及交互页面层。对底层服务,我们进行单元测试。对业务层进行接口自动化测试。对用户交互页面层进行 UI 自动化测试。
针对服务层的单元测试,由于执行速度快,自动化维护成本低,并优先考虑自动化,并且尽量保证完全最大可能的自动化覆盖,建议由开发人员来实施。针对业务层的接口测试,由于执行速度快,维护成本一般,我们建议在单元测试之后进行最大可能的覆盖可以由开发人员或者测试人员完成针对页面层的用户交互测试。由于执行速度一般,自动化维护成本较至其他两层最高,应最后考虑自动化,且建议只进行主干和核心分支的自动化覆盖,建议由测试人员来完成。
服务层 |
业务层 |
页面层 |
|
内容 |
DAO/远程接口/底层服务 |
Service/Bo |
前端渲染的业务逻辑和展示逻辑 |
执行速度 |
快 |
快 |
一般 |
维护成本 |
低 |
一般 |
较高 |
测试方法 |
自动化 |
自动化 |
自动+手工 |
完成优先级 |
1 |
2 |
3 |
建议覆盖范围 |
全部 |
全部 |
主干/核心分支 |
建议实施者 |
Dev |
Dev / QA |
QA |
在本小节的课程中,我们学习了软件测试的定义与分类。软件的测试活动有两种设计方法,我们还学习探索式软件测试和分层自动化的理论。