Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
65f95a19
提交
65f95a19
authored
11月 05, 2014
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
mux test race #270
上级
d26fd581
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
12 行增加
和
0 行删除
+12
-0
mux_test.go
net/mux/mux_test.go
+12
-0
没有找到文件。
net/mux/mux_test.go
浏览文件 @
65f95a19
...
...
@@ -3,6 +3,7 @@ package mux
import
(
"bytes"
"fmt"
"sync"
"testing"
"time"
...
...
@@ -121,6 +122,7 @@ func TestSimultMuxer(t *testing.T) {
total
:=
10000
speed
:=
time
.
Microsecond
*
1
counts
:=
[
2
][
2
][
2
]
int
{}
var
countsLock
sync
.
Mutex
// run producers at every end sending incrementing messages
produceOut
:=
func
(
pid
pb
.
ProtocolID
,
size
int
)
{
...
...
@@ -130,7 +132,9 @@ func TestSimultMuxer(t *testing.T) {
s
:=
fmt
.
Sprintf
(
"proto %v out %v"
,
pid
,
i
)
m
:=
msg
.
New
(
peer1
,
[]
byte
(
s
))
mux1
.
Protocols
[
pid
]
.
GetPipe
()
.
Outgoing
<-
m
countsLock
.
Lock
()
counts
[
pid
][
0
][
0
]
++
countsLock
.
Unlock
()
// log.Debug("sent %v", s)
}
}
...
...
@@ -147,7 +151,9 @@ func TestSimultMuxer(t *testing.T) {
m
:=
msg
.
New
(
peer1
,
d
)
mux1
.
Incoming
<-
m
countsLock
.
Lock
()
counts
[
pid
][
1
][
0
]
++
countsLock
.
Unlock
()
// log.Debug("sent %v", s)
}
}
...
...
@@ -163,7 +169,9 @@ func TestSimultMuxer(t *testing.T) {
// log.Debug("got %v", string(data))
_
=
data
countsLock
.
Lock
()
counts
[
pid
][
1
][
1
]
++
countsLock
.
Unlock
()
case
<-
ctx
.
Done
()
:
return
...
...
@@ -175,7 +183,9 @@ func TestSimultMuxer(t *testing.T) {
for
{
select
{
case
m
:=
<-
mux1
.
Protocols
[
pid
]
.
GetPipe
()
.
Incoming
:
countsLock
.
Lock
()
counts
[
pid
][
0
][
1
]
++
countsLock
.
Unlock
()
// log.Debug("got %v", string(m.Data()))
_
=
m
case
<-
ctx
.
Done
()
:
...
...
@@ -195,10 +205,12 @@ func TestSimultMuxer(t *testing.T) {
limiter
:=
time
.
Tick
(
speed
)
for
{
<-
limiter
countsLock
.
Lock
()
got
:=
counts
[
0
][
0
][
0
]
+
counts
[
0
][
0
][
1
]
+
counts
[
0
][
1
][
0
]
+
counts
[
0
][
1
][
1
]
+
counts
[
1
][
0
][
0
]
+
counts
[
1
][
0
][
1
]
+
counts
[
1
][
1
][
0
]
+
counts
[
1
][
1
][
1
]
countsLock
.
Unlock
()
if
got
==
total
*
8
{
cancel
()
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论