分享一个自己量产项目上的集成测试软件MTTEST

简介: 分享一个自己量产项目上的集成测试软件MTTEST

分享一个刚毕业的时候写的一个量产测试工具吧,采用的是C语言来编写,刚开始应用在Linux和Android平台上,后面通过移植也用在单片机上,使用起来非常简单,让我们来看看怎么回事。


一、主程序源码分析

int main(void)
{
  s32 i ;
  //初始化测试系统
  INIT_TEST_SYSTEM();
  //定义头指针,初始化头节点
  INIT_WORK(work_node);
  for(i = ZERO ; i < NR(work_Register) ; i++) 
  {
    //实现工作任务的注册
    REGISTER_WORK(work_node , create_cwork(work_Register[i].work_num ,work_Register[i].work_name , work_Register[i].work_handler));
  }
  //调度工作任务,编号从小到大排序
  SCHEDULING_WORK(work_node,Positive,NR(work_Register));
  while(True)
  {
    ;
  }
  DESTROY_WORK(work_node,work_Register);
  return SUCCESS ;
}

这段程序的核心框架由四部分组成:

  • INIT_WORK
  • REGISTER_WORK
  • SCHEDULING_WORK
  • DESTROY_WORK

如果你不去追,你可能以为这是四个定义好的函数,别被它的表面欺骗了,其实它们是宏,宏的下面一级才是函数的实现:

#define __INIT_WORK(_work)            \
do{                            \
        _work =Init_cwork(_work);        \
}while(0)
#define INIT_WORK(work_node) \
     _work work_node = NULL ; \
    __INIT_WORK(work_node);
#define REGISTER_WORK(__work,new_work) \
Register_work_fuc(__work,new_work);
#define SCHEDULING_WORK(work_node,direction,array_size) \
Run_Priority_work(work_node,direction,array_size);
#define DESTROY_WORK(work_node,array) \
        work_node =Destroy_work(work_node ,array);

各个子函数的实现:

//初始化一个子任务
_work Init_cwork();
//创建一个子任务
_work create_cwork(s32 work_num,pchar work_name ,work_fun work_fuc);
//注册子任务
No_returnRegister_work_fuc(_work __work,_work new_work);
//查找子任务的编号
s32 Find_Work_Num(_work headler,s32 work_num);
//查找子任务的名称
pchar Find_Work_Name(_work headler,pchar work_name);
//执行子任务----根据任务名称来执行
s32 Run_work_for_work_name(_work headler,pchar work_name);
//销毁一个子任务
s32 Destroy_cwork(_work headler,pchar work_name);
//销毁全部任务
_work Destroy_work(_work headler,_work array);
//工作优先级调度执行--->工作编号小的优先级高,依次类推
s32 Run_Priority_work(_work handler,s32 direction,const s32 work_array_size);

通过宏调用各个子函数完成任务的初始化,注册、执行、销毁,这个过程是由一个链表来实现的:

typedefstruct __Work
{
//任务编号
//根据任务编号决定工作任务的优先级
//编号越小,优先级越高
    s32 work_num ;
//任务名称
    pchar work_name ;
//根据相应的任务名称,处理相应的任务
  void(*work_handler)(int);
struct __Work *next;
}work;
typedef work * _work ;

由于这是一个集成测试工具,所以存在着任务的并行执行,所以当执行一个任务的时候其实就创建了一条线程,这个过程是在Run_Priority_work里实现的。

s32 Run_Priority_work(_work handler,s32 direction,const s32 work_array_size)
{
  s32 count = 0 ;
  s32 i ;
  assert(handler != NULL);
  _work temp = handler->next ;
  s32 Curent_node_Array[work_array_size];
  while(temp != NULL){
    Curent_node_Array[count] = temp->work_num ;
    temp = temp->next ;
    if(count < work_array_size)
      count++ ;
  }
  Sort_work_num(Curent_node_Array,NR(Curent_node_Array),direction) ;
  for(i = 0 ; i < NR(Curent_node_Array) ; i++)
    Run_work_for_work_num(handler,Curent_node_Array[i]);
  return SUCCESS ;
}

核心的部分也就这些了,接下来讲讲怎么用吧。

二、使用MTTEST实现并行测试项


main.c的代码一句都不用动,如果你要添加一个并行的测试项目,只需要在结构体数组里声明好,定义好测试任务函数就可以了,具体使用方法如下:

