前言

文章内容为本人这三年来在嵌入式软件测试(黑盒)上的一些积累吧,说起来也挺快的,毕业三年的时间就这样过去了,在两家公司工作过(现在这家是第二家),这几年的测试项目基本都是围绕着嵌入式软件,同时需要兼顾测试App端、Web端功能、Web后端接口(Postman),只是测试业务重心还是在嵌入式软件上。

为什么测试的这么杂呢,其实这些全部加起来只是一个产品,只是因为目前就只有我一个测试,所以整套系统都是由我一个人来测。

就拿我现在这家公司做的一个视频会议系统来说吧,整套系统包含有硬终端(Linux端)、App端、Web端(用于后台账户/会议管理等)、PC端组成。

接触过嵌入式软件测试的同学应该都明白这些事,下面我就来说说自己这几年对嵌入式软件测试的理解和看法吧,欢迎留言补充或讨论,勿喷喔~

什么是嵌入式系统?

嵌入式系统是一种“完全嵌入受控器件内部,为特定应用而设计的专用计算机系统”。

嵌入式系统是“用于控制,监视或辅助操作机器和设备的装置”。

嵌入式系统还可以定义为“以应用为中心,以计算机技术为基础,软硬件可裁剪,功能、可靠性、成本、体积、功耗要求严格的专用计算机系统。”

嵌入式系统由嵌入式硬件和嵌入式软件两部分组成,硬件是支撑,软件是灵魂。

嵌入式系统按实时性分类,可分为非实时性,软实时性和硬实时性。

其中硬实时性是指系统对响应时间有严格要求,如果响应时间不能满足,就要引起系统崩溃或致命错误;软实时性是指系统对响应时间有要求,但是如果系统响应时间不能满足,不会导致系统出现致命的错误或崩溃。

什么是嵌入式软件?

嵌入式软件是基于嵌入式系统设计的软件,它是计算机软件的一种,同样由程序及其文档组成,可分为操作系统,支撑软件,应用软件三大类,是嵌入式系统的重要组成部分。

说通俗易懂一点就是一套安装在带有linux系统的PCB板子上的软件。像这样:

嵌入式软件的特征:

·系统内核小

· 专用性强

· 系统精简

· 高实时性操作系统

· 基于硬件和软件的相辅相成

· 与商用软件测试异同点

此文单从黑盒测试的角度来讲。

相同点

嵌入式软件测试和商用软件测试的目的和原则是相同的,都是为了找Bug、跟踪Bug、验证Bug,使产品实现需求文档上功能,满足用户需求。

不同点

需要的测试环境不同。

测试嵌入式软件的时候,你需要准备的环境是一整套设备,里面可能包含电源、网线、高清线(各种视频传输线)、交换机、摄像头、麦克风、U盘、路由器等等。

测试商用软件可能就是一个安装包,或者是一个测试URL,你需要准备的可能就是一个电脑或者一部手机。

测试的思维不同(要做到出现问题先自检)。

这里的测试思维并不是说设计测试用例时需要的思维方式,而是在定位Bug的时候,思维不一样。

在测试嵌入式软件的时候,如果出现某个功能无法实现,有可能是确实是功能实现问题,有可能是内存问题,有可能是硬件支持问题,有可能是驱动问题,有可能是网络问题,有可能是硬件物理接口问题。

虽然看似这些问题与我无关,但是如果是硬件支持的问题,你抛出Bug,开发排查完之后发现是你自己没有按照规格接入所能支持的硬件,到时候尴尬的是不是你?

再比如POE网口如果没有接入支持POE的网线,造成问题是不是你的不专业了等等,我们既然是测试工程师,那就应该要有工程师的专业程度来完成工作。

在测试商用软件的时候,遇到功能无法实现,我们大部分情况下就是直接抛出Bug给开发,附带Bug截图、log和操作步骤,通常都好使。

需要的技能点不同

根据这几年的测试项目经验,发现嵌入式软件测试对计算机网络原理的应用比较频繁。

在测试嵌入式软件的时候,你要接入网线、进行网络配置、接入交换机、了解网络通信、数据传输等等……

也就是说嵌入式软件测试你需要的是(扎实的软件测试理论和测试方法+计算机网络相关基础知识)。

