vulkan游戏引擎test_manager实现

1.test_manager.h

#pragma once

#include <defines.h>

#define BYPASS 2

typedef u8 (*PFN_test)();

void test_manager_init();

void test_manager_register_test(PFN_test, char* desc);

void test_manager_run_tests();

2.test_manager.c

#include "test_manager.h"

#include <containers/darray.h>

#include <core/logger.h>

#include <core/kstring.h>

#include <core/clock.h>

typedef struct test_entry{

PFN_test func;

char* desc;

}test_entry;

static test_entry* tests;

void test_manager_init()

{

tests = darray_create(test_entry);

}

void test_manager_register_test(u8 (*PFN_test)(), char* desc)

{

test_entry e;

e.func = PFN_test;

e.desc = desc;

darray_push(tests,e);

}

void test_manager_run_tests()

{

u32 passed = 0;

u32 failed = 0;

u32 skipped = 0;

u32 count = darray_length(tests);

clock total_time;

clock_start(&total_time);

for(u32 i = 0; i<count;++i)

{

clock test_time;

clock_start(&test_time);

u8 result = tests[i].func();

clock_update(&test_time);

if(result == true)

{

++passed;

}else if(result == BYPASS)

{

KWARN("[SKIPPED]: %s",tests[i].desc);

++skipped;

}else

{

KERROR("[FAILED]: %s",tests[i].desc);

++failed;

}

char status[20];

string_format(status, failed ? "*** %d FAILED ***" : "SUCCESS",failed);

clock_update(&total_time);

KINFO("Executed %d of %d (skipping %d) %s (%.6f sec / %.6f sec total", i + 1,count, skipped,status,test_time.elapsed,total_time.elapsed);

}

clock_stop(&total_time);

KINFO("Result: %d passed,%d failed,%d skipped.",passed,failed,skipped);

}

相关推荐
宝贝儿好1 分钟前
【LLM】第一章:分词算法BPE、WordPiece、Unigram、分词工具jieba
人工智能·python·深度学习·神经网络·算法·语言模型·自然语言处理
渡我白衣2 分钟前
运筹帷幄——在线学习与实时预测系统
人工智能·深度学习·神经网络·学习·算法·机器学习·caffe
好家伙VCC2 分钟前
**InfluxDB实战进阶:基于Golang的高性能时序数据采集与可视化方
java·开发语言·后端·python·golang
斌味代码3 分钟前
Java SpringBoot 微服务实战:企业级架构设计与性能调优完全指南
java·spring boot·微服务
colus_SEU3 分钟前
SVM 的终极视角:合页损失函数 (Hinge Loss) 与正则化
算法·机器学习·支持向量机
好家伙VCC4 分钟前
**发散创新:基于Go语言的服务网格实践与流量治理实战**在微服务架构日益复杂的今天,**服务网格(S
java·python·微服务·架构·golang
汀、人工智能4 分钟前
[特殊字符] 第71课:爬楼梯
数据结构·算法·数据库架构·图论·bfs·爬楼梯
MicroTech20255 分钟前
微算法科技(NASDAQ :MLGO)量子启发式算法与CNN、Transformer结合,实现端到端彩色图像分割
科技·算法·启发式算法
X journey6 分钟前
机器学习进阶(14):交叉验证
人工智能·算法·机器学习
lolo大魔王11 分钟前
Go语言的循环语句、判断语句、通道选择语句
开发语言·算法·golang