AICon 上海站|日程100%上线,解锁Al未来! 了解详情
写点什么

针对易测试性的系统设计

  • 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:271984

评论

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

面试官:你了解JVM的锁优化吗?

百度开发者中心

Java 最佳实践 方法论 语言 & 开发

体验有奖 | 1 分钟 Serverless 部署掌上游戏机,“一行命令”找回小时候的乐趣!

Serverless Devs

【秋招面试专题解析】成功入职头条月薪35K

欢喜学安卓

android 程序员 面试 移动开发

【吐血整理】大牛耗时一年最佳总结,让你的app体验更丝滑

欢喜学安卓

android 程序员 面试 移动开发

gitlab无法通过ssh拉代码

阿呆

#GitLab

区块链技术如何有效应对气候变化

CECBC

【性能优化实战】Android架构组件Room功能详解

欢喜学安卓

android 程序员 面试 移动开发

分布式拒绝服务 (DDoS) 攻击对企业运维造成的影响分析

九河云安全

FIL分币系统源码|分销商城功能开发模式介绍

Geek_23f0c3

fil Fil算力挖矿分币系统 Filecoin分销商城

编译脚本:编写CMakeFile(一)

正向成长

CMakeFile

立体车库数据管理被卡脖子?织信车库管理系统全面掌控车辆新状况

优秀

低代码

DataPipeline荣膺CFS第十届财经峰会“2021数字化转型推动力奖”

DataPipeline数见科技

大数据 数据融合 数据管理

当企业遭遇分布式拒绝服务 (DDoS) 攻击时,第一时间该如何进行操作?

九河云安全

双非本化学跨专业,投岗阿里/滴滴后端三面,最终拿下offer

编程菌

Java 编程 程序员 面试 计算机

如何用EasyRecovery恢复U盘内损坏的数据

淋雨

文件恢复 硬盘数据恢复 Easyrecivery

态势感知一屏可视:数治安全,智理未来

一只数据鲸鱼

网络安全 数据可视化 数据监测 数字孪生

迅捷录屏大师 Tech Support

凌天一击

FastApi-04-请求体-1

Python研究所

FastApi 8月日更

关于Spring注解开发教程,打包全送你

华为云开发者联盟

Java spring 容器 注解 组件

从河南暴雨、疫情反弹看区块链“灾疫”治理

CECBC

24岁,月薪35k!全靠这份阿里P5-P9知识核心手册+10W字面试题总结

Java架构追梦

Java 阿里巴巴 架构 面试

你使用的SimpleDateFormat类还安全吗?

华为云开发者联盟

Java 安全 线程 高并发 SimpleDateFormat类

啃书一年多的我,推荐Python初学者不要在乱看书了,有这三本就妥妥的

冇先生

频繁出现的分布式拒绝服务 (DDoS) 攻击​,有什么办法可以抵御吗?

九河云安全

「跨链网关的模块化进程」插件机制演化

趣链科技

TRTC代码示例文档集合完毕!哪里不会点哪里!

腾讯云音视频

腾讯云 音视频 API sdk

基于 Apache APISIX,新浪微博API网关的定制化开发之路

API7.ai 技术团队

Apache 网关 APISIX 微博

android 工作资料!职场中的中年危机

欢喜学安卓

android 程序员 面试 移动开发

Linux 网络管理技术 OSI 七层模型和 TCP/IP 四层模型

学神来啦

Linux 运维 IP

下一个颠覆的领域:区块链如何影响审计行业?(下)

CECBC

ironSource 在 2021 ChinaJoy 举办多场活动赋能中国开发者

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