Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
畅游知识海洋
json
提交
4b9bd96a
J
json
项目概览
畅游知识海洋
/
json
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
json
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4b9bd96a
编写于
2月 11, 2015
作者:
N
Niels
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
re-added old (failing) test cases
上级
c816fd12
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
47 addition
and
50 deletion
+47
-50
test/unit.cpp
test/unit.cpp
+47
-50
未找到文件。
test/unit.cpp
浏览文件 @
4b9bd96a
...
...
@@ -4037,67 +4037,64 @@ TEST_CASE("lexer class")
CHECK
(
json
::
lexer
::
token_type_name
(
json
::
lexer
::
token_type
::
parse_error
)
==
"<parse error>"
);
CHECK
(
json
::
lexer
::
token_type_name
(
json
::
lexer
::
token_type
::
end_of_input
)
==
"<end of input>"
);
}
}
TEST_CASE
(
"parser class"
)
{
SECTION
(
"get_token"
)
SECTION
(
"parse errors on first character"
)
{
/*
SECTION("parse errors on first character")
for
(
int
c
=
1
;
c
<
128
;
++
c
)
{
for (int c = 1; c < 255; ++c)
auto
s
=
std
::
string
(
1
,
c
);
CAPTURE
(
c
);
CAPTURE
(
s
);
switch
(
c
)
{
auto s = std::string(1, c);
// characters that are prefixes of reasonable json
case
(
'['
):
case
(
']'
):
case
(
'{'
):
case
(
'}'
):
case
(
','
):
case
(
':'
):
case
(
'0'
):
case
(
'1'
):
case
(
'2'
):
case
(
'3'
):
case
(
'4'
):
case
(
'5'
):
case
(
'6'
):
case
(
'7'
):
case
(
'8'
):
case
(
'9'
):
case
(
'"'
):
{
CHECK
(
json
::
lexer
(
s
.
c_str
()).
scan
()
!=
json
::
lexer
::
token_type
::
parse_error
);
break
;
}
CAPTURE(c);
CAPTURE(s);
// whitespace
case
(
' '
):
case
(
'\t'
):
case
(
'\n'
):
case
(
'\r'
):
{
CHECK
(
json
::
lexer
(
s
.
c_str
()).
scan
()
==
json
::
lexer
::
token_type
::
end_of_input
);
break
;
}
switch (c)
// anything else is not expected
default:
{
// characters that are prefixes of reasonable json
case ('['):
case (']'):
case ('{'):
case ('}'):
case (','):
case (':'):
case ('0'):
case ('1'):
case ('2'):
case ('3'):
case ('4'):
case ('5'):
case ('6'):
case ('7'):
case ('8'):
case ('9'):
case ('"'):
{
CHECK(json::parser(s).last_token != json::lexer::token_type::parse_error);
break;
}
case (' '):
case ('\t'):
case ('\n'):
case ('\r'):
{
CHECK(json::parser(s).last_token == json::lexer::token_type::end_of_input);
break;
}
default:
{
CHECK(json::parser(s).last_token == json::lexer::token_type::parse_error);
break;
}
CHECK
(
json
::
lexer
(
s
.
c_str
()).
scan
()
==
json
::
lexer
::
token_type
::
parse_error
);
break
;
}
}
}
*/
}
}
TEST_CASE
(
"parser class"
)
{
SECTION
(
"parse"
)
{
SECTION
(
"null"
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录