而测试商用软件的时候,由于环境搭建没有太复杂,涉及到计算机网络相关的知识比较少,需要的往往是扎实的软件测试理论和测试方法。

嵌入式软件测试的自身特点和测试困难:

· 目前系统资源有限

· 与硬件系统紧密关联

· 运行平台多样化

· 交叉式的测试模式

· 系统的安全性、可靠性、系统运行结果的正确性等

嵌入式软件的测试策略与一般的商用软件有很大的区别。

有人可能会问嵌入式软件测试难吗?跟商用软件测试相比哪个难度更高?

我感觉在黑盒测试中,嵌入式软件测试是要比商用软件测试难度高的,我只站在嵌入式软件的黑盒测试角度来发言。为什么这么说呢,我暂时只想到以下几点:

硬件平台不同导致测试难度增大,由于嵌入式软件是跟硬件平台紧密关联的,也就是说同一套软件,如果移植到另一个平台上,就要从头到尾的测试一遍,在工作量上就比商用软件大,出错几率也会提升,相应的测试难度也会提高一点。我就遇到一个项目需要跑在两个平台的情况。

测试环境导致测试难度增大,我可以很肯定的说,同一套设备在A环境操作正常,我只要换一个交换机,搭建一个B环境,就很有可能会出现Bug,所以有经验的嵌入式软件测试同学在遇到客诉的Bug时第一时间都是问当时的环境是什么,设备有哪些,操作步骤是什么?必要时采取将设备全部寄回来复现。

硬件平台性能导致测试难度增大,硬件平台的芯片性能是肯定没有电脑上的CPU这么吊的,所以在测试的时候,我们往往会出现一些硬件性能上的问题导致一些Bug偶现,这对我们测试人员来说,想要找到一个偶现的Bug是非常的难,需要采取工具来跟踪操作步骤打印log。

外接设备导致测试难度增大,生活中基本上的嵌入式软件都是需要外接其他的设备的,比如接入U盘、摄像头、麦克风等等,在测试时如果发现某个工作无法实现,我们需要从三个方面去考虑:

1、是不是软件的功能Bug;

2、是不是硬件物理接口损坏问题;

3、是不是接入的外设与软件协议有问题或者驱动有问题等等原因增加了测试难度。

最后一个导致测试难度大的原因就是嵌入式软件测试相对来说是比较独立于软件测试的,相关的资料也是比较少的,并不像商用软件测试一样,只要一搜索,就能找到测试方法和一些测试文章。嵌入式软件测试更多的是一个实战,每一个应用场所的嵌入式软件测试的思维方式不一样。

结尾

测试也是一个有技术难度的岗位,需要不断的积累经验,老手测试和新手测试最大的不同就是老手测试可以很快的定位和发现Bug,老手测试可以有更多的测试方法和测试策略去找到Bug,有更好的测试管理经验和业务能力。

祝各位同学在测试的道路上越来越好,一起加油哈!

在这里还是要推荐下我自己建的Python学习Q群:746506216,群里都是学Python的,如果你想学或者正在学习Python ,欢迎你加入,大家都是软件开发党,不定期分享干货(只有Python软件开发相关的),包括我自己整理的一份2022最新的Python进阶资料和零基础教学,欢迎进阶中和对Python感兴趣的小伙伴加入!

