Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
26155b95
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
Star
22018
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
26155b95
编写于
5月 05, 2022
作者:
wmmhello
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor:add schemaless test cases
上级
119e7952
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
123 addition
and
46 deletion
+123
-46
source/client/src/clientSml.c
source/client/src/clientSml.c
+43
-22
source/client/test/smlTest.cpp
source/client/test/smlTest.cpp
+80
-24
未找到文件。
source/client/src/clientSml.c
浏览文件 @
26155b95
...
...
@@ -133,8 +133,12 @@ static uint64_t smlGenId() {
}
static
int32_t
smlBuildInvalidDataMsg
(
SSmlMsgBuf
*
pBuf
,
const
char
*
msg1
,
const
char
*
msg2
)
{
if
(
msg1
)
snprintf
(
pBuf
->
buf
,
pBuf
->
len
,
"%s:"
,
msg1
);
if
(
msg2
)
strncpy
(
pBuf
->
buf
,
msg2
,
pBuf
->
len
);
if
(
msg1
)
strncat
(
pBuf
->
buf
,
msg1
,
pBuf
->
len
);
int32_t
left
=
pBuf
->
len
-
strlen
(
pBuf
->
buf
);
if
(
left
>
2
&&
msg2
)
{
strncat
(
pBuf
->
buf
,
":"
,
left
-
1
);
strncat
(
pBuf
->
buf
,
msg2
,
left
-
2
);
}
return
TSDB_CODE_SML_INVALID_DATA
;
}
...
...
@@ -658,11 +662,12 @@ static bool smlParseBigInt(SSmlKv *kvVal, bool *isValid, SSmlMsgBuf *msg) {
int32_t
len
=
kvVal
->
valueLen
;
if
(
len
>
3
&&
strncasecmp
(
pVal
+
len
-
3
,
"i64"
,
3
)
==
0
)
{
char
*
endptr
=
NULL
;
errno
=
0
;
int64_t
result
=
strtoll
(
pVal
,
&
endptr
,
10
);
if
(
endptr
!=
pVal
+
len
-
3
){
// 78ri8
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"invalid big int"
,
endptr
);
}
else
if
(
!
IS_VALID_BIGINT
(
result
)){
}
else
if
(
errno
==
ERANGE
||
!
IS_VALID_BIGINT
(
result
)){
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"big int out of range[-9223372036854775808,9223372036854775807]"
,
endptr
);
}
else
{
...
...
@@ -672,11 +677,12 @@ static bool smlParseBigInt(SSmlKv *kvVal, bool *isValid, SSmlMsgBuf *msg) {
return
true
;
}
else
if
(
len
>
1
&&
pVal
[
len
-
1
]
==
'i'
)
{
char
*
endptr
=
NULL
;
errno
=
0
;
int64_t
result
=
strtoll
(
pVal
,
&
endptr
,
10
);
if
(
endptr
!=
pVal
+
len
-
1
){
// 78ri8
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"invalid big int"
,
endptr
);
}
else
if
(
!
IS_VALID_BIGINT
(
result
)){
}
else
if
(
errno
==
ERANGE
||
!
IS_VALID_BIGINT
(
result
)){
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"big int out of range[-9223372036854775808,9223372036854775807]"
,
endptr
);
}
else
{
...
...
@@ -700,11 +706,12 @@ static bool smlParseBigUint(SSmlKv *kvVal, bool *isValid, SSmlMsgBuf *msg) {
const
char
*
signalPos
=
pVal
+
len
-
3
;
if
(
strncasecmp
(
signalPos
,
"u64"
,
3
)
==
0
)
{
char
*
endptr
=
NULL
;
errno
=
0
;
uint64_t
result
=
strtoull
(
pVal
,
&
endptr
,
10
);
if
(
endptr
!=
signalPos
){
// 78ri8
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"invalid unsigned big int"
,
endptr
);
}
else
if
(
!
IS_VALID_UBIGINT
(
result
)){
}
else
if
(
errno
==
ERANGE
||
!
IS_VALID_UBIGINT
(
result
)){
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"unsigned big int out of range[0,18446744073709551615]"
,
endptr
);
}
else
{
...
...
@@ -720,18 +727,19 @@ static bool smlParseFloat(SSmlKv *kvVal, bool *isValid, SSmlMsgBuf *msg) {
const
char
*
pVal
=
kvVal
->
value
;
int32_t
len
=
kvVal
->
valueLen
;
char
*
endptr
=
NULL
;
errno
=
0
;
float
result
=
strtof
(
pVal
,
&
endptr
);
if
(
endptr
==
pVal
+
len
&&
IS_VALID_FLOAT
(
result
)){
// 78
if
(
endptr
==
pVal
+
len
&&
errno
!=
ERANGE
&&
IS_VALID_FLOAT
(
result
)){
// 78
kvVal
->
f
=
result
;
*
isValid
=
true
;
return
true
;
}
if
(
len
>
3
&&
len
<
strncasecmp
(
pVal
+
len
-
3
,
"f32"
,
3
)
==
0
)
{
if
(
len
>
3
&&
strncasecmp
(
pVal
+
len
-
3
,
"f32"
,
3
)
==
0
)
{
if
(
endptr
!=
pVal
+
len
-
3
){
// 78ri8
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"invalid float"
,
endptr
);
}
else
if
(
!
IS_VALID_FLOAT
(
result
)){
}
else
if
(
errno
==
ERANGE
||
!
IS_VALID_FLOAT
(
result
)){
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"float out of range[-3.402823466e+38,3.402823466e+38]"
,
endptr
);
}
else
{
...
...
@@ -750,13 +758,14 @@ static bool smlParseDouble(SSmlKv *kvVal, bool *isValid, SSmlMsgBuf *msg) {
return
false
;
}
const
char
*
signalPos
=
pVal
+
len
-
3
;
if
(
len
<
strncasecmp
(
signalPos
,
"f64"
,
3
)
==
0
)
{
if
(
strncasecmp
(
signalPos
,
"f64"
,
3
)
==
0
)
{
char
*
endptr
=
NULL
;
errno
=
0
;
double
result
=
strtod
(
pVal
,
&
endptr
);
if
(
endptr
!=
signalPos
){
// 78ri8
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"invalid double"
,
endptr
);
}
else
if
(
!
IS_VALID_DOUBLE
(
result
)){
}
else
if
(
errno
==
ERANGE
||
!
IS_VALID_DOUBLE
(
result
)){
*
isValid
=
false
;
smlBuildInvalidDataMsg
(
msg
,
"double out of range[-1.7976931348623158e+308,1.7976931348623158e+308]"
,
endptr
);
}
else
{
...
...
@@ -817,27 +826,31 @@ static bool smlIsNchar(const char *pVal, uint16_t len) {
static
bool
smlParseValue
(
SSmlKv
*
pVal
,
SSmlMsgBuf
*
msg
)
{
// put high probability matching type first
bool
isValid
=
false
;
if
(
smlParseFloat
(
pVal
,
&
isValid
,
msg
))
{
if
(
!
isValid
)
return
false
;
pVal
->
type
=
TSDB_DATA_TYPE_FLOAT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
return
true
;
}
//binary
if
(
smlIsBinary
(
pVal
->
value
,
pVal
->
valueLen
))
{
pVal
->
type
=
TSDB_DATA_TYPE_BINARY
;
pVal
->
length
=
pVal
->
valueLen
-
2
;
pVal
->
valueLen
-=
2
;
pVal
->
value
=
pVal
->
value
++
;
pVal
->
length
=
pVal
->
valueLen
;
pVal
->
value
++
;
return
true
;
}
//nchar
if
(
smlIsNchar
(
pVal
->
value
,
pVal
->
valueLen
))
{
pVal
->
type
=
TSDB_DATA_TYPE_NCHAR
;
pVal
->
length
=
pVal
->
valueLen
-
3
;
pVal
->
value
=
pVal
->
value
+
2
;
pVal
->
valueLen
-=
3
;
pVal
->
length
=
pVal
->
valueLen
;
pVal
->
value
+=
2
;
return
true
;
}
//float
if
(
smlParseFloat
(
pVal
,
&
isValid
,
msg
))
{
if
(
!
isValid
)
return
false
;
pVal
->
type
=
TSDB_DATA_TYPE_FLOAT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
return
true
;
}
//double
if
(
smlParseDouble
(
pVal
,
&
isValid
,
msg
))
{
if
(
!
isValid
)
return
false
;
pVal
->
type
=
TSDB_DATA_TYPE_DOUBLE
;
...
...
@@ -1017,7 +1030,7 @@ static int32_t smlParseCols(const char* data, int32_t len, SArray *cols, bool is
kv
->
valueLen
=
strlen
(
TAG
);
kv
->
type
=
TSDB_DATA_TYPE_NCHAR
;
if
(
cols
)
taosArrayPush
(
cols
,
&
kv
);
return
true
;
return
TSDB_CODE_SUCCESS
;
}
for
(
int
i
=
0
;
i
<
len
;
i
++
){
...
...
@@ -1039,12 +1052,20 @@ static int32_t smlParseCols(const char* data, int32_t len, SArray *cols, bool is
// parse value
i
++
;
const
char
*
value
=
data
+
i
;
bool
isInQuote
=
false
;
while
(
i
<
len
){
if
(
data
[
i
]
==
COMMA
&&
i
>
0
&&
data
[
i
-
1
]
!=
SLASH
){
if
(
data
[
i
]
==
QUOTE
&&
data
[
i
-
1
]
!=
SLASH
){
isInQuote
=
!
isInQuote
;
}
if
(
!
isInQuote
&&
data
[
i
]
==
COMMA
&&
i
>
0
&&
data
[
i
-
1
]
!=
SLASH
){
break
;
}
i
++
;
}
if
(
isInQuote
){
smlBuildInvalidDataMsg
(
msg
,
"only one quote"
,
value
);
return
TSDB_CODE_SML_INVALID_DATA
;
}
int32_t
valueLen
=
data
+
i
-
value
;
if
(
valueLen
==
0
){
smlBuildInvalidDataMsg
(
msg
,
"invalid value"
,
value
);
...
...
source/client/test/smlTest.cpp
浏览文件 @
26155b95
...
...
@@ -131,11 +131,6 @@ TEST(testCase, smlParseString_Test) {
}
TEST
(
testCase
,
smlParseCols_Error_Test
)
{
char
msg
[
256
]
=
{
0
};
SSmlMsgBuf
msgBuf
;
msgBuf
.
buf
=
msg
;
msgBuf
.
len
=
256
;
const
char
*
data
[]
=
{
"c=
\"
89sd"
,
// binary, nchar
"c=j
\"
89sd
\"
"
,
...
...
@@ -198,12 +193,70 @@ TEST(testCase, smlParseCols_Error_Test) {
};
for
(
int
i
=
0
;
i
<
sizeof
(
data
)
/
sizeof
(
data
[
0
]);
i
++
){
char
msg
[
256
]
=
{
0
};
SSmlMsgBuf
msgBuf
;
msgBuf
.
buf
=
msg
;
msgBuf
.
len
=
256
;
int32_t
len
=
strlen
(
data
[
i
]);
int32_t
ret
=
smlParseCols
(
data
[
i
],
len
,
NULL
,
false
,
&
msgBuf
);
ASSERT_NE
(
ret
,
TSDB_CODE_SUCCESS
);
}
}
TEST
(
testCase
,
smlParseCols_tag_Test
)
{
char
msg
[
256
]
=
{
0
};
SSmlMsgBuf
msgBuf
;
msgBuf
.
buf
=
msg
;
msgBuf
.
len
=
256
;
SArray
*
cols
=
taosArrayInit
(
16
,
POINTER_BYTES
);
ASSERT_NE
(
cols
,
NULL
);
const
char
*
data
=
"cbin=
\"
passit hello,c=2
\"
,cnch=L
\"
iisdfsf
\"
,cbool=false,cf64=4.31f64,cf32_=8.32,cf32=8.23f32,ci8=-34i8,cu8=89u8,ci16=233i16,cu16=898u16,ci32=98289i32,cu32=12323u32,ci64=-89238i64,ci=989i,cu64=8989323u64,cbooltrue=true,cboolt=t,cboolf=f,cnch_=l
\"
iuwq
\"
"
;
int32_t
len
=
strlen
(
data
);
int32_t
ret
=
smlParseCols
(
data
,
len
,
cols
,
true
,
&
msgBuf
);
ASSERT_EQ
(
ret
,
TSDB_CODE_SUCCESS
);
int32_t
size
=
taosArrayGetSize
(
cols
);
ASSERT_EQ
(
size
,
19
);
// nchar
SSmlKv
*
kv
=
taosArrayGetP
(
cols
,
0
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cbin"
,
4
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
4
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_NCHAR
);
ASSERT_EQ
(
kv
->
valueLen
,
18
);
ASSERT_EQ
(
strncasecmp
(
kv
->
value
,
"
\"
passit"
,
7
),
0
);
taosMemoryFree
(
kv
);
// nchar
kv
=
taosArrayGetP
(
cols
,
3
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cf64"
,
4
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
4
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_NCHAR
);
ASSERT_EQ
(
kv
->
valueLen
,
7
);
ASSERT_EQ
(
strncasecmp
(
kv
->
value
,
"4.31f64"
,
7
),
0
);
taosMemoryFree
(
kv
);
taosArrayClear
(
cols
);
data
=
"t=3e"
;
len
=
0
;
memset
(
msgBuf
.
buf
,
0
,
msgBuf
.
len
);
ret
=
smlParseCols
(
data
,
len
,
cols
,
true
,
&
msgBuf
);
ASSERT_EQ
(
ret
,
TSDB_CODE_SUCCESS
);
size
=
taosArrayGetSize
(
cols
);
ASSERT_EQ
(
size
,
1
);
// nchar
kv
=
taosArrayGetP
(
cols
,
0
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
TAG
,
strlen
(
TAG
)),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
strlen
(
TAG
));
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_NCHAR
);
ASSERT_EQ
(
kv
->
valueLen
,
strlen
(
TAG
));
ASSERT_EQ
(
strncasecmp
(
kv
->
value
,
TAG
,
strlen
(
TAG
)),
0
);
taosMemoryFree
(
kv
);
}
TEST
(
testCase
,
smlParseCols_Test
)
{
char
msg
[
256
]
=
{
0
};
SSmlMsgBuf
msgBuf
;
...
...
@@ -213,7 +266,7 @@ TEST(testCase, smlParseCols_Test) {
SArray
*
cols
=
taosArrayInit
(
16
,
POINTER_BYTES
);
ASSERT_NE
(
cols
,
NULL
);
const
char
*
data
=
"cbin=
\"
passit hello,c=2
\"
,cnch=L
\"
iisdfsf
\"
,cbool=false,cf64=4f64,cf32_=8.32,cf32=8.23f32,ci8=-34i8,cu8=89u8,ci16=233i16,cu16=898u16,ci32=98289i32,cu32=12323u32,ci64=-89238i64,ci=989i,cu64=8989323u64,cbooltrue=true,cboolt=t,cboolf=f,cnch_=l
\"
iuwq
\"
"
;
const
char
*
data
=
"cbin=
\"
passit hello,c=2
\"
,cnch=L
\"
iisdfsf
\"
,cbool=false,cf64=4
.31
f64,cf32_=8.32,cf32=8.23f32,ci8=-34i8,cu8=89u8,ci16=233i16,cu16=898u16,ci32=98289i32,cu32=12323u32,ci64=-89238i64,ci=989i,cu64=8989323u64,cbooltrue=true,cboolt=t,cboolf=f,cnch_=l
\"
iuwq
\"
"
;
int32_t
len
=
strlen
(
data
);
int32_t
ret
=
smlParseCols
(
data
,
len
,
cols
,
false
,
&
msgBuf
);
ASSERT_EQ
(
ret
,
TSDB_CODE_SUCCESS
);
...
...
@@ -223,8 +276,8 @@ TEST(testCase, smlParseCols_Test) {
// binary
SSmlKv
*
kv
=
taosArrayGetP
(
cols
,
0
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cbin"
,
4
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
4
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BINARY
;
ASSERT_EQ
(
kv
->
keyLen
,
4
)
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BINARY
)
;
ASSERT_EQ
(
kv
->
length
,
16
);
ASSERT_EQ
(
strncasecmp
(
kv
->
value
,
"passit"
,
6
),
0
);
taosMemoryFree
(
kv
);
...
...
@@ -243,7 +296,7 @@ TEST(testCase, smlParseCols_Test) {
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cbool"
,
5
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
5
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BOOL
);
ASSERT_EQ
(
kv
->
length
,
1
;
ASSERT_EQ
(
kv
->
length
,
1
)
;
ASSERT_EQ
(
kv
->
i
,
false
);
taosMemoryFree
(
kv
);
...
...
@@ -252,8 +305,9 @@ TEST(testCase, smlParseCols_Test) {
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cf64"
,
4
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
4
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_DOUBLE
);
ASSERT_EQ
(
kv
->
length
,
8
;
ASSERT_EQ
(
kv
->
d
,
4
);
ASSERT_EQ
(
kv
->
length
,
8
);
//ASSERT_EQ(kv->d, 4.31);
printf
(
"4.31 = kv->f:%f
\n
"
,
kv
->
d
);
taosMemoryFree
(
kv
);
// float
...
...
@@ -262,7 +316,8 @@ TEST(testCase, smlParseCols_Test) {
ASSERT_EQ
(
kv
->
keyLen
,
5
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_FLOAT
);
ASSERT_EQ
(
kv
->
length
,
4
);
ASSERT_EQ
(
kv
->
f
,
8.32
);
//ASSERT_EQ(kv->f, 8.32);
printf
(
"8.32 = kv->f:%f
\n
"
,
kv
->
f
);
taosMemoryFree
(
kv
);
// float
...
...
@@ -271,16 +326,17 @@ TEST(testCase, smlParseCols_Test) {
ASSERT_EQ
(
kv
->
keyLen
,
4
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_FLOAT
);
ASSERT_EQ
(
kv
->
length
,
4
);
ASSERT_EQ
(
kv
->
f
,
8.23
);
//ASSERT_EQ(kv->f, 8.23);
printf
(
"8.23 = kv->f:%f
\n
"
,
kv
->
f
);
taosMemoryFree
(
kv
);
// tiny int
kv
=
taosArrayGetP
(
cols
,
6
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"ci8"
,
3
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
3
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_TINYINT
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_TINYINT
)
;
ASSERT_EQ
(
kv
->
length
,
1
);
ASSERT_EQ
(
i
,
-
34
);
ASSERT_EQ
(
kv
->
i
,
-
34
);
taosMemoryFree
(
kv
);
// unsigned tiny int
...
...
@@ -332,8 +388,8 @@ TEST(testCase, smlParseCols_Test) {
// bigint
kv
=
taosArrayGetP
(
cols
,
12
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"ci64"
,
4
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
4
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BIGINT
;
ASSERT_EQ
(
kv
->
keyLen
,
4
)
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BIGINT
)
;
ASSERT_EQ
(
kv
->
length
,
8
);
ASSERT_EQ
(
kv
->
i
,
-
89238
);
taosMemoryFree
(
kv
);
...
...
@@ -369,10 +425,10 @@ TEST(testCase, smlParseCols_Test) {
// bool
kv
=
taosArrayGetP
(
cols
,
16
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cboolt"
,
6
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
6
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BOOL
;
ASSERT_EQ
(
kv
->
length
,
8
);
ASSERT_EQ
(
kv
->
i
,
-
89238
);
ASSERT_EQ
(
kv
->
keyLen
,
6
)
;
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BOOL
)
;
ASSERT_EQ
(
kv
->
length
,
1
);
ASSERT_EQ
(
kv
->
i
,
true
);
taosMemoryFree
(
kv
);
// bool
...
...
@@ -380,11 +436,11 @@ TEST(testCase, smlParseCols_Test) {
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cboolf"
,
6
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
6
);
ASSERT_EQ
(
kv
->
type
,
TSDB_DATA_TYPE_BOOL
);
ASSERT_EQ
(
kv
->
length
,
8
);
ASSERT_EQ
(
kv
->
i
,
989
);
ASSERT_EQ
(
kv
->
length
,
1
);
ASSERT_EQ
(
kv
->
i
,
false
);
taosMemoryFree
(
kv
);
//
unsigned bigint
//
nchar
kv
=
taosArrayGetP
(
cols
,
18
);
ASSERT_EQ
(
strncasecmp
(
kv
->
key
,
"cnch_"
,
5
),
0
);
ASSERT_EQ
(
kv
->
keyLen
,
5
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录