Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
0c413de8
提交
0c413de8
authored
12月 04, 2016
作者:
Jeromy Johnson
提交者:
GitHub
12月 04, 2016
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #3432 from keks/feat/pubsub-sharness
add sharness test for pubsub
上级
a1d2d47a
993e7816
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
69 行增加
和
18 行删除
+69
-18
pubsub.go
core/commands/pubsub.go
+5
-15
iptb-lib.sh
test/sharness/lib/iptb-lib.sh
+11
-3
t0180-pubsub.sh
test/sharness/t0180-pubsub.sh
+53
-0
没有找到文件。
core/commands/pubsub.go
浏览文件 @
0c413de8
...
...
@@ -122,30 +122,17 @@ To use, the daemon must be run with '--enable-pubsub-experiment'.
},
Marshalers
:
cmds
.
MarshalerMap
{
cmds
.
Text
:
getPsMsgMarshaler
(
func
(
m
*
floodsub
.
Message
)
(
io
.
Reader
,
error
)
{
if
m
.
Message
==
nil
{
return
strings
.
NewReader
(
""
),
nil
}
return
bytes
.
NewReader
(
m
.
Data
),
nil
}),
"ndpayload"
:
getPsMsgMarshaler
(
func
(
m
*
floodsub
.
Message
)
(
io
.
Reader
,
error
)
{
if
m
.
Message
==
nil
{
return
strings
.
NewReader
(
"
\n
"
),
nil
}
m
.
Data
=
append
(
m
.
Data
,
'\n'
)
return
bytes
.
NewReader
(
m
.
Data
),
nil
}),
"lenpayload"
:
getPsMsgMarshaler
(
func
(
m
*
floodsub
.
Message
)
(
io
.
Reader
,
error
)
{
buf
:=
make
([]
byte
,
8
)
var
data
[]
byte
if
m
.
Message
!=
nil
{
data
=
m
.
Data
}
n
:=
binary
.
PutUvarint
(
buf
,
uint64
(
len
(
data
)))
return
io
.
MultiReader
(
bytes
.
NewReader
(
buf
[
:
n
]),
bytes
.
NewReader
(
data
)),
nil
n
:=
binary
.
PutUvarint
(
buf
,
uint64
(
len
(
m
.
Data
)))
return
io
.
MultiReader
(
bytes
.
NewReader
(
buf
[
:
n
]),
bytes
.
NewReader
(
m
.
Data
)),
nil
}),
},
Type
:
floodsub
.
Message
{},
...
...
@@ -187,6 +174,9 @@ func getPsMsgMarshaler(f func(m *floodsub.Message) (io.Reader, error)) func(cmds
if
!
ok
{
return
nil
,
u
.
ErrCast
()
}
if
obj
.
Message
==
nil
{
return
strings
.
NewReader
(
""
),
nil
}
return
f
(
obj
)
}
...
...
test/sharness/lib/iptb-lib.sh
浏览文件 @
0c413de8
...
...
@@ -19,11 +19,19 @@ check_has_connection() {
startup_cluster
()
{
num_nodes
=
"
$1
"
shift
other_args
=
"
$@
"
bound
=
$(
expr
"
$num_nodes
"
- 1
)
test_expect_success
"start up nodes"
'
iptb start
'
if
test
-n
"
$other_args
"
;
then
test_expect_success
"start up nodes with additional args"
'
iptb start --args $other_args
'
else
test_expect_success
"start up nodes"
'
iptb start
'
fi
test_expect_success
"connect nodes to eachother"
'
iptb connect [1-$bound] 0
...
...
test/sharness/t0180-pubsub.sh
0 → 100755
浏览文件 @
0c413de8
#!/bin/sh
test_description
=
"Test dht command"
.
lib/test-lib.sh
# start iptb + wait for peering
NUM_NODES
=
5
test_expect_success
'init iptb'
'
iptb init -n $NUM_NODES --bootstrap=none --port=0
'
startup_cluster
$NUM_NODES
--enable-pubsub-experiment
test_expect_success
'peer ids'
'
PEERID_0=$(iptb get id 0) &&
PEERID_2=$(iptb get id 2)
'
# ipfs pubsub sub
test_expect_success
'pubsub'
'
echo "testOK" > expected &&
touch empty &&
mkfifo wait ||
test_fsh echo init fail
# ipfs pubsub sub is long-running so we need to start it in the background and
# wait put its output somewhere where we can access it
(
ipfsi 0 pubsub sub --enc=ndpayload testTopic | if read line; then
echo $line > actual &&
echo > wait
fi
) &
# wait until ipfs pubsub sub is ready to do work
sleep 1 &&
# publish something
ipfsi 1 pubsub pub testTopic "testOK" &> pubErr &&
# wait until `echo > wait` executed
cat wait &&
test_cmp pubErr empty &&
test_cmp expected actual
'
test_expect_success
'stop iptb'
'
iptb stop
'
test_done
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论