嵌入式软件测试规范
嵌入式软件的测试方法与技术

嵌入式软件的测试方法与技术引言嵌入式软件的测试方法与技术是保证嵌入式系统质量的关键环节。
随着科技的发展,嵌入式系统在各个领域得到了广泛应用,从家用电器到汽车,从医疗设备到航空航天,都离不开嵌入式软件。
而这些应用领域对于系统的可靠性和安全性要求越来越高,因此对于嵌入式软件的测试方法与技术也提出了更高要求。
一、嵌入式软件测试方法概述1.1 黑盒测试黑盒测试是一种基于功能需求和接口规范来进行测试的方法。
在黑盒测试中,我们不关心被测系统内部是如何实现的,只关注其输入和输出之间是否符合预期。
这种方法可以很好地验证系统是否满足需求,并且可以提前发现潜在问题。
1.2 白盒测试白盒测试是一种基于代码内部结构来进行测试的方法。
通过分析代码逻辑、覆盖率等指标来评估被测系统是否符合预期。
白盒测试可以发现代码中隐藏的逻辑错误和漏洞,并且可以提供更详细的测试覆盖率信息。
1.3 灰盒测试灰盒测试是黑盒测试和白盒测试的结合,既关注系统功能,也关注系统内部结构。
在灰盒测试中,可以利用黑盒测试的方法验证系统功能,同时通过白盒测试的方法发现潜在问题。
这种方法可以综合利用黑白两种方法的优点。
二、嵌入式软件测试技术2.1 静态分析技术静态分析技术是一种通过分析源代码或二进制代码来发现潜在问题的方法。
静态分析可以帮助开发人员在编码阶段发现错误和漏洞,并且可以提供代码质量评估和优化建议。
2.2 动态分析技术动态分析技术是一种通过运行时监测来评估系统行为和性能的方法。
动态分析可以帮助开发人员了解系统运行时状态,并且可以提供性能优化建议。
2.3 模糊测试技术模糊测试是一种通过生成大量随机输入来验证系统鲁棒性和安全性的方法。
模糊测试可以帮助开发人员找到输入错误处理不当或存在漏洞的地方,并且可以提供安全防护建议。
2.4 测试自动化技术测试自动化技术是一种通过编写测试脚本和使用自动化工具来提高测试效率和准确性的方法。
测试自动化可以帮助开发人员快速执行大量的测试用例,并且可以提供准确的测试结果。
嵌入式软件测试方法详解

嵌入式软件测试方法详解嵌入式软件测试是指针对嵌入式系统中的软件进行测试的过程。
嵌入式系统是指集成了软件和硬件的复杂系统,这些系统通常嵌入在一些设备中,如手机、汽车、电视等。
为了确保嵌入式系统的正常运行和稳定性,嵌入式软件测试变得极其重要。
本文将详细介绍嵌入式软件测试的方法。
一、静态测试方法静态测试方法是在嵌入式软件开发的早期阶段就进行的测试方法。
它主要通过代码审查和静态分析来发现潜在的问题和错误。
代码审查是指通过人工检查代码的规范性、可读性和实现逻辑等方面的错误和问题。
静态分析是指使用工具对代码进行扫描,以发现潜在的问题和错误。
静态测试方法可以帮助开发人员在开发的早期阶段就发现并修复问题,从而减少后期测试阶段的工作量。
二、单元测试方法单元测试方法是对嵌入式软件中的各个模块进行独立测试的方法。
它通常是使用白盒测试技术,开发人员可以直接查看代码并编写测试用例。
单元测试旨在检查模块是否按照预期执行,并验证其输出是否正确。
单元测试方法可以帮助开发人员在开发过程中对每个模块进行细致的测试,以确保其功能的正确性和稳定性。
三、集成测试方法集成测试方法是对嵌入式软件的各个模块进行整合测试的方法。
在嵌入式系统中,各个模块通常是独立开发的,集成测试旨在测试模块之间的接口和交互是否正常。
通过集成测试,可以发现并解决模块之间的兼容性问题、数据传输问题以及接口交互问题。
集成测试可以确保整个系统的功能正常运行,并保证各个模块之间的协调性。
四、系统测试方法系统测试方法是对整个嵌入式系统进行测试的方法。
系统测试旨在验证系统是否满足需求规格说明书中的要求,并检查系统在不同环境下的性能和稳定性。
系统测试一般包括功能测试、性能测试、兼容性测试、安全性测试等多个方面。
通过系统测试,可以发现并修复系统中的问题,确保系统的完整性和可靠性。
五、回归测试方法回归测试方法是在系统发生变更后对系统进行重新测试的方法。
嵌入式软件开发过程中,经常需要对系统进行改进和升级,回归测试旨在验证系统的改动是否对原有功能和模块产生了影响。
嵌入式软件测试标准

