Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
0dd0f252
提交
0dd0f252
authored
2月 12, 2018
作者:
Jeromy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
bitswap virtual test net code should send messages in order
License: MIT Signed-off-by:
Jeromy
<
jeromyj@gmail.com
>
上级
d4d30f4e
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
55 行增加
和
6 行删除
+55
-6
virtual.go
exchange/bitswap/testnet/virtual.go
+55
-6
没有找到文件。
exchange/bitswap/testnet/virtual.go
浏览文件 @
0dd0f252
...
...
@@ -4,6 +4,7 @@ import (
"context"
"errors"
"sync"
"time"
bsmsg
"github.com/ipfs/go-ipfs/exchange/bitswap/message"
bsnet
"github.com/ipfs/go-ipfs/exchange/bitswap/network"
...
...
@@ -22,7 +23,7 @@ var log = logging.Logger("bstestnet")
func
VirtualNetwork
(
rs
mockrouting
.
Server
,
d
delay
.
D
)
Network
{
return
&
network
{
clients
:
make
(
map
[
peer
.
ID
]
bsnet
.
Receiver
),
clients
:
make
(
map
[
peer
.
ID
]
*
receiverQueue
),
delay
:
d
,
routingserver
:
rs
,
conns
:
make
(
map
[
string
]
struct
{}),
...
...
@@ -31,12 +32,28 @@ func VirtualNetwork(rs mockrouting.Server, d delay.D) Network {
type
network
struct
{
mu
sync
.
Mutex
clients
map
[
peer
.
ID
]
bsnet
.
Receiver
clients
map
[
peer
.
ID
]
*
receiverQueue
routingserver
mockrouting
.
Server
delay
delay
.
D
conns
map
[
string
]
struct
{}
}
type
message
struct
{
from
peer
.
ID
msg
bsmsg
.
BitSwapMessage
shouldSend
time
.
Time
}
// receiverQueue queues up a set of messages to be sent, and sends them *in
// order* with their delays respected as much as sending them in order allows
// for
type
receiverQueue
struct
{
receiver
bsnet
.
Receiver
queue
[]
*
message
active
bool
lk
sync
.
Mutex
}
func
(
n
*
network
)
Adapter
(
p
testutil
.
Identity
)
bsnet
.
BitSwapNetwork
{
n
.
mu
.
Lock
()
defer
n
.
mu
.
Unlock
()
...
...
@@ -46,7 +63,7 @@ func (n *network) Adapter(p testutil.Identity) bsnet.BitSwapNetwork {
network
:
n
,
routing
:
n
.
routingserver
.
Client
(
p
),
}
n
.
clients
[
p
.
ID
()]
=
client
n
.
clients
[
p
.
ID
()]
=
&
receiverQueue
{
receiver
:
client
}
return
client
}
...
...
@@ -64,7 +81,7 @@ func (n *network) SendMessage(
ctx
context
.
Context
,
from
peer
.
ID
,
to
peer
.
ID
,
mes
sage
bsmsg
.
BitSwapMessage
)
error
{
mes
bsmsg
.
BitSwapMessage
)
error
{
n
.
mu
.
Lock
()
defer
n
.
mu
.
Unlock
()
...
...
@@ -77,7 +94,12 @@ func (n *network) SendMessage(
// nb: terminate the context since the context wouldn't actually be passed
// over the network in a real scenario
go
n
.
deliver
(
receiver
,
from
,
message
)
msg
:=
&
message
{
from
:
from
,
msg
:
mes
,
shouldSend
:
time
.
Now
()
.
Add
(
n
.
delay
.
Get
()),
}
receiver
.
enqueue
(
msg
)
return
nil
}
...
...
@@ -191,11 +213,38 @@ func (nc *networkClient) ConnectTo(_ context.Context, p peer.ID) error {
// TODO: add handling for disconnects
otherClient
.
PeerConnected
(
nc
.
local
)
otherClient
.
receiver
.
PeerConnected
(
nc
.
local
)
nc
.
Receiver
.
PeerConnected
(
p
)
return
nil
}
func
(
rq
*
receiverQueue
)
enqueue
(
m
*
message
)
{
rq
.
lk
.
Lock
()
defer
rq
.
lk
.
Unlock
()
rq
.
queue
=
append
(
rq
.
queue
,
m
)
if
!
rq
.
active
{
rq
.
active
=
true
go
rq
.
process
()
}
}
func
(
rq
*
receiverQueue
)
process
()
{
for
{
rq
.
lk
.
Lock
()
if
len
(
rq
.
queue
)
==
0
{
rq
.
active
=
false
rq
.
lk
.
Unlock
()
return
}
m
:=
rq
.
queue
[
0
]
rq
.
queue
=
rq
.
queue
[
1
:
]
rq
.
lk
.
Unlock
()
time
.
Sleep
(
time
.
Until
(
m
.
shouldSend
))
rq
.
receiver
.
ReceiveMessage
(
context
.
TODO
(),
m
.
from
,
m
.
msg
)
}
}
func
tagForPeers
(
a
,
b
peer
.
ID
)
string
{
if
a
<
b
{
return
string
(
a
+
b
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论