網(wǎng)站首頁 編程語言 正文
前沿
單元測試(unit testing),是指對軟件中的最小可測試單元進(jìn)行檢查和驗(yàn)證。對于單元測試中單元的含義,一般來說,要根據(jù)實(shí)際情況去判定其具體含義,如C語言中單元指一個函數(shù),Java里單元指一個類,圖形化的軟件中可以指一個窗口或一個菜單等??偟膩碚f,單元就是人為規(guī)定的最小的被測功能模塊。單元測試是在軟件開發(fā)過程中要進(jìn)行的最低級別的測試活動,軟件的獨(dú)立單元將在與程序的其他部分相隔離的情況下進(jìn)行測試。
在網(wǎng)上找了找C語言都沒有類似java 的junit單元測試 ,反復(fù)測試自己寫的模塊非常費(fèi)勁,特別是交叉模塊測試的時候根本就無法弄
因?yàn)橐粋€程序只允許一個main方法,如果其他地方存在了,那么就會報(bào)錯,這就導(dǎo)致了測完A模塊想要測試B模塊就需要把A模塊測試的相關(guān)內(nèi)容刪除,這樣會出現(xiàn)什么問題呢? 如果后期我們對A模塊的內(nèi)容進(jìn)行了修改,那么是不是需要在重新寫一套測試Demo, 這樣非常浪費(fèi)時間和精力 ,沒辦法只能自己開發(fā)一套類似的,來協(xié)助本地開發(fā)進(jìn)行測試代碼
使用前提
自己必須有集合數(shù)據(jù)結(jié)構(gòu)和hash結(jié)構(gòu)
測試框架如下
#ifndef STUDY_TESTCORE_H
#define STUDY_TESTCORE_H
#include "../structure/charHash.h"
typedef int boolean;//定義一個布爾類型
#define TRUE 1
#define FALSE 0
#define EXECUTE_TEST_RUN_METHOD(method) void (*testMethod)() = method;testMethod();
typedef struct testCore{
HashMap *methodAll; // 方法集合
HashMap *methodAllState; //方法狀態(tài)
} TestCore;
extern TestCore *testCore;
void test_Run_MethodAll(void (*initMethod)());
void test_Run_Method(char *methodName,void (*initMethod)());
void addTestMethodName( char *methodName,void *method,boolean state) ;
#endif //STUDY_TESTCORE_H
#include "testcore.h"
#include "malloc.h"
#include "string.h"
TestCore *testCore = NULL;
//創(chuàng)建一個測試環(huán)境
TestCore *createTestCore() {
TestCore *testCore = (TestCore *) malloc(sizeof(TestCore));
testCore->methodAll = createHashMap(200);
testCore->methodAllState = createHashMap(200);
return testCore;
}
/**
*
* @param hash
* @param methodName 方法名
* @param method 需要運(yùn)行的方法
* @param state 方法狀態(tài)TRUE啟用 FALSE禁用
*/
void addTestMethodName( char *methodName,void *method,boolean state) {
if(testCore == NULL) {
testCore = createTestCore();
}
putHashMap(testCore->methodAll, methodName,method);
putHashMap(testCore->methodAllState, methodName,state);
}
/**
* 運(yùn)行指定的測試方法
* @param methodName
* @param initMethod
*/
void test_Run_Method(char *methodName,void (*initMethod)()) {
initMethod();//初始化方法
void *method = getHashMap(testCore->methodAll, methodName);
if(method != NULL) {
EXECUTE_TEST_RUN_METHOD(method)
}
}
/**
* 運(yùn)行所有的測試方法,如果方法狀態(tài)為FALSE則跳過
* @param initMethod
*/
void test_Run_MethodAll(void (*initMethod)()) {
initMethod();//初始化方法
HashMapIterator *pIterator = createHashMapIterator(testCore->methodAllState);
while(hasNextHashMapIterator(pIterator)) {
CharKvLinkedNode *pNode = nextHashMapIterator(pIterator);
if(pNode->value == (void *)TRUE) {
void *method = getHashMap(testCore->methodAll, pNode->key);
EXECUTE_TEST_RUN_METHOD(method)
}
}
}
測試方法編寫文件
注意: 測試文件的方法名稱不要一樣,否則后面會把前面的給頂替了
#ifndef STUDY_TESTMETHOD_H
#define STUDY_TESTMETHOD_H
#include "testcore.h"
void initMethod();
#endif //STUDY_TESTMETHOD_H
#include <stdio.h>
#include "testmethod.h"
void test_1(){
printf("test_1\n");
}
void test_2(){
printf("test_2\n");
}
void initMethod(){
addTestMethodName("test_1",test_1,TRUE);
addTestMethodName("test_2",test_2,TRUE);
}
驗(yàn)證
#include <stdio.h>
#include "unittest/testcore.h"
#include "unittest/testmethod.h"
int main() {
printf("==============test_Run_MethodAll=============\n");
//批量測試
test_Run_MethodAll(initMethod);
printf("==============test_Run_Method=============\n");
//點(diǎn)對點(diǎn)測試
test_Run_Method("test_1",initMethod);
return (0);
}
現(xiàn)在我就能隨心所欲的測試了,想測試那個模塊就測試那個模塊,而且還可批量測試
原文鏈接:https://blog.csdn.net/weixin_45203607/article/details/126660961
相關(guān)推薦
- 2023-05-14 Redis為什么默認(rèn)有16個數(shù)據(jù)庫問題_Redis
- 2022-06-24 SingleFlight模式的Go并發(fā)編程學(xué)習(xí)_Golang
- 2022-09-17 詳解python中靜態(tài)方法staticmethod用法_python
- 2023-01-01 C語言用fun函數(shù)實(shí)現(xiàn)兩個數(shù)的交換方式_C 語言
- 2022-08-30 Kotlin object的用法和內(nèi)存泄漏研究
- 2022-11-14 C語言?ffmpeg與sdl實(shí)現(xiàn)播放視頻同時同步時鐘詳解_C 語言
- 2022-11-14 開發(fā)板NFS掛載方案
- 2024-02-25 maven打包測試jar包沖突
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支