嵌入式软件测试标准嵌入式软件测试是指针对嵌入式系统中的软件进行的测试活动,其目的是确保嵌入式软件的质量和可靠性。
嵌入式软件通常运行在嵌入式系统中,这些系统可能是汽车电子控制单元、医疗设备、智能家居设备等。
由于嵌入式软件的特殊性,其测试标准也需要有相应的规范和要求。
本文将介绍嵌入式软件测试标准的相关内容。
首先,嵌入式软件测试标准需要包括测试计划的编制。
测试计划是测试活动的指导性文件,其中包括测试的范围、目标、资源需求、进度安排、风险评估等内容。
在嵌入式软件测试中,测试计划的编制是非常重要的,它能够确保测试活动按照既定的目标和计划进行,有助于提高测试效率和测试质量。
其次,嵌入式软件测试标准还需要包括测试用例的设计。
测试用例是测试活动的核心,它描述了针对特定功能或场景的测试步骤、输入数据、预期输出等信息。
在嵌入式软件测试中,测试用例的设计需要考虑到嵌入式系统的特殊性,例如对实时性、稳定性、安全性的要求。
因此,测试用例的设计需要充分考虑这些特殊要求,以确保测试覆盖的全面性和有效性。
另外,嵌入式软件测试标准还需要包括测试环境的搭建和管理。
测试环境是进行测试活动所必需的硬件、软件、工具等资源的集合,它对测试活动的顺利进行起着至关重要的作用。
在嵌入式软件测试中,由于嵌入式系统通常是由硬件和软件共同组成的,因此测试环境的搭建和管理需要考虑到这些特殊性,确保测试环境能够准确地模拟嵌入式系统的实际运行环境。
最后,嵌入式软件测试标准还需要包括测试结果的分析和报告。
测试结果的分析和报告是测试活动的总结和输出,它能够为软件质量评估和改进提供重要依据。
在嵌入式软件测试中,由于嵌入式系统的特殊性,测试结果的分析和报告需要充分考虑到实时性、稳定性、安全性等方面的要求,以确保分析和报告的准确性和有效性。
综上所述,嵌入式软件测试标准是确保嵌入式软件质量和可靠性的重要保障,它涵盖了测试计划的编制、测试用例的设计、测试环境的搭建和管理、测试结果的分析和报告等内容。
如何做好嵌入式软件开发测试

如何做好嵌入式软件开发测试嵌入式软件测试是确保嵌入式系统的稳定性和可靠性的关键步骤之一、嵌入式软件的特点是运行在嵌入式系统中,并受到硬件限制、资源限制以及实时性要求的约束。
因此,嵌入式软件测试需要特别的关注点和方法。
下面是一些关键的步骤和技巧,以保证嵌入式软件开发测试的质量。
1.理解需求和软件架构:在进行嵌入式软件测试之前,必须对软件系统的需求和架构有充分的理解。
这将有助于测试人员了解系统的功能和性能要求,从而制定相应的测试策略和计划。
2.制定详细的测试计划:测试计划是一个指导测试活动的重要文档。
它应该明确规定测试的范围、目标、方法、资源和时间等方面的内容。
测试计划还应该包括测试的策略、用例和检查点等详细信息。
3.设计和制定测试用例:测试用例是测试的基本单元,用于验证系统的各种功能和性能。
在嵌入式软件测试中,测试用例的设计和制定可能会受到资源和实时性要求的限制。
因此,测试人员应该注意测试用例的覆盖率和效率,以确保尽可能多地测试到系统中的错误。
4.搭建适当的测试环境:在进行嵌入式软件测试之前,必须搭建适当的测试环境。
这包括硬件、软件、工具和数据等方面的准备。
嵌入式系统的测试环境应尽可能接近实际使用环境,以确保测试结果的准确性和可靠性。
5.进行功能测试:功能测试是嵌入式软件测试的核心。
它涉及对软件的各种功能进行验证和确认,以确保其满足需求和规范。
功能测试应包括正常情况下的功能测试和异常情况下的功能测试,以确保软件在各种情况下都能正常工作。
6.进行性能测试:性能测试是确定系统响应时间、吞吐量和资源利用率等方面的测试。
在嵌入式软件测试中,性能测试可能针对处理速度、内存占用和能耗等方面进行。
性能测试应尽可能接近实际使用情况,以确保软件在实际运行时能够满足性能要求。
7.进行安全测试:安全测试是确保嵌入式系统的安全性和可靠性的关键测试。
在进行安全测试时,测试人员应注意系统的漏洞和错误,以及可能的攻击和破坏方式。
嵌入式软件接口测试方法

