Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
okll00
rt-thread
提交
85d275b3
R
rt-thread
项目概览
okll00
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
5
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rt-thread
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
85d275b3
编写于
11月 30, 2018
作者:
M
MurphyZhao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[components/utilities][add] 增加测试框架 utest 代码
Signed-off-by:
N
MurphyZhao
<
d2014zjt@163.com
>
上级
bcd591c5
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
380 addition
and
0 deletion
+380
-0
components/utilities/utest/SConscript
components/utilities/utest/SConscript
+8
-0
components/utilities/utest/utest.c
components/utilities/utest/utest.c
+236
-0
components/utilities/utest/utest.h
components/utilities/utest/utest.h
+69
-0
components/utilities/utest/utest_assert.h
components/utilities/utest/utest_assert.h
+36
-0
components/utilities/utest/utest_log.h
components/utilities/utest/utest_log.h
+31
-0
未找到文件。
components/utilities/utest/SConscript
0 → 100644
浏览文件 @
85d275b3
from
building
import
*
cwd
=
GetCurrentDir
()
src
=
Glob
(
'*.c'
)
CPPPATH
=
[
cwd
]
group
=
DefineGroup
(
'utest'
,
src
,
depend
=
[],
CPPPATH
=
CPPPATH
)
Return
(
'group'
)
components/utilities/utest/utest.c
0 → 100644
浏览文件 @
85d275b3
/*
* Copyright (c) 2006-2018, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2018-11-19 MurphyZhao the first version
*/
#include "utest.h"
#include <rtthread.h>
#include <finsh.h>
#undef DBG_SECTION_NAME
#undef DBG_LEVEL
#undef DBG_COLOR
#undef DBG_ENABLE
#define DBG_ENABLE
#define DBG_SECTION_NAME "utest"
#ifdef UTEST_DEBUG
#define DBG_LEVEL DBG_LOG
#else
#define DBG_LEVEL DBG_INFO
#endif
#define DBG_COLOR
#include <rtdbg.h>
#if RT_CONSOLEBUF_SIZE < 256
#error "RT_CONSOLEBUF_SIZE is less than 256!"
#endif
static
utest_tc_export_t
tc_table
=
RT_NULL
;
static
rt_size_t
tc_num
;
static
struct
utest
local_utest
=
{
UTEST_PASSED
,
0
,
0
};
#if defined(__ICCARM__) || defined(__ICCRX__)
/* for IAR compiler */
#pragma section="UtestTcTab"
#endif
int
utest_init
(
void
)
{
/* initialize the utest commands table.*/
#if defined(__CC_ARM)
/* ARM C Compiler */
extern
const
int
UtestTcTab
$$
Base
;
extern
const
int
UtestTcTab
$$
Limit
;
tc_table
=
(
utest_tc_export_t
)
&
UtestTcTab
$$
Base
;
tc_num
=
(
utest_tc_export_t
)
&
UtestTcTab
$$
Limit
-
tc_table
;
#elif defined (__ICCARM__) || defined(__ICCRX__)
/* for IAR Compiler */
tc_table
=
(
utest_tc_export_t
)
__section_begin
(
"UtestTcTab"
);
tc_num
=
(
utest_tc_export_t
)
__section_end
(
"UtestTcTab"
)
-
tc_table
;
#elif defined (__GNUC__)
/* for GCC Compiler */
extern
const
int
__rtatcmdtab_start
;
extern
const
int
__rtatcmdtab_end
;
tc_table
=
(
utest_tc_export_t
)
&
__rtatcmdtab_start
;
tc_num
=
(
utest_tc_export_t
)
&
__rtatcmdtab_end
-
tc_table
;
#endif
/* defined(__CC_ARM) */
LOG_D
(
"[ ] total utest testcase num: (%d)"
,
tc_num
);
return
tc_num
;
}
INIT_COMPONENT_EXPORT
(
utest_init
);
static
void
utest_tc_list
(
void
)
{
rt_size_t
i
=
0
;
LOG_D
(
"Commands list : "
);
for
(
i
=
0
;
i
<
tc_num
;
i
++
)
{
LOG_D
(
"%s"
,
tc_table
[
i
].
name
);
}
}
MSH_CMD_EXPORT_ALIAS
(
utest_tc_list
,
utest_tc_list
,
output
all
utest
testcase
);
static
char
*
file_basename
(
const
char
*
file
)
{
char
*
ptr
=
RT_NULL
;
char
*
rst
=
RT_NULL
;
char
*
file_bak
=
rt_strdup
(
file
);
uint8_t
len
=
0
;
if
((
ptr
=
strrchr
(
file_bak
,
'\\'
))
!=
RT_NULL
||
(
ptr
=
strrchr
(
file_bak
,
'/'
))
!=
RT_NULL
)
{
rst
=
ptr
;
}
else
{
rst
=
file_bak
;
}
len
=
rst
-
file_bak
;
if
(
rst
!=
file
)
{
file_bak
[
len
]
=
'\0'
;
if
((
ptr
=
strrchr
(
file_bak
,
'\\'
))
!=
RT_NULL
||
(
ptr
=
strrchr
(
file_bak
,
'/'
))
!=
RT_NULL
)
{
rst
=
ptr
;
}
else
{
rst
=
file_bak
;
}
len
=
rst
-
file_bak
;
}
rt_free
(
file_bak
);
len
=
len
!=
0
?
len
+
1
:
len
;
return
(
char
*
)(
file
+
len
);
}
static
void
utest_run
(
const
char
*
utest_name
)
{
rt_size_t
i
=
0
;
LOG_D
(
"[ ] total utest testcase num: (%d)"
,
tc_num
);
LOG_I
(
"[==========] [ utest ] started"
);
while
(
i
<
tc_num
)
{
if
(
utest_name
&&
rt_strcmp
(
utest_name
,
tc_table
[
i
].
name
))
{
i
++
;
continue
;
}
if
(
tc_table
[
i
].
init
!=
RT_NULL
)
{
tc_table
[
i
].
init
();
}
LOG_I
(
"[----------] [ testcase ] (%s) started"
,
tc_table
[
i
].
name
);
tc_table
[
i
].
tc
();
if
(
local_utest
.
failed_num
==
0
)
{
LOG_I
(
"[ PASSED ] [ result ] testcase (%s)"
,
tc_table
[
i
].
name
);
}
else
{
LOG_I
(
"[ FAILED ] [ result ] testcase (%s)"
,
tc_table
[
i
].
name
);
}
LOG_I
(
"[----------] [ testcase ] (%s) finished"
,
tc_table
[
i
].
name
);
if
(
tc_table
[
i
].
cleanup
!=
RT_NULL
)
{
tc_table
[
i
].
cleanup
();
}
i
++
;
}
LOG_I
(
"[==========] [ utest ] finished"
);
}
static
void
utest_testcase_run
(
int
argc
,
char
**
argv
)
{
char
utest_name
[
UTEST_NAME_MAX_LEN
];
if
(
argc
==
1
)
{
utest_run
(
RT_NULL
);
}
else
if
(
argc
==
2
)
{
rt_memset
(
utest_name
,
0x0
,
sizeof
(
utest_name
));
rt_strncpy
(
utest_name
,
argv
[
1
],
sizeof
(
utest_name
)
-
1
);
utest_run
(
utest_name
);
}
else
{
LOG_E
(
"[ error ] at (%s:%d), in param error."
,
__func__
,
__LINE__
);
}
}
MSH_CMD_EXPORT_ALIAS
(
utest_testcase_run
,
utest_run
,
utest_run
[
testcase
name
]);
utest_t
utest_handle_get
(
void
)
{
return
(
utest_t
)
&
local_utest
;
}
void
utest_unit_run
(
test_unit_func
func
,
const
char
*
unit_func_name
)
{
// LOG_I("[==========] utest unit name: (%s)", unit_func_name);
local_utest
.
error
=
UTEST_PASSED
;
local_utest
.
passed_num
=
0
;
local_utest
.
failed_num
=
0
;
func
();
}
void
utest_assert
(
int
value
,
const
char
*
file
,
int
line
,
const
char
*
func
,
const
char
*
msg
)
{
if
(
!
(
value
))
{
local_utest
.
error
=
UTEST_FAILED
;
local_utest
.
failed_num
++
;
LOG_E
(
"[ ASSERT ] [ unit ] at (%s); func: (%s:%d); msg: (%s)"
,
file_basename
(
file
),
func
,
line
,
msg
);
}
else
{
LOG_D
(
"[ OK ] [ unit ] (%s:%d) is passed"
,
func
,
line
);
local_utest
.
error
=
UTEST_PASSED
;
local_utest
.
passed_num
++
;
}
}
void
utest_assert_string
(
const
char
*
a
,
const
char
*
b
,
rt_bool_t
equal
,
const
char
*
file
,
int
line
,
const
char
*
func
,
const
char
*
msg
)
{
if
(
a
==
RT_NULL
||
b
==
RT_NULL
)
{
utest_assert
(
0
,
file
,
line
,
func
,
msg
);
}
if
(
equal
)
{
if
(
rt_strcmp
(
a
,
b
)
==
0
)
{
utest_assert
(
1
,
file
,
line
,
func
,
msg
);
}
else
{
utest_assert
(
0
,
file
,
line
,
func
,
msg
);
}
}
else
{
if
(
rt_strcmp
(
a
,
b
)
==
0
)
{
utest_assert
(
0
,
file
,
line
,
func
,
msg
);
}
else
{
utest_assert
(
1
,
file
,
line
,
func
,
msg
);
}
}
}
components/utilities/utest/utest.h
0 → 100644
浏览文件 @
85d275b3
/*
* Copyright (c) 2006-2018, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2018-11-19 MurphyZhao the first version
*/
#ifndef __UTEST_H__
#define __UTEST_H__
#include <rtthread.h>
#include "utest_log.h"
#define UTEST_SW_VERSION "0.0.1"
enum
utest_error
{
UTEST_PASSED
=
0
,
UTEST_FAILED
=
1
,
UTEST_SKIPPED
=
2
};
typedef
enum
utest_error
utest_err_e
;
struct
utest
{
utest_err_e
error
;
uint32_t
passed_num
;
uint32_t
failed_num
;
};
typedef
struct
utest
*
utest_t
;
struct
utest_tc_export
{
const
char
*
name
;
rt_err_t
(
*
init
)(
void
);
void
(
*
tc
)(
void
);
rt_err_t
(
*
cleanup
)(
void
);
};
typedef
struct
utest_tc_export
*
utest_tc_export_t
;
typedef
void
(
*
test_unit_func
)(
void
);
#define TC_LOG_I(...) LOG_I(__VA_ARGS__)
#define TC_LOG_D(...) LOG_D(__VA_ARGS__)
#define TC_LOG_E(...) LOG_E(__VA_ARGS__)
#define TC_LOG_W(...) LOG_W(__VA_ARGS__)
void
utest_unit_run
(
test_unit_func
func
,
const
char
*
unit_func_name
);
utest_t
utest_handle_get
(
void
);
#define UTEST_NAME_MAX_LEN (128u)
#define UTEST_TC_EXPORT(testcase, name, init, cleanup) \
RT_USED static const struct utest_tc_export _utest_testcase \
SECTION("UtestTcTab") = \
{ \
name, \
init, \
testcase, \
cleanup \
}
#define UTEST_UNIT_RUN(test_unit_func) \
utest_unit_run(test_unit_func, #test_unit_func); \
if(utest_handle_get()->failed_num != 0) return;
#endif
components/utilities/utest/utest_assert.h
0 → 100644
浏览文件 @
85d275b3
/*
* Copyright (c) 2006-2018, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2018-11-19 MurphyZhao the first version
*/
#ifndef __UTEST_ASSERT_H__
#define __UTEST_ASSERT_H__
#include "utest.h"
#include <rtthread.h>
void
utest_assert
(
int
value
,
const
char
*
file
,
int
line
,
const
char
*
func
,
const
char
*
msg
);
void
utest_assert_string
(
const
char
*
a
,
const
char
*
b
,
rt_bool_t
equal
,
const
char
*
file
,
int
line
,
const
char
*
func
,
const
char
*
msg
);
#define __utest_assert(value, msg) utest_assert(value, __FILE__, __LINE__, __func__, msg)
#define uassert_true(value) __utest_assert(value, "(" #value ") is false")
#define uassert_false(value) __utest_assert(!(value), "(" #value ") is true")
#define uassert_null(value) __utest_assert((value) == NULL, "(" #value ") is not null")
#define uassert_not_null(value) __utest_assert((value) != NULL, "(" #value ") is null")
#define uassert_int_equal(a, b) __utest_assert((a) == (b), "(" #a ") not equal to (" #b ")")
#define uassert_int_not_equal(a, b) __utest_assert((a) != (b), "(" #a ") equal to (" #b ")")
#define uassert_str_equal(a, b) utest_assert_string((const char*)(a), (const char*)(b), RT_TRUE, __FILE__, __LINE__, __func__, "string not equal")
#define uassert_str_not_equal(a, b) utest_assert_string((const char*)(a), (const char*)(b), RT_FALSE, __FILE__, __LINE__, __func__, "string equal")
#define uassert_in_range(value, min, max) __utest_assert(((value >= min) && (value <= max)), "(" #value ") not in range("#min","#max")")
#define uassert_not_in_range(value, min, max) __utest_assert(!((value >= min) && (value <= max)), "(" #value ") in range("#min","#max")")
#endif
/* __UTEST_ASSERT_H__ */
components/utilities/utest/utest_log.h
0 → 100644
浏览文件 @
85d275b3
/*
* Copyright (c) 2006-2018, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2018-11-19 MurphyZhao the first version
*/
#ifndef __UTEST_LOG_H__
#define __UTEST_LOG_H__
#define UTEST_DEBUG
#undef DBG_SECTION_NAME
#undef DBG_LEVEL
#undef DBG_COLOR
#undef DBG_ENABLE
#define DBG_ENABLE
#define DBG_SECTION_NAME "testcase"
#ifdef UTEST_DEBUG
#define DBG_LEVEL DBG_LOG
#else
#define DBG_LEVEL DBG_INFO
#endif
#define DBG_COLOR
#include <rtdbg.h>
#endif
/* __UTEST_LOG_H__ */
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录