当前位置:首页 > 测试测量 > 测试测量
[导读]前言目前在嵌入式领域,目标系统的应用系统日趋复杂,而由于竞争要求产品快速上市,开发技术日新月异,同时硬件发展的日益稳定,造成了软件故障日益突出。由此,软件的重要性越来越引起人们的重视,人们认识到嵌入式

前言

目前在嵌入式领域,目标系统的应用系统日趋复杂,而由于竞争要求产品快速上市,开发技术日新月异,同时硬件发展的日益稳定,造成了软件故障日益突出。由此,软件的重要性越来越引起人们的重视,人们认识到嵌入式系统的测试势在必行。

由于嵌入式系统的自身特点,如实时性、内存不丰富、I/O通道少、开发工具昂贵、并且与硬件紧密相关,CPU种类繁多等等。嵌入式软件的开发和测试也就与一般商用软件的开发和测试策略有了很大的不同,可以说嵌入式软件是最难测试的一种软件。

嵌入式软件测试使用有效的测试策略是唯一的出路,它可以使开发的效率最大化,避免目标系统的瓶颈。自从出现高级语言,开发环境与最终运行环境通常都是存在差异的,嵌入式系统更是如此。开发环境被认为是主机平台,软件运行环境为目标平台。相应的测试为主机-目标测试或交叉测试。

讨论嵌入式软件测试首先就会遇到一个问题:为什么不把所有测试都放在目标上进行呢?因为若所有测试都放在目标平台上有很多不利的因素:例如测试软件可能会造成与开发者争夺时间的瓶颈;目标环境还不具备;比起主机平台环境,目标环境通常是不精密的和不方便的等等。

从经济上和开发效率上考虑,在开发周期中软件应该尽可能多地工作在主机系统环境中,其中包括测试。

确定主机-目标(Host-target)测试环境后,开发测试人员又会遇到以下的问题:例如多少开发人员会卷入测试工作;多少软件应该测试,花费多长时间测试;在主机环境和目标环境有哪些软件工具,价格如何等等。

任何人或组织在测试嵌入式软件时都应深入考虑以上问题,结合自身实际情况选定合理测试策略和方案。

嵌入式软件测试或叫交叉测试(Cross-test),测试内容包括:1.单元测试;2.集成测试;3.确认测试;4.系统测试。

使用有效的交叉测试策略可极大地提高嵌入式软件开发测试的水平和效率,下文给出各个阶段的嵌入式软件测试方案。

静态测试

静态测试不利用计算机运行被测程序,目的是度量程序静态复杂度,检查软件是否符合编程标准。

1)静态测试工具McCabe QA

McCabe QA是美国McCabe&Association公司的产品。它利用著名学者McCabe的软件结构化测试理论,即使用V(G)圈复杂度=模块内部独立线性路径数来度量软件的复杂度。

McCabe最大的特点就是可视化,以独特的图形技术表示代码。软件通过分析源码,得到整个软件系统的结构图,同时得到了各种基于工业标准评估代码复杂性,包括V(g)、EV(g)、DV(g)、Halstead等数十种静态复杂度度量。用不同的颜色表示软件模块的复杂性,测试人员的测试重点放在质量差的模块上;提供各种质量模型深入评价软件质量,纪录软件质量波动曲线和版本变化趋势分析,从而控制软件修改不同阶段的质量。在单元级McCabe 显示模块的流程图,并且相对应地标出代码的位置,视图与代码相互对应,可很快找出问题所在。分析最终得到可定制的符合工业标准的综合报告。

2) 代码规则检查工具QAC/C++

QAC/QAC++是用于代码规则检查的自动化工具。代码审查主要检查代码和设计的一致性,代码对标准的遵循、可读性,代码的逻辑表达的正确性,代码结构的合理性等方面。发现违背程序编写标准的问题,程序中不安全、不明确和模糊的部分,找出程序中不可移植部分、违背程序编程风格的问题,包括变量检查、命名和类型审查、程序逻辑审查、程序语法检查和程序结构检查等内容。

动态测试

动态测试时软件必须运行。动态测试方法分为黑盒法和白盒法。为了较快得到测试效果,通常先进行功能测试,达到所有功能后,为确定软件的可靠性进行必要的覆盖测试。

在软件开发的不同时期进行动态测试,测试又分为单元测试、集成测试、确认测试、系统测试。

单元测试

单元测试方案之一采用IPL公司的Cantata++测试工具,它能够满足开发者进行高效的单元测试和集成测试要求,能够提高测试效率,具有一整套包含测试、覆盖率分析和静态分析的功能。Cantata++含有以下几个主要部分:

CTH测试功能库,Cantata++通过CTH提供的测试函数执行测试,提供测试所需用例的输入输出,并检查输出结果是否符合要求,给出合格/不合格的确切结果。打桩、封装和动态分析的执行也是利用CTH。

Cantata++主程序包括测试脚本自动生成器和管理器。测试脚本生成工具通过分析源代码得到参数和数据信息,连同自动产生的Stub打桩函数和Wrap封装函数,自动生成到测试脚本中。测试脚本完全使用C或C++语言构成,可重用。通过使用测试脚本管理器可以自动完成测试用例定义到测试脚本的转换。对于熟练的用户,可以直接利用CTH提供的库函数,直接编写C或C++语言的测试脚本。