嵌入式软件测试的小结相关推荐

  1. 这几款嵌入式软件测试工具,好用到起飞~

    也许你陌生,但在智能物联网时代,人们会越来越关注嵌入式软件测试. 说起嵌入式软件测试,我们先快速了解一下嵌入式软件自身的特点.嵌入式软件具有实时性.内存空间有限.I/O通道少,而且要求功耗低.高可靠性 ...

  2. 嵌入式系统课堂小结5

    嵌入式系统课堂小结3.24 嵌入式Linux开发工具-gcc.gdb.make 学习目标:了解gdb 学习目标:编写makefile(.c–.o)–Linux内核 – makefile 自动生成:Cm ...

  3. 嵌入式软件测试——1.简介

    #百科介绍 一般来说,软件测试有7个基本阶段,即单元或模块测试.集成测试.外部功能测试.回归测试.系统测试.验收测试.安装测试.嵌入式软件测试在4个阶段上进行,即模块测试.集成测试.系统测试.硬件/软 ...

  4. 嵌入式软件测试的十大秘诀

    嵌入式软件测试的十大秘诀 <script type="text/javascript"> </script><script language=&quo ...

  5. 嵌入式软件测试的基本方法

    1.引言 随着数字化时代的到来,大量系统架构复杂.功能日益强大的嵌入式系统正不断进入市场,应用也日趋复杂,这对嵌人式软件的开发技术和测试技术提出了更高的要求.嵌人式系统的复杂性和集成度越来越高,其中的 ...

  6. 嵌入式软件测试(黑盒测试)-----三年嵌入式软件测试的理解

    前言 文章内容为本人这三年来在嵌入式软件测试(黑盒)上的一些积累吧,说起来也挺快的,毕业三年的时间就这样过去了,在两家公司工作过(现在这家是第二家),这几年的测试项目基本都是围绕着嵌入式软件,同时需要 ...

  7. 韦东山嵌入式开发板小结1

    韦东山嵌入式开发板小结1 一.连接[开发板-win10-虚拟机] 1.播放虚拟机VMware的ubuntu 16.04,设置win10和 虚拟机处于同一网段 >>>ipconfig ...

  8. 三年黑盒测试工程师对嵌入式软件测试的理解

    文章内容为本人这三年来在嵌入式软件测试(黑盒)上的一些积累吧,说起来也挺快的,毕业三年的时间就这样过去了,在两家公司工作过(现在这家是第二家),这几年的测试项目基本都是围绕着嵌入式软件,同时需要兼顾测 ...

  9. 嵌入式 html 解析文件,嵌入式软件测试——方法、案例与模板详解.html.pdf

    前言 近几年 ,我国的软件测试行业进入 了飞速发展 阶段 ,在一个新兴行业刚刚发展 的时期 ,给 们带来的误 区也是最多的,例 如 :很 多 认为测试工作 简单 ,技术 门槛低 ,容易上手,也有 担心 ...

最新文章

  1. 1 字节的 utf-8 序列的字节 1 无效_字节码文件结构详解
  2. Jenkins:配置信息变更历史
  3. 利用被入侵的路由器迈入内网——抓包,利用路由器漏洞入侵,进行流量劫持...
  4. java护眼色是什么数据,护眼色的RGB值和颜色代码汇总
  5. php.ini-development和php.ini-production的区别
  6. BZOJ4293 Siano
  7. 逻辑回归预测事件发生的概率_通过逻辑回归,对信用卡申请数据使用卡方分箱法预测违约率建模...
  8. AD转换中参考电压的作用 .
  9. 学习EXT第九日:表单入门
  10. 解决Android SDK Manager更新、下载速度慢
  11. ERP实施过程中的沟通管理研究
  12. Android 融云SDK-即时通讯IM(附源码)
  13. 无人机怎么设定航线_飞行航线设置方法及装置与流程
  14. 在线广告系统的架构变迁
  15. 电脑网速慢怎么办?手把手教你提升网速
  16. websocket 实现长连接原理
  17. [FJOI 2016]bzoj 4408 神秘数 - 线段树
  18. 一位苦读6年终于毕业的博士说出了读博的四个陷阱
  19. 计算机考研【调剂心得体会】,给学弟学妹们的一些经验感想(希望对你们有所帮助)
  20. 聊聊学习计算机的硬实力和软能力

热门文章

  1. 电脑微信的文件在哪里?单独导出某个人的微信聊天记录教程
  2. 计算机专业应届生简历英语作文,计算机专业英文简历模板范文六篇
  3. ajax上传文件(javaweb)
  4. 144hz刷新率到底有多快?看看这两款电竞屏就知道了
  5. 模拟实现atoi函数
  6. PMBOK史上最大的改版,你知道到底有什么精华嘛?
  7. Hi3798日志分析-海思
  8. sas软件使用mysql吗_图解SAS软件统计分析(一):基本知识和界面操作
  9. ❤️Android 性能优化之启动优化❤️
  10. 云服务器+ngrok搭建内网穿透服务(只有公网ip无域名)