三、嵌入式软件接口测试方法
API接口测试 协议接口——底层:信号类 协议接口——中间层:数据类 协议接口——高层:文本类
三、嵌入式软件接口测试方法
API接口测试 API接口函数 测试接口函数的功能和性能 测试方法:
编写测试程序,调用API函数 交叉编译 可执行程序下载到嵌入式设备 运行,获取测试结果
接口的分类(二)
人与系统 硬件与硬 的接口 件的接口
软件与软 软件与硬 件的接口 件的接口
一、接口与接口测试
底层软件提供的应用编程接口 系统API 开发包API
人与计算机操作用户界面 GUI CLI
接口的分类(三)
API
总线/网
络接口
人机交互 界面
数据库 接口
部件与部件通过总线/网络相连 Ethernet、RS232、CAN、
很大比例是安全关键软件,关系到生命安全和国家安全,要求
非常严格 一般来说上比非嵌入式软件更困难一些
测试 人员
二、嵌入式软件接口测试
嵌入式软件接口测试
对嵌入式软件测试包括静态和动态,包括基于结构的白盒测试和基于 需求规约的黑盒测试
嵌入式软件接口测试:对嵌入式软件提供的接口按照接口需求进行测 试和验证 ➢ 测试嵌入式软件接口信息数据与控制逻辑的正确性 ➢ 测试正常情况和异常情况(包括数据和逻辑) ➢ 测试接口的功能性、性能、安全性和稳定性
pass data and control correctly to one another.
一、接口与接口测试
接口测试(interface testing) 军用软件测评实验室测评过程与技术能力要求 接口测试是对软件需求规格说明或设计文档中的接口需求逐项进行的 测试。接口测试一般需进行:
嵌入式软件测试方法

嵌入式软件测试方法嵌入式软件测试方法是针对嵌入式系统开发的软件测试方法。
嵌入式系统是指嵌入在各种设备中的计算机系统,如智能手机、家庭电器、汽车、医疗设备等。
嵌入式软件测试的目标是确保嵌入式系统的软件质量和可靠性。
以下是常用的嵌入式软件测试方法:1.静态分析:静态分析是一种基于源代码或二进制代码的分析方法,用于检查代码中的错误和潜在的问题。
它通常包括代码审查、代码规范和代码耦合分析等。
静态分析可以在开发早期识别问题,并且可以帮助改进代码质量。
2.单元测试:单元测试是针对软件模块或功能的测试方法。
在嵌入式系统中,软件通常被分为多个模块,每个模块都有其特定的功能。
单元测试通过对每个模块进行测试,以确保它们按照预期运行。
单元测试可以使用各种测试技术,如白盒测试和黑盒测试。
3.集成测试:集成测试是将不同的模块或功能组合在一起进行测试的方法。
在嵌入式系统中,不同的模块通常需要相互协作才能实现系统的功能。
集成测试通过模拟实际的运行环境,测试模块之间的接口和交互,确保整个系统按照预期工作。
4.验收测试:验收测试是在开发完成后对整个系统进行的一系列测试。
验收测试的目标是确认系统是否符合用户需求和规格说明。
它通常由系统开发人员和最终用户共同进行,以确保系统的功能和性能满足用户的期望。
5.性能测试:性能测试是评估系统在不同负载条件下的性能和响应时间的方法。
在嵌入式系统中,性能测试可以用来评估系统的运行速度、内存使用情况和功耗等。
性能测试可以通过模拟实际的使用情况或使用工具和设备进行。
6.可靠性测试:可靠性测试是评估系统在长时间运行中的稳定性和可靠性的方法。
在嵌入式系统中,可靠性测试可以通过模拟不同的环境和使用条件,以确保系统在各种情况下都能正常工作。
7.安全测试:安全测试是评估系统的安全性和防护措施的方法。
嵌入式系统通常需要保护用户的隐私和数据安全。
安全测试可以通过模拟攻击、检查系统的漏洞和弱点等方式进行。
总的来说,嵌入式软件测试方法是多样的,旨在保证嵌入式系统的软件质量和可靠性。
嵌入式软件测试报告

