针对易测试性的系统设计

来自于西门子公司的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以这句话作为了他的教程的结论。

时间: 2024-10-22 06:15:15

针对易测试性的系统设计的相关文章

易测性与好的设计之间的关系

好的单元测试用例中发现的问题揭露了设计和代码上的缺点. 最近这段时间,对单元测试的介绍急剧地增多.而在上世纪90年代和2000年早期,这一习惯似乎十分无力.通常就是这样,人们采用一项新的技术,回溯当年,各机构们也在从结构化设计方法转向以对象为中心的设计方法,他们将所有的焦点放在至关重要的权利上,同时丢弃看起来不能与新愿景整齐地融合的例行做法.因此单元测试就被忽略了. 但是,很少但是要说我们从过去的10年中学到了什么,那就是我们学到了单元测试是一个非常重要的学科.测试帮助我们更好地来写代码,形成回

航空航天专用Everspin非易失性MRAM存储器

TAMU是由瑞典乌普萨拉的?ngstr?m航空航天公司(?AC)开发的高级磁力计子系统.TAMU的目的是提供地球磁场的磁力计数据,以便与子画面观测相关.实验性TAMU由使用领先技术制造的四种类型的设备组成:3轴地磁传感器,通过3D封装系统技术制造的MPU芯片,制造的4Mbit MRAM(磁性随机存取存储器)芯片由Everspin Technologies和IMU(惯性测量单元)芯片组成. ?ACMicrotec在其Tohoku-?ACMEMS单元(TAMU)(磁力计子系统)中使用了Everspi

基于pstore 和 ramoops实现在非易失性内存中保存panic日志

基于pstore和 ramoops实现在非易失性内存中保存panic日志 具体步骤如下 0.确定地址范围 需求提前知道用来保存panic日志的非易失性内存的起始地址和长度.比如笔者用到的那部分内存的起始地址是0x11ff000000,长度是16M. 2.修改内核 保证内核配置选项中选上了ramoops驱动支持: 生成驱动加载过程中,如果发现对独立的非易失性存储加载驱动失败,检查是否需要修改内核驱动,特别是fs/pstore/ram_core.c中的request_mem_region()函数,然

展望由非易失性设备构成的未来存储

 展望由非易失性设备构成的未来存储 Edward Sharp "愿你生活的时代充满趣味".不知您是否注意到,而今的IT世界已然如此,充斥着诸如云.移动.大数据.内存数据库.NoSQL.远程直接内存访问(RDMA).叠瓦式磁记录(SMR)硬盘.非易失性存储(NVM)以及其他不胜列数的新技术.正是由于这些新科技与技术让使用者能以更精简的资源来实现更为强大的功能,我们面临的世界正经历着天翻地覆的变化.这样的变革对现有的行业既是一种威胁,但另一方面,对于敏捷.专注而果敢的公司而言,恰恰

“非易失性内存”嫁接“内存计算”——高速安全的大数据时代来临

“非易失性内存”嫁接“内存计算” ——高速安全的大数据时代来临 题记 数据库奠基人Jim Gray:“磁带已经死了,磁盘已经落伍,闪存成为存储,内存才是王道”.“不管磁盘是否消融,闪存都是将来的一个趋势.” 石油一直直接影响着世累经济的发展速度和发展水平,现在,信息将发挥同样的作用.<经济学人>表示:“数据和信息日益成为商业的新能源,是一种与资本.劳动力并列的新经济元素”. 数据保护 大数据时代的机遇和挑战 大数据“风华正茂” 大数据时代,每两天的数据量就达到2ZB,相当于20世纪前人类文明所

EVERSPIN非易失性MRAM具吸引力的嵌入式技术

相关研究指出,如果以嵌入式MRAM取代微控制器中的eFlash和SRAM,可节省高达90%的功耗:如果采用单一晶体管MRAM取代六个晶体管SRAM,则可实现更高的位元密度和更小的芯片尺寸,这些功率与面积成本优势将使MRAM成为边缘侧设备的有力竞争者.而相较于传统的NAND闪存,PCRAM或ReRAM存储级存储器更可提供超过10倍以上的存取速度,更适合在云端对资料进行存储. MRAM是一种非易失性存储技术,该技术具备接近静态随机存储器的高速读取写入能力,快闪存储器的非易失性.容量密度和与DRAM几

非易失性MRAM诞生过程

MRAM技术是以可沉积在标准逻辑制程上的磁性隧道结 (MTJ)储存单元为基础,MTJ中包含了一个维持单一极性方向的固定层,和一个通过隧道结与其隔离的自由层.当自由层被施予和固定层相同方向的极化时,MTJ的隧道结便会显现出低电阻特性.而当自由层被施予反方向的极化时,MTJ便会有高电阻.此一磁阻效应可使MRAM不需改变内存状态,便能快速读取数据.在MRAM存储器中有一个富含创造性的设计,这也是EVERSPIN的专利. 在MRAM的诞生过程中,设计的难点和关键节点,在于一个小电流通过"自由层"

关于系统设计原则回顾

最近有人问我 系统设计的原则,事实上不论今天各个技术栈怎么演化,那些本质的原则与方法不会变, 让我们回顾一下 这些原则: ?分散关注 Separation of concerns. Divide your application into distinct features with as little overlap in functionality as possible. The important factor is minimization of interaction points

软件测试,性能测试,功能测试,自动化测试,接口测试,移动端测试

1.问:你在测试中发现了一个bug,但是开发经理认为这不是一个bug,你应该怎样解决? 首先,将问题提交到缺陷管理库里面进行备案. 然后,要获取判断的依据和标准: 根据需求说明书.产品说明.设计文档等,确认实际结果是否与计划有不一致的地方,提供缺陷是否确认的直接依据: 如果没有文档依据,可以根据类似软件的一般特性来说明是否存在不一致的地方,来确认是否是缺陷: 根据用户的一般使用习惯,来确认是否是缺陷: 与设计人员.开发人员和客户代表等相关人员探讨,确认是否是缺陷: 合理的论述,向测试经理说明自己