QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

针对易测试性的系统设计

  • 2014-10-28
  • 本文字数:1422 字

    阅读完需:约 5 分钟

来自于西门子公司的 Peter Zimmerer 说,在系统中,易测试性必须被明确地设计。测试架构师应该推动易测试性,并和架构师、设计人员和测试人员去共同使用好的设计和工程实践。

QA&Test 2014 大会上,Peter 贡献了一个关于针对嵌入式软件系统的易测试性的设计教程。

Peter 对易测试性给出的定义是“系统可以被有效及高效测试的程度”。效率与积增的深度和测试的质量有关,在此是指有效地降低成本、工作量和测试时间。易测试性是轻松地确认,即软件可以被高效测试的程度。它在软件的初期开发阶段和维护阶段发挥着作用,易测试性可以被认为是已修改的软件可以被确认的能力。

按照 Peter 的说法,影响易测试性的主要因素是:

  • 控制(不稳定性):我们能够比较好地控制系统(以孤立的方式),更多、更好的测试可以被执行、自动化和优化。
  • 可见性或可观察性:你能够看到什么可以被测试。可以观察到输入、输出、状态、内部构件、错误条件、资源利用率,以及系统在测试时其他方面的影响。

Peter 说,易测试性通常是比自动化更为经济的投资。同时,自动化也依赖于易测试性,如果系统设计为可测试的,那么也将会降低自动化测试所需的工作量。

为什么针对易测试性的设计重要呢,你可以如何去说服管理者为此投资呢?它最主要的好处是能够降低成本、工作量和调试、诊断的时间,以及整个软件开发生命周期中的维护成本。Peter 引用了 Stefan Jungmayr 在德国测试社区的调查,这个调查在 Testbarkeitsfaktoren und Testaufwand: Auswertung dreier Umfragen 中进行了描述说明; testbarkeitsanforderungen an die Software 上其中有一个结论是,易测试性可以节省总体开发中大约 10% 的预算。

针对易测试性的设计必须由架构师、开发人员和测试人员共同来完成。Peter 说,架构师愿意接受易测试性的设计。易测试性是一个设计准则,测试人员必须定义易测试性需求。在敏捷中,易测试性是整个团队的职责,但是,如果有一个专人(比如测试架构师)来推动易测试性会很有好处。

Peter 在他的陈述中贡献了一个针对易测试性设计的检查表。这份检查表可以用来讨论团队或项目对易测试性的处理做到了什么程度,能够做什么去改进它:

  • 适当的测试架构,好的设计原则
  • 通过良定义控制点和可观察点在测试时与系统交互
  • 出于测试目的(安装、配置、模拟、恢复)附加的(可脚本化的)接口、端口、钩子、模拟、拦截器
  • 编码指南、命名规范
  • 内部软件质量(架构、代码)
  • 内建自测试、内建测试
  • 一致性检验(断言、契约式设计、偏差)
  • 日志和跟踪(面向方面的程序设计、计数器、监控器、探查、剖析)
  • 诊断和 dump 工具,黑盒子(内部状态、资源利用率、运行期的异常现象)
  • 测试优先的思维(xTDD):我可以怎么去测试它呢?

通过应用好的设计实践可以完成针对易测试性的设计。这正是 Peter 所说的为什么架构师在此扮演着一个非常重要的角色。做好敏捷其实是指做好敏捷工程实践。Peter 提到了干净的代码开发人员维基百科,它包括做更好的软件的原则和实践。

针对易测试性的设计策略需要涉及需求、测试和架构。易测试性需要被一致地定义,并由涉及其中的每个人充分地理解它,这些人参与或负责基于风险的测试策略,并保持非功能性需求的稳定性。易测试性指南可以在设计中用来规定易测试性和内嵌的易测试性。里程碑和质量门需要有易测试性的标准,不管是从事静态测试还是动态测试都必须要研究和探索易测试性。

“忽视易测试性意味着增加技术债”,Peter 以这句话作为了他的教程的结论。

查看英文原文: Designing Systems for Testability

2014-10-28 08:271855

评论

发布
暂无评论
发现更多内容

互联网寒冬之际,凭借这份10w字大厂Java面试真题汇总,半月斩获7个Offer!

Java永远的神

spring 程序员 JVM 多线程 Java 面试

手把手教你入门Vue,猴子都能看懂的教程

知心宝贝

JavaScript 云原生 Vue 前端 可视化

OpenHarmony应用HAP包签名

OpenHarmony开发者

OpenHarmony

开源浪潮下,Apache APISIX 如何成为全球最活跃 API 网关

API7.ai 技术团队

API网关 APISIX 网关 OpenSergo

后CNN探索,如何用RNN进行图像分类

华为云开发者联盟

人工智能 华为云 CNN 企业号十月PK榜

等保测评机构是什么意思?是什么性质的单位?

行云管家

公司 机构 等级保护 等保测评 等级测评

追求性能极致:Redis客户端缓存带来的革命

程序员小毕

Java 数据库 redis 面试 后端

Java开发培训机构怎样选择靠谱的

小谷哥

java线下培训哪家比较适合小白学习

小谷哥

MathType2023软件安装word教程

茶色酒

MathType2023

特权账号管理系统是什么?是堡垒机吗?

行云管家

网络安全 堡垒机 账号安全 特权账号管理 特权账号

参加前端培训学习还值得吗

小谷哥

划重点!2022面试必刷461道大厂架构面试真题汇总+面经+简历模板

Geek_0c76c3

Java 数据库 程序员 架构 面试

两种方式修复谷歌翻译无法使用问题

echeverra

线下学习web前端培训可以吗

小谷哥

大数据ELK(二十三):Kibana简介

Lansonli

Kibana 10月月更

Go WEB进阶实战:基于GoFrame搭建的电商前后台API系统

王中阳Go

电商 Go web #go #开源 10月月更

最后一块石头的重量

掘金安东尼

算法 10月月更

拿捏了!阿里2022最新JDK源码深度解析小册,Github全站热榜第二

Geek_0c76c3

Java 数据库 开源 程序员 开发

KubeEdge 1.12版本发布,稳定性、安全性、可扩展性均带来大幅提升

华为云开发者联盟

云计算 云原生 华为云 kubeedge 企业号十月PK榜

首次公开!阿里巴巴最新高并发架构设计实录被我从Github扒下来了

Geek_0c76c3

Java 数据库 开源 程序员 开发

Android技术分享| Bugly 应用升级自定义UI

anyRTC开发者

android 音视频 UI 移动开发 Bugly

优秀!阿里甩出GC面试小册,仅7天Github获赞96.9K

Geek_0c76c3

Java 数据库 程序员 JVM 规划

OA是什么意思?

优秀

OA oa办公系统 OA是什么意思

全新出品!Github总榜排行第七的SpringCloud生态全栈笔记我粉了

Geek_0c76c3

Java 数据库 程序员 架构 面经

easyrecovery2023数据恢复软件功能介绍

茶色酒

EasyRecovery easyrecovery2023

MobTech短信验证常见问题

MobTech袤博科技

sdk 短信验证

大数据开发培训学习费用多少呢

小谷哥

mmmbsc互助系统开发3M智能合约技术

薇電13242772558

智能合约

CDR2023最新版本有什么新功能?

茶色酒

imazing2023免费版iOS管理工具

茶色酒

imazing2023

针对易测试性的系统设计_研发效能_Ben Linders_InfoQ精选文章