//按键测试
intTpad_Key_Test(int work_num);
//Gsensor测试
intTpad_Gsensor_Test(int work_num);
//时钟测试
int RTC_Test(int work_num);
//电池电量测试
intBattery_Capacity_Test(int work_num);
//电池状态测试
intBattery_Status_Test(int work_num);
//内存测试
int DDR_Test(int work_num);
//EMMC测试
int EMMC_Test(int work_num);
//SD卡测试
int SD_Test(int work_num);
//WIFI MAC地址读取测试
int NVRAM_WIFI_MAC_ADDRESS_READ_TEST(int work_num);
//WIFI ssid获取测试
int WIFI_SSID_Test(int work_num);
//LCD RGB测试
int LCD_Test(int work_num);
//初始化测试系统
int INIT_TEST_SYSTEM();
//Camera旋转按键测试
int camera_rotate_test(int work_num);
//结构体数组描述:
/*
    ep:
    {1,"LCD_Test",LCD_Test},
    1表示任务编号,同时也表示在LCD的哪一行进行显示
    "LCD_Test"表示任务名称
    LCD_Test表示任务执行函数
*/
work work_Register[]=
{
{1,"Tpad_Key_Test",Tpad_Key_Test},
{2,"Tpad_Gsensor_Test",Tpad_Gsensor_Test},
{3,"RTC_Test",RTC_Test},
{4,"Battery_Capacity_Test",Battery_Capacity_Test},
{5,"Battery_Status_Test",Battery_Status_Test},
{6,"DDR_Test",DDR_Test},
{7,"EMMC_Test",EMMC_Test},
{8,"SD_Test",SD_Test},
{9,"NVRAM_WIFI_MAC_ADDRESS_READ_TEST",NVRAM_WIFI_MAC_ADDRESS_READ_TEST},
{10,"WIFI_SSID_Test",WIFI_SSID_Test},
#ifndef __PLAN_A
{11,"camera_rotate_test",camera_rotate_test},
#endif
{12,"LCD_Test",LCD_Test},
};

预知详情,请详细看看我分享的项目代码,注释很详细。

三、分享链接


链接:https://pan.baidu.com/s/1rPjS2r1-JgmzhF1nFhc0Kg
提取码:dlv3

往期分享

分享一个非常有用且简单C语言测试框架

C语言strstr函数解析自定义协议参数

深入浅出剖析C语言函数指针与回调函数

C语言数组结合位运算实战-位移与查表

目录
相关文章
|
1月前
|
人工智能 测试技术 项目管理
测试不再碎片化:AI智能体平台「项目资料套件」功能上线!
在实际项目中,需求文档分散、整理费时、测试遗漏等问题常困扰测试工作。霍格沃兹推出AI智能体测试平台全新功能——项目资料套件,可将多个关联文档打包管理,并一键生成测试用例,提升测试完整性与效率。支持套件创建、文档关联、编辑删除及用例生成,适用于复杂项目、版本迭代等场景,助力实现智能化测试协作,让测试更高效、更专业。
|
12天前
|
安全 Java 数据库
SpringSecurity认证授权及项目集成
本文介绍了基于Spring Security的权限管理框架,涵盖认证、授权与鉴权核心概念,通过快速入门示例演示集成流程,并结合数据库实现用户认证。进一步扩展实现正常登录,JWT登录及鉴权管理器,实现灵活的安全控制,适用于前后端分离项目中的权限设计与实践。
133 3
|
1月前
|
资源调度 JavaScript 前端开发
在Vue 3项目中集成Element Plus组件库的步骤
总结起来,在集成过程当中我们关注于库本身提供功能与特性、环境搭建与依赖管理、模块化编程思想以及前端工程化等方面知识点;同时也涵盖前端性能优化(比如上文提及“按需加载”)与定制化开发(例如“自定义主题”)等高级话题.
118 16
|
运维 监控 安全
Cisco ISR 4000 Series IOS XE 17.18.1a ED 发布 - 思科 4000 系列集成服务路由器 IOS XE 系统软件
Cisco ISR 4000 Series IOS XE 17.18.1a ED - 思科 4000 系列集成服务路由器 IOS XE 系统软件
31 0
|
19天前
|
测试技术 UED 开发者
性能测试报告-用于项目的性能验证、性能调优、发现性能缺陷等应用场景
性能测试报告用于评估系统性能、稳定性和安全性,涵盖测试环境、方法、指标分析及缺陷优化建议,是保障软件质量与用户体验的关键文档。
|
3月前
|
JSON 分布式计算 大数据
springboot项目集成大数据第三方dolphinscheduler调度器
springboot项目集成大数据第三方dolphinscheduler调度器
151 3
|
3月前
|
Java 关系型数据库 数据库连接
Spring Boot项目集成MyBatis Plus操作PostgreSQL全解析
集成 Spring Boot、PostgreSQL 和 MyBatis Plus 的步骤与 MyBatis 类似,只不过在 MyBatis Plus 中提供了更多的便利功能,如自动生成 SQL、分页查询、Wrapper 查询等。
281 3
|
3月前
|
Java 关系型数据库 MySQL
springboot项目集成dolphinscheduler调度器 实现datax数据同步任务
springboot项目集成dolphinscheduler调度器 实现datax数据同步任务
365 2
|
3月前
|
分布式计算 Java 大数据
springboot项目集成dolphinscheduler调度器 可拖拽spark任务管理
springboot项目集成dolphinscheduler调度器 可拖拽spark任务管理
173 2