Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
6bd9758e
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6bd9758e
编写于
3月 16, 2016
作者:
E
Erik Skultety
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tests: Add a new test for logging outputs parser
Test for parser's functionality.
上级
814b2ec6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
45 addition
and
4 deletion
+45
-4
tests/virlogtest.c
tests/virlogtest.c
+45
-4
未找到文件。
tests/virlogtest.c
浏览文件 @
6bd9758e
...
@@ -25,6 +25,7 @@
...
@@ -25,6 +25,7 @@
struct
testLogData
{
struct
testLogData
{
const
char
*
str
;
const
char
*
str
;
int
count
;
bool
pass
;
bool
pass
;
};
};
...
@@ -42,29 +43,69 @@ testLogMatch(const void *opaque)
...
@@ -42,29 +43,69 @@ testLogMatch(const void *opaque)
return
0
;
return
0
;
}
}
static
int
testLogParseOutputs
(
const
void
*
opaque
)
{
int
ret
=
-
1
;
const
struct
testLogData
*
data
=
opaque
;
ret
=
virLogParseOutputs
(
data
->
str
);
if
(
ret
<
0
)
{
if
(
!
data
->
pass
)
{
VIR_TEST_DEBUG
(
"Got expected error: %s
\n
"
,
virGetLastErrorMessage
());
virResetLastError
();
ret
=
0
;
goto
cleanup
;
}
}
else
if
(
ret
!=
data
->
count
)
{
VIR_TEST_DEBUG
(
"Expected number of parsed outputs is %d, "
"but got %d
\n
"
,
data
->
count
,
ret
);
goto
cleanup
;
}
else
if
(
!
data
->
pass
)
{
VIR_TEST_DEBUG
(
"Test should have failed
\n
"
);
goto
cleanup
;
}
ret
=
0
;
cleanup:
virLogReset
();
return
ret
;
}
static
int
static
int
mymain
(
void
)
mymain
(
void
)
{
{
int
ret
=
0
;
int
ret
=
0
;
#define DO_TEST_FULL(name, test, str,
pass)
\
#define DO_TEST_FULL(name, test, str,
count, pass)
\
do { \
do { \
struct testLogData data = { \
struct testLogData data = { \
str,
pass
\
str,
count, pass
\
}; \
}; \
if (virtTestRun(name, test, &data) < 0) \
if (virtTestRun(name, test, &data) < 0) \
ret = -1; \
ret = -1; \
} while (0)
} while (0)
#define TEST_LOG_MATCH_FAIL(str) \
#define TEST_LOG_MATCH_FAIL(str) \
DO_TEST_FULL("testLogMatch " # str, testLogMatch, str, false)
DO_TEST_FULL("testLogMatch " # str, testLogMatch, str,
0,
false)
#define TEST_LOG_MATCH(str) \
#define TEST_LOG_MATCH(str) \
DO_TEST_FULL("testLogMatch " # str, testLogMatch, str, true)
DO_TEST_FULL("testLogMatch " # str, testLogMatch, str, 0, true)
#define TEST_PARSE_OUTPUTS_FAIL(str, count) \
DO_TEST_FULL("testLogParseOutputs " # str, testLogParseOutputs, str, count, false)
#define TEST_PARSE_OUTPUTS(str, count) \
DO_TEST_FULL("testLogParseOutputs " # str, testLogParseOutputs, str, count, true)
TEST_LOG_MATCH
(
"2013-10-11 15:43:43.866+0000: 28302: info : libvirt version: 1.1.3"
);
TEST_LOG_MATCH
(
"2013-10-11 15:43:43.866+0000: 28302: info : libvirt version: 1.1.3"
);
TEST_LOG_MATCH_FAIL
(
"libvirt: error : cannot execute binary /usr/libexec/libvirt_lxc: No such file or directory"
);
TEST_LOG_MATCH_FAIL
(
"libvirt: error : cannot execute binary /usr/libexec/libvirt_lxc: No such file or directory"
);
TEST_PARSE_OUTPUTS
(
"1:file:/dev/null"
,
1
);
TEST_PARSE_OUTPUTS
(
"1:file:/dev/null 2:stderr"
,
2
);
TEST_PARSE_OUTPUTS_FAIL
(
"foo:stderr"
,
1
);
TEST_PARSE_OUTPUTS_FAIL
(
"1:bar"
,
1
);
TEST_PARSE_OUTPUTS_FAIL
(
"1:stderr:foobar"
,
1
);
return
ret
;
return
ret
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录