Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
feb653b4
提交
feb653b4
authored
9月 02, 2016
作者:
Jeromy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
bitswap: add better tests around wantlist clearing
License: MIT Signed-off-by:
Jeromy
<
why@ipfs.io
>
上级
0e5e6cf9
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
73 行增加
和
5 行删除
+73
-5
bitswap_test.go
exchange/bitswap/bitswap_test.go
+73
-5
没有找到文件。
exchange/bitswap/bitswap_test.go
浏览文件 @
feb653b4
...
...
@@ -334,7 +334,6 @@ func TestDoubleGet(t *testing.T) {
blocks
:=
bg
.
Blocks
(
1
)
ctx1
,
cancel1
:=
context
.
WithCancel
(
context
.
Background
())
blkch1
,
err
:=
instances
[
1
]
.
Exchange
.
GetBlocks
(
ctx1
,
[]
key
.
Key
{
blocks
[
0
]
.
Key
()})
if
err
!=
nil
{
t
.
Fatal
(
err
)
...
...
@@ -362,11 +361,15 @@ func TestDoubleGet(t *testing.T) {
t
.
Fatal
(
err
)
}
blk
,
ok
:=
<-
blkch2
if
!
ok
{
t
.
Fatal
(
"expected to get the block here"
)
select
{
case
blk
,
ok
:=
<-
blkch2
:
if
!
ok
{
t
.
Fatal
(
"expected to get the block here"
)
}
t
.
Log
(
blk
)
case
<-
time
.
After
(
time
.
Second
*
5
)
:
t
.
Fatal
(
"timed out waiting on block"
)
}
t
.
Log
(
blk
)
for
_
,
inst
:=
range
instances
{
err
:=
inst
.
Exchange
.
Close
()
...
...
@@ -375,3 +378,68 @@ func TestDoubleGet(t *testing.T) {
}
}
}
func
TestWantlistCleanup
(
t
*
testing
.
T
)
{
net
:=
tn
.
VirtualNetwork
(
mockrouting
.
NewServer
(),
delay
.
Fixed
(
kNetworkDelay
))
sg
:=
NewTestSessionGenerator
(
net
)
defer
sg
.
Close
()
bg
:=
blocksutil
.
NewBlockGenerator
()
instances
:=
sg
.
Instances
(
1
)[
0
]
bswap
:=
instances
.
Exchange
blocks
:=
bg
.
Blocks
(
20
)
var
keys
[]
key
.
Key
for
_
,
b
:=
range
blocks
{
keys
=
append
(
keys
,
b
.
Key
())
}
ctx
,
cancel
:=
context
.
WithTimeout
(
context
.
Background
(),
time
.
Millisecond
*
50
)
defer
cancel
()
_
,
err
:=
bswap
.
GetBlock
(
ctx
,
keys
[
0
])
if
err
!=
context
.
DeadlineExceeded
{
t
.
Fatal
(
"shouldnt have fetched any blocks"
)
}
time
.
Sleep
(
time
.
Millisecond
*
50
)
if
len
(
bswap
.
GetWantlist
())
>
0
{
t
.
Fatal
(
"should not have anyting in wantlist"
)
}
ctx
,
cancel
=
context
.
WithTimeout
(
context
.
Background
(),
time
.
Millisecond
*
50
)
defer
cancel
()
_
,
err
=
bswap
.
GetBlocks
(
ctx
,
keys
[
:
10
])
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
<-
ctx
.
Done
()
time
.
Sleep
(
time
.
Millisecond
*
50
)
if
len
(
bswap
.
GetWantlist
())
>
0
{
t
.
Fatal
(
"should not have anyting in wantlist"
)
}
_
,
err
=
bswap
.
GetBlocks
(
context
.
Background
(),
keys
[
:
1
])
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
ctx
,
cancel
=
context
.
WithCancel
(
context
.
Background
())
_
,
err
=
bswap
.
GetBlocks
(
ctx
,
keys
[
10
:
])
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
time
.
Sleep
(
time
.
Millisecond
*
50
)
if
len
(
bswap
.
GetWantlist
())
!=
11
{
t
.
Fatal
(
"should have 11 keys in wantlist"
)
}
cancel
()
time
.
Sleep
(
time
.
Millisecond
*
50
)
if
!
(
len
(
bswap
.
GetWantlist
())
==
1
&&
bswap
.
GetWantlist
()[
0
]
==
keys
[
0
])
{
t
.
Fatal
(
"should only have keys[0] in wantlist"
)
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论