完全支持白盒测试和黑盒测试技术,通过脚本检查所有标准的和用户定义的类型,对期望和不期望的异常进行检查;重用继承类和模板实例的测试用例;为所有预期结果和实际结果的检查进行详细的测试分析。支持覆盖率分析,提供从语句覆盖级到MC/DC (DO-178B A)标准的度量。

集成测试

集成测试是软件的单元测试完成后进行的。Cantata++同样支持集成测试方法,进行调用序列,传递参数的检查。并且提供独特的封装功能,完成硬件错误注入的测试。提供Wrap技术,相对于打桩函数stub,封装函数,Wrap技术有以下优势:

1) 在被测模块中采用模拟的误码,避免真实代码的执行。模拟硬件问题,进行逆向测试。

2) 可以校验集成调用的执行过程Call 序列,允许测试者控制被测软件的外部环境,以及检查调用其成员函数的执行是否正确(包括参数、执行的顺序)。

3) 允许真实调用某些成员函数,而封装另一些函数的调用,控制其输入和返回参数。

另一款集成测试工具是McCabe Test。正如前一部分提到的,它可很直观地从整体上把握软件的结构,生成集成测试计划,通过插装被测试软件,得到被插装后的源代码。运行目标编译器,最后测量覆盖率,产生覆盖率报告。

通过被测试软件的结构图,直观地评估“测了多少”,深入得到代码级,以图形的方式标示已测代码和未测代码。支持MC / DC覆盖分析,满足DO178B-A标准。McCabe QA 与McCabe TEST等组件组成McCabe IQ工具包,构成了一整套完整的白盒测试方案。

确认测试和系统测试

包括恢复测试、安全测试、强度测试、性能测试,已超出了本文讨论的范畴,本文暂不详述。

结语

嵌入式软件通常在主机环境执行多数的测试,只是在最终确定测试结果和最后的系统测试才移植到目标环境,这样可以避免发生访问目标系统资源上的瓶颈,也可以减少在昂贵资源如在线仿真器上的费用。另外,若目标系统的硬件由于某种原因而不能使用时,最后的确认测试可以推迟直到目标硬件可用,这为嵌入式软件的开发测试提供了弹性。

设计软件的可移植性是成功进行交叉测试的先决条件,它通常可以提高软件的质量,并且对软件的维护大有益处。本文提到的测试工具,都可以通过各自的方式提供测试在主机与目标之间的移植,从而使嵌入式软件的测试得以方便地执行。

使用有效的测试策略可极大地提高嵌入式软件开发测试水平和效率,提高嵌入式软件的质量并降低成本。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

瑞典乌普萨拉,2025年6月24日 — 全球嵌入式系统软件解决方案领导者IAR正式发布适用于瑞萨RX和RL78系列微控制器的新版本开发工具链:Renesas RX v5.20和RL78 v5.20。此次更新进一步巩固了I...

关键字: MCU 嵌入式软件 工具链

为增进大家对嵌入式软件的认识,本文将对嵌入式软件的发展以及分析嵌入式软件问题的方法予以介绍。

关键字: 嵌入式 指数 嵌入式软件

为增进大家对嵌入式软件的认识,本文将对嵌入式软件的开发流程予以详细介绍。

关键字: 嵌入式 指数 嵌入式软件

为增进大家对嵌入式软件的认识,本文将对嵌入式软件的特征、嵌入式软件的分类以及嵌入式软件Vector予以介绍。

关键字: Vector 指数 嵌入式软件

在嵌入式系统开发中,硬件资源的限制和测试环境的搭建常常成为开发者面临的挑战。QEMU(Quick Emulator)作为一款开源的机器模拟器和虚拟化器,能够在主机系统上模拟目标硬件环境,为嵌入式软件的仿真测试提供了强大的...

关键字: QEMU 嵌入式软件 仿真

随着汽车电子化程度的不断提高,汽车嵌入式软件的功能复杂性也在日益增长。为了确保这些软件在复杂多变的车载环境中能够稳定、可靠地运行,功能安全(Functional Safety)成为了汽车软件开发过程中不可或缺的一环。IS...

关键字: ISO 26262 功能安全 嵌入式软件

嵌入式软件可编程逻辑控制器(PLC)是工业自动化领域的核心设备,广泛应用于生产线控制、过程控制、运动控制等场景。随着工业4.0和智能制造的发展,PLC控制器需要具备更高的实时性、可靠性和可扩展性。本文将探讨工业PLC控制...

关键字: PLC控制器 嵌入式软件

嵌入式软件开发团队面临的最大挑战之一是,他们花费太多时间来调试软件。当我与全球团队和工程师交谈时,在我参加的各种会议上,显然,开发人员平均将其40%的时间或更多时间用于调试软件。

关键字: 嵌入式软件 合同设计

开发灵活且可扩展的嵌入式软件已成为产品开发的重要方面。越来越多的公司不是开发单个单片产品,而是开发一个核心平台,从中可以创建几个不同的产品线。在核心代码中,有时会有所需的软件行为未知,并且必须满足特定产品需求。为了实现代...

关键字: 代码灵活性 嵌入式软件

软件体系结构是其组件中体现的系统的基本组织,彼此之间的关系以及环境的关系以及指导其设计和进化的原则。软件体系结构并不是要创建一次并将其设置为石头。相反,软件体系结构应在整个产品的一生中发展和变化。多年来,我听到工程师和经...

关键字: 嵌入式软件 软件体系结构
关闭