Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
e01c22a5
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
未验证
提交
e01c22a5
编写于
7月 05, 2020
作者:
S
Shengliang Guan
提交者:
GitHub
7月 05, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2567 from taosdata/feature/sangshuduo/random-network-fail
Feature/sangshuduo/random network fail
上级
bdaf7e6e
d2169f9b
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
78 addition
and
4 deletion
+78
-4
cmake/define.inc
cmake/define.inc
+4
-0
cmake/input.inc
cmake/input.inc
+5
-0
src/os/linux/inc/os.h
src/os/linux/inc/os.h
+19
-0
src/os/linux/src/linuxPlatform.c
src/os/linux/src/linuxPlatform.c
+46
-0
src/util/src/tfile.c
src/util/src/tfile.c
+4
-4
未找到文件。
cmake/define.inc
浏览文件 @
e01c22a5
...
...
@@ -28,3 +28,7 @@ ENDIF ()
IF
(
TD_RANDOM_FILE_FAIL
)
ADD_DEFINITIONS
(
-
DTAOS_RANDOM_FILE_FAIL
)
ENDIF
()
IF
(
TD_RANDOM_NETWORK_FAIL
)
ADD_DEFINITIONS
(
-
DTAOS_RANDOM_NETWORK_FAIL
)
ENDIF
()
cmake/input.inc
浏览文件 @
e01c22a5
...
...
@@ -36,3 +36,8 @@ IF (${RANDOM_FILE_FAIL} MATCHES "true")
SET
(
TD_RANDOM_FILE_FAIL
TRUE
)
MESSAGE
(
STATUS
"build with random-file-fail enabled"
)
ENDIF
()
IF
(
$
{
RANDOM_NETWORK_FAIL
}
MATCHES
"true"
)
SET
(
TD_RANDOM_NETWORK_FAIL
TRUE
)
MESSAGE
(
STATUS
"build with random-network-fail enabled"
)
ENDIF
()
src/os/linux/inc/os.h
浏览文件 @
e01c22a5
...
...
@@ -86,9 +86,28 @@ extern "C" {
} \
}
#ifdef TAOS_RANDOM_NETWORK_FAIL
ssize_t
taos_send_random_fail
(
int
sockfd
,
const
void
*
buf
,
size_t
len
,
int
flags
);
ssize_t
taos_sendto_random_fail
(
int
sockfd
,
const
void
*
buf
,
size_t
len
,
int
flags
,
const
struct
sockaddr
*
dest_addr
,
socklen_t
addrlen
);
ssize_t
taos_read_random_fail
(
int
fd
,
void
*
buf
,
size_t
count
);
ssize_t
taos_write_random_fail
(
int
fd
,
const
void
*
buf
,
size_t
count
);
#define send(sockfd, buf, len, flags) taos_send_random_fail(sockfd, buf, len, flags)
#define sendto(sockfd, buf, len, flags, dest_addr, addrlen) \
taos_sendto_random_fail(sockfd, buf, len, flags, dest_addr, addrlen)
#define taosWriteSocket(fd, buf, len) taos_write_random_fail(fd, buf, len)
#define taosReadSocket(fd, buf, len) taos_read_random_fail(fd, buf, len)
#else
#define taosWriteSocket(fd, buf, len) write(fd, buf, len)
#define taosReadSocket(fd, buf, len) read(fd, buf, len)
#endif
/* TAOS_RANDOM_NETWORK_FAIL */
#define atomic_load_8(ptr) __atomic_load_n((ptr), __ATOMIC_SEQ_CST)
#define atomic_load_16(ptr) __atomic_load_n((ptr), __ATOMIC_SEQ_CST)
#define atomic_load_32(ptr) __atomic_load_n((ptr), __ATOMIC_SEQ_CST)
...
...
src/os/linux/src/linuxPlatform.c
浏览文件 @
e01c22a5
...
...
@@ -270,3 +270,49 @@ int tSystem(const char * cmd)
}
}
#ifdef TAOS_RANDOM_NETWORK_FAIL
#define RANDOM_NETWORK_FAIL_FACTOR 20
ssize_t
taos_send_random_fail
(
int
sockfd
,
const
void
*
buf
,
size_t
len
,
int
flags
)
{
if
(
rand
()
%
RANDOM_NETWORK_FAIL_FACTOR
==
0
)
{
errno
=
ECONNRESET
;
return
-
1
;
}
return
send
(
sockfd
,
buf
,
len
,
flags
);
}
ssize_t
taos_sendto_random_fail
(
int
sockfd
,
const
void
*
buf
,
size_t
len
,
int
flags
,
const
struct
sockaddr
*
dest_addr
,
socklen_t
addrlen
)
{
if
(
rand
()
%
RANDOM_NETWORK_FAIL_FACTOR
==
0
)
{
errno
=
ECONNRESET
;
return
-
1
;
}
return
sendto
(
sockfd
,
buf
,
len
,
flags
,
dest_addr
,
addrlen
);
}
ssize_t
taos_read_random_fail
(
int
fd
,
void
*
buf
,
size_t
count
)
{
if
(
rand
()
%
RANDOM_NETWORK_FAIL_FACTOR
==
0
)
{
errno
=
ECONNRESET
;
return
-
1
;
}
return
read
(
fd
,
buf
,
count
);
}
ssize_t
taos_write_random_fail
(
int
fd
,
const
void
*
buf
,
size_t
count
)
{
if
(
rand
()
%
RANDOM_NETWORK_FAIL_FACTOR
==
0
)
{
errno
=
EINTR
;
return
-
1
;
}
return
write
(
fd
,
buf
,
count
);
}
#endif
/* TAOS_RANDOM_NETWORK_FAIL */
src/util/src/tfile.c
浏览文件 @
e01c22a5
...
...
@@ -26,12 +26,12 @@
#include "os.h"
#define RANDOM_FACTOR 5
#define RANDOM_F
ILE_FAIL_F
ACTOR 5
ssize_t
taos_tread
(
int
fd
,
void
*
buf
,
size_t
count
)
{
#ifdef TAOS_RANDOM_FILE_FAIL
if
(
rand
()
%
RANDOM_FACTOR
==
0
)
{
if
(
rand
()
%
RANDOM_F
ILE_FAIL_F
ACTOR
==
0
)
{
errno
=
EIO
;
return
-
1
;
}
...
...
@@ -43,7 +43,7 @@ ssize_t taos_tread(int fd, void *buf, size_t count)
ssize_t
taos_twrite
(
int
fd
,
void
*
buf
,
size_t
count
)
{
#ifdef TAOS_RANDOM_FILE_FAIL
if
(
rand
()
%
RANDOM_FACTOR
==
0
)
{
if
(
rand
()
%
RANDOM_F
ILE_FAIL_F
ACTOR
==
0
)
{
errno
=
EIO
;
return
-
1
;
}
...
...
@@ -55,7 +55,7 @@ ssize_t taos_twrite(int fd, void *buf, size_t count)
off_t
taos_lseek
(
int
fd
,
off_t
offset
,
int
whence
)
{
#ifdef TAOS_RANDOM_FILE_FAIL
if
(
rand
()
%
RANDOM_FACTOR
==
0
)
{
if
(
rand
()
%
RANDOM_F
ILE_FAIL_F
ACTOR
==
0
)
{
errno
=
EIO
;
return
-
1
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录