嵌入式软件测试报告1.引言2.测试目标和范围测试目标是确保嵌入式软件的各个模块在提供正确的功能和性能的同时,具有高度的可靠性和稳定性。
测试范围包括嵌入式软件的所有模块和子系统。
3.测试方法本次测试采用了黑盒测试、白盒测试和灰盒测试的组合方法。
-黑盒测试:对系统功能进行测试,通过输入有效和无效的数据,验证输出是否符合预期。
主要包括界面测试、功能测试和用户场景测试。
-白盒测试:对系统的内部结构和算法进行测试,以揭示隐藏的错误和异常情况。
主要包括语句覆盖、分支覆盖和路径覆盖等测试方法。
-灰盒测试:将黑盒测试和白盒测试相结合,同时验证系统功能和内部结构。
通过用户输入和系统输出,检查系统的状态和中间数据。
4.测试环境测试环境包括嵌入式开发板、经典测试工具、仿真器和调试器等。
具体的测试环境如下:-嵌入式开发板:使用ABC公司的嵌入式开发板作为测试目标。
- 经典测试工具:包括XUnit、Junit等测试工具。
-仿真器和调试器:使用ABC公司提供的仿真器和调试器来调试和分析嵌入式软件。
5.测试计划和进度测试计划是根据项目需求和测试目标制定的,其中包括测试任务、测试资源、测试用例、测试时间和测试评估方法等。
测试进度按照计划进行,包括准备测试环境、设计测试用例、执行测试、分析测试结果和编写测试报告等。
6.测试结果测试结果根据不同测试方法和技术进行分析和评估。
具体的测试结果如下:-黑盒测试:通过有效和无效的数据输入测试了系统的各个功能模块。
测试结果显示系统的功能和界面都正常工作,没有发现明显的错误和异常。
-白盒测试:采用了语句覆盖、分支覆盖和路径覆盖等方法对系统内部结构进行了详细测试。
测试结果显示系统的内部结构和算法都正常工作,覆盖率达到了预期要求。
-灰盒测试:结合了黑盒测试和白盒测试的优点,综合验证了系统的功能和内部结构。
测试结果显示系统在不同输入下都正常工作,没有发现明显的错误和异常。
7.测试总结和建议根据测试结果和评估分析,可以得出以下结论:-系统的功能和界面都正常工作,满足了项目需求和用户期望。
嵌入式软件测试方法精

