“AI 技术+人才”如何成为企业增长新引擎?戳此了解>>> 了解详情
写点什么

针对易测试性的系统设计

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

评论

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

正式发布!《ICPMM行业云平台运营管理能力成熟度》系列标准来了!

天翼云开发者社区

云计算 云服务 企业上云

otc承兑商支付系统开发 otc承兑商支付模式系统开发

西安链酷科技

为什么跨境电商成为海外云手机的主要受众群体?

Ogcloud

云手机 海外云手机 跨境电商云手机 云手机海外版

探索 Vue 3.0 下的低代码创新

不在线第一只蜗牛

低代码 开发 Vue3 API

Comparison between IPQ9574 and IPQ9554 | MLO EHT Solution Unveils the WiFi 7 CPU for Industrial

wallyslilly

选择海外云手机需要考虑什么?

Ogcloud

云手机 海外云手机 云手机海外版

连续四次登顶!天翼云稳居中国专属云服务市场第一

天翼云开发者社区

云计算 云服务 IDC

BRC20铭文跨链系统开发技术

西安链酷科技

BRC-20 铭文币

亚洲杯+欧洲杯+奥运会观赛“体育直播平台”如何开发方法

软件开发-梦幻运营部

软件测试学习笔记丨Flask环境安装

测试人

软件测试

AI for Good | AI+环保,点亮可持续的智能未来

澳鹏Appen

人工智能 AI向善 环境保护

区块链开发项目:构建去中心化未来的蓝图

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

做dapp的开发公司有哪些

西安链酷科技

DAPP系统开发

传统外贸和代购独立站的区别

tbapi

传统外贸 外贸独立站

在线视频转Mp3软件4K YouTube to MP3中文直装版

南屿

音频提取工具 音频转换 MP3

软件测试学习笔记丨Linux数据处理

测试人

软件测试

低代码开发业务在AIGC时代的应用

EquatorCoco

人工智能 低代码 AIGC

大模型+知识图谱双驱架构:新一代《知识语义框架SPG》白皮书

机器智能社区

知识图谱 大模型

一文深度解读多模态大模型视频检索技术的实现与使用

阿里云视频云

云计算 大模型 视频云

使用云手机运营TikTok,实现更多可能性

Ogcloud

云手机 海外云手机 tiktok云手机 云手机海外版

Higress 开源一周年:新版本,新标准,新工具,新征程

阿里巴巴云原生

阿里云 开源 云原生 Higress

最佳在线项目管理网站揭晓:2024年全方位对比15大热门工具

PingCode

项目管理 项目管理工具

苹果电脑实用工具:Unclutter for mac 下拉菜单隐藏工具

南屿

下一代软件架构,如何构建微服务核心能力

阿里巴巴云原生

阿里云 Serverless 微服务 云原生

10个适合后端程序员的前端框架

快乐非自愿限量之名

程序员 前端 前端框架

减少文件体积优化性能,你的姿势对了吗?

Yestodorrow

云原生 前端开发 可观测性 用户体验 网站性能

低代码是软件开发的未来吗?

这我可不懂

软件开发 低代码开发 JNPF

SWAP/DEX去中心化交易所开发

西安链酷科技

swap链游 合约交易所开发

一个响指,代码生成!华为云CodeArts Snap正式公测

华为云PaaS服务小智

人工智能 华为云

17 位社区大咖寄语,Seata 进入 Apache 孵化器

阿里巴巴云原生

Apache 阿里云 云原生 seata

BRC20铭文合约代币系统开发

西安链酷科技

铭文开发

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