1、前言跟着经济的发展和科技的进步 ,信息技术的发展令人类进入数字时代 ,而陪伴着计算机技术发展起来的嵌入式技术获取了巨大的发展 ,改变了人们的平时。
跟着对嵌入式产品对各方面的要求愈来愈高 ,对嵌入式产品的性能有着决定性影响的嵌入式软件的测试显得尤其重要。
嵌入式的目的是保证软件知足需求规格说明 ,与非嵌入式软件的测试目的是同样的。
系统无效是系统没有知足—个或多个正式需求规范中所要求的需求项 , 嵌入式软件有其特别的无效判断准则。
并且嵌入式软件对靠谱性的要求比较高。
安全性的缺点常常会致使灾害性的结果 ,即便是非安全性系统 ,因为大量量生产也会致使严重的经济损失。
这就要求对嵌入式系统 ,包含嵌入式软件、嵌入式硬件进行严格的测试、确认和考证。
一般来说 ,软件测试有 7 个基本阶段 ,即单元或模块测试、集成测试、外面、回归测试、统测试、查收测试、安装测试。
嵌入式软件测试在 4 个阶段长进行 , 即模块测试、集成测试、系统测试、硬件 / 软件集成测试。
前 3 个阶段合用于任何软件的测试 ,硬件 / 软件集成测试阶段是嵌入式软件所独有的 ,目的是考证嵌入式软件与其所控制的硬件设施可否正确地交互。
2、嵌入式软件测试环境嵌入式软件测试的测试环境主要有两种:1 目标环境测试 :鉴于目标的测试测试全面有效,可是耗费许多的经费和时间。
2 宿主环境测试 :鉴于宿主的测试代价较小 ,可是有些对环境要求高的功能和性能宿主机没法模拟 ,测试没法实现。
当前的趋向是把更多的测试转移到宿主环境中进行,把宿主环境测试没法实现的复杂和独到功能放在目标环境测试。
我们的要点是鉴于宿主环境的测试 ,鉴于目标环境的测试作为增补。
文档在两个环境中能够出现不一样的软件缺点 ,重要的是目标环境和宿主环境的测试内容有所选择。
在宿主环境中 ,能够进行逻辑或界面的测试、以及与硬件没关的测试。
在模拟或宿主环境中的测试耗费时间往常相对较少 ,用调试工具能够更快地达成调试和测试任务。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
嵌入式软件测试规范篇一:嵌入式软件测试和验证嵌入式软件测试和验证一、软件测试1.1定义1993 年 IEEE 对软件测试给出了一个综合的定义:①将系统化的、规范的、可度量的方法应用于软件的开发、运行和维护的过程,即将工程化应用于软件中;②是对①中所述方法的研究。
它指出软件工程是一种层次化的技术。
科学的测试是贯穿整个产品生命周期中的测试。
要突破原来对测试的理解,着眼于整个软件生存期,特别是着眼于编码以前各开发阶段的测试工作,以保证软件的质量。
1.2软件测试的真正目标软件测试的真正目标是寻找bug。
即使是在交付时间表很紧的情况下,采取一个步骤来想一下从哪里开始着手,这样,测试才会是最有效率的。
但即使在时间非常充足的情况下,也不可能测试出每一个bug,所以必须将测试划分优先级,划分的根据是基于产品目前的状态(新的,修改的或者只是纯漏洞)和对客户的可能影响而进行的最诚实的评估。
避免采用知道软件可以处理的测试数据和操作;测试人员的任务是在测试中扩大软件的边界。
在设计自动化测试时,也要避免“踩灭”失败条件的误区。
测试人员的任务不是创造大量的总是可以干净的成功运行的测试。
测试人员需要去寻找和理解故障条件。
不要浪费时间去想软件产品中是否存在bug。
它肯定有bug,并且不可能全部找出它们。
测试的目的是指望测试人员找出那些最有影响的bug。
必须要做的是,要从消极的角度考虑这些问题。
1.3软件测试的意义1.发现软件错误;2.有效定义和实现软件成分由低层到高层的组装过程;3.验证软件是否满足任务书和系统定义文档所规定的技术要求;4.为软件质量模型的建立提供依据;即软件测试包括“找错”、“组装”、“确认”和“评估”四个层次的作用。
1.4软件测试方法从不同的角度来看,可以将软件测试的方法分为以下几类:根据是否需要运行被测软件的角度,软件测试分为静态测试方法和动态测试方法。
根据在动态测试中是否需要了解被测软件代码结构的角度,又分为白盒测试和黑盒测试。
根据在静态测试中是否要了解源程序语法的角度,测试可分为语法测试和语义测试。
根据如何选择测试数据的角度,测试又可分为功能测试、结构测试和随机测试。
根据使用的测试数据的类型,测试又可分为确定性测试和随机测试等等。
图1 是软件测试方法的分类图。
图1软件测试分类图1.5软件测试的基本内容软件测试工作包括两个层次:1.测试工作的组织与管理,包括:制定测试方法与规范、控制测试进度、管理测试资源。
2.测试工作的实施,包括:编制符合标准的测试文档、研制测试环境、与开发组织协作实现各阶段的测试活动。
软件测试工作可以分为四个方面:1.测试管理。
测试小组是质量保证组织的一个成分,因此测试管理工作应被置于软件质量管理工作范围内。
2.测试计划。
独立的测试组织负责定义软件测试的方法与规范。
开发组织负责编制单元测试的计划和说明;测试组织主要负责编制其它各测试阶段的测试计划和说明。
3.测试实施。
测试实施组织的作用是:按测试计划与测试说明的定义对测试对象进行相应的测试;填写测试报告中相应的表格。
4.测试评审。
依据软件测试评审准则在各测试阶段评审时提交类型完整的测试文档。
1.6软件测试的标准组织者在指定范围内选择软件测试遵循的标准,并结合本软件系统的具体要求,使之贯彻到整个软件测试的计划、实现和管理过程之中。
根据标准,需要被明确的内容包括:测试阶段和测试文档类型。
可以从三个角度来划分测试阶段:面向测试操作类型的阶段划分、面向测试操作对象的阶段划分、面向测试实施者的阶段划分。
测试操作类型包括:调试、集成、确认、验证、组装、验收、操作等。
测试操作对象可以是:单元、部件、配置项、子系统、系统等。
测试实施者可以是:开发者、测试者、使用者、验收者等。
各类标准从不同角度定义测试评审阶段,而测试组织者可以在符合所选标准的同时,结合多个划分因素规定本系统的测试阶段。
各标准规定的测试文档类型也不尽相同。
如国标《软件产品开发文件编制指南》规定了两类测试文档:测试计划、测试分析报告;国标《计算机软件测试文件编制规范》定义了八类测试文档:测试计划、测试设计说明、测试用例说明、测试规程说明、测试项传递报告、测试日志、测试事件报告、测试总结报告 ; 《XXXX软件工程化技术文件》定义了三类测试文档:测试计划、测试说明、测试报告。
我们认为最后这种规定较易操作:因为,太少的测试文档类型不利于有步骤有层次地定义测试内容,也不利于测试用例和测试例程的良好表达;太多的测试文档类型易使测试组织陷入到繁杂的文档规范和编制中去;而第三种定义较为适中。
其中:测试计划在系统分析/设计阶段提交,着重定义测试的资源、范围、内容、安排、通过准则等;测试说明在测试计划明确后开始编制,针对软件需求和设计要求具体定义测试用例和测试规程;测试报告分析和总结测试结果,测试日志是其必要附件。
二、嵌入式软件测试和验证2.1嵌入式软件测试的独特性和必要性嵌入式系统在人类生活中发挥着重要的作用,包括飞行控制器这样的控制系统,以及洗衣机这样的家用电器。
目前,嵌入式系统中软件的比重越来越大,也越来越复杂,保证嵌入式软件的可靠性正面临严峻的挑战。
大多数软件测试方法都可以直接或间接地用于嵌入式软件的测试,但是由于操作系统的实时和嵌入式特性,嵌入式软件测试也面临一些特殊的问题。
虽然目前已经有一些针对嵌入式软件的测试和调试工具,但是在有些方面仍存在不足,包括许多任务操作系统的并发、非侵入式的测试和调试、嵌入式系统的软件抽象等。
对于嵌入式软件测试技术的研究人选测试工具有待开发,仍须要做很多进一步的工作。
软件测试的目的是保证软件满足需求规格说明。
系统失效是系统没有满足一个或多个正式需求规范中所要求的需求项。
嵌入式软件有其特殊的失效判定准则,但是,嵌入式软件测试/嵌入式测试或叫交叉测试(cross-test)的目的与非嵌入式软件是相同的。
在嵌入式系统设计中,软件正越来越多地取代硬件,以降低系统的成本,获得更大的灵活性,这就需要使用更好的测试方法和工具进行嵌入式和实时软件的测试。
通常嵌入式系统对可靠性的要求比较高。
嵌入式系统安全性的失效可能会导致灾难性的后果,即使是非安全性系统,由于大批量生产也会导致严重的经济损失。
这就要求对嵌入式系统,包括嵌入式软件进行严格的测试、确认和验证。
随着越来越多的领域使用软件和微处理器控制各种嵌入式设备,对日益复杂的嵌入式软件进行快速有效的测试愈加显得重要。
例如,航天飞机的飞行软件达 50 万行源代码,F-22 战斗机更达 150 多万行源代码,软件失效已成为系统瘫痪的主要原因。
根据美国国防部和NASA 的统计,当今武器系统和航天项目中的软件可靠性比硬件系统大约低一个数量级。
在工程应用中由软件引发的、震惊科技界的故障持续不断,在某些类型的设备中软件故障甚至远远超过了硬件,成为系统的主要故障源。
如何保障软件具有一定的可靠性以避免灾难性后果的发生,是当前计算机学科应该重点研究的问题。
2.2嵌入式软件测试环境软件测试环境包括设计环境、实施环境和管理环境。
软件测试设计环境指:编制测试计划/说明/报告及与测试有关的文件所基于的软/硬件设备和支持。
软件测试实施环境指:对软件系统进行各级测试所基于的软/硬件设备和支持。
测试实施环境包括被测软件的运行平台和用于各级测试的工具。
软件测试管理环境指:管理测试资源所基于的软/硬件设备和支持。
测试资源指测试活动所利用或产生的有形物质(如软件、硬件、文档)或无形财富(如人力、时间、测试操作等)。
广义的测试管理环境包含测试设计环境、测试实施环境,和专门的测试管理工具。
对软件测试环境的定义包括两个方面:折衷需求和实际条件来选择已有的测试工具;有重点地自行开发测试辅助工具。
软件测试必须依托工具,以便测试过程的自动/半自动执行和测试结果的自动/半自动评审和报告。
目前市场上测试工具分为三类:代码分析工具、自动/半自动测试过程管理工具和测试资源管理工具。
嵌入式软件与其他软件相比,它具有专用性,它只能在需求所指定的硬件平台上运行。
并且嵌入式软件的开发环境和运行环境是不一致的,因此即使宿主机环境下测试再充分,也不能说明在目标机环境下运行该软件就不出问题。
因而,嵌入式软件还面临着目标环境的测试。
这不仅增加了测试的代价,而且还带来了嵌入式软件的测试策略问题,即哪些测试分配到宿主机环境进行,哪些测试分配到目标机环境下进行。
嵌入式软件测试使用有效的测试策略是唯一的出路,它可以使开发的效率最大化,避免目标系统的瓶颈,使用在线仿真器节省昂贵的目标资源。
嵌入式系统开发环境被认为是主机平台,软件运行环境为目标平台。
相应的测试为 Host/Target测试或 cross-testing。
通常在主机环境执行多数的测试(即Host/Host),只是在最终确定测试结果和最后的系统测试才移植到目标环境,这样可以避免发生访问目标系统资源上的瓶颈,也可以减少在昂贵资源如在线仿真器上的费用。
另外,若目标系统的硬件由于某种原因而不能使用时,最后的确认测试可以推迟直到目标硬件可用,这为嵌入式软件的开发测试提供了弹性。
设计软件的可移植性是成功进行 Host/Target的先决条件,它通常可以提高软件的质量,并且对软件的维护大有益处。
有效采用 Host/Target 测试策略可极大地提高嵌入式软件开发测试的水平和效率,提高嵌入式软件的质量。
当在真实运行环境下进行测试是不可能的时候,仿真便成了一种有效的建立运行环境的手段。
软件驱动的仿真器是用来替代真实的运行环境,能提供真实运行环境中的各种功能模拟。
而在仿真器中运行的软件不会受到真实环境下的一些干扰。
由于仿真器是用于观察软件的运行状况,不是测量运行性能,所以不需要精确的性能测量。
实际上,真实环境下的随机性引起的性能变化要大于精确的性能测量和在仿真器上的类似的性能测量的不同,因此,仿真器能很好地工作,为软件测试提供运行模拟。
嵌入式软件的专用性决定了其测试需要专用的测试环境。
测试环境可分为宿主机软件仿真、在线仿真器(In Circuit Emulator)、目标机仿真。
由于受测试成本、效率、测试自动化程度和目标机的可用性等因素影响,这三种测试环境都各有利弊。
宿主机软件仿真是用软件构造一个嵌入式应用程序运行所需的仿真环境,能模拟执行目标机 CPU 的指令,还能模拟中断、I/O 命令等外部消息。
这种仿真方式需要对处理器有良好的定义,可仿真总线模型及处理器与外部设备的交互。
其优点是无须目标机硬件便可测试,灵活、方便;用软件仿真的手段可分清软、硬件各自的错误;可对测试过程编程;自动化程度较高;降低开发成本。
但也有不足,首先实时性受限,无法模拟真实硬设备之间的高速通信,此种仿真环境适用于软实时或无实时性要求的嵌入式系统。