Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
dms3
go-dms3
Commits
ebfdb3a4
Commit
ebfdb3a4
authored
Jul 23, 2015
by
Juan Benet
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1501 from ipfs/fix/notif-test
fix race condition in notifications test
parents
8c0ca5e3
47cd70fa
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
43 additions
and
21 deletions
+43
-21
p2p/net/mock/mock_notif_test.go
p2p/net/mock/mock_notif_test.go
+23
-10
p2p/net/swarm/swarm_notif_test.go
p2p/net/swarm/swarm_notif_test.go
+20
-11
No files found.
p2p/net/mock/mock_notif_test.go
View file @
ebfdb3a4
...
...
@@ -7,6 +7,7 @@ import (
ma
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr"
context
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/golang.org/x/net/context"
inet
"github.com/ipfs/go-ipfs/p2p/net"
peer
"github.com/ipfs/go-ipfs/p2p/peer"
)
func
TestNotifications
(
t
*
testing
.
T
)
{
...
...
@@ -42,31 +43,43 @@ func TestNotifications(t *testing.T) {
// test everyone got the correct connection opened calls
for
i
,
s
:=
range
nets
{
n
:=
notifiees
[
i
]
for
_
,
s2
:=
range
nets
{
var
actual
[]
inet
.
Conn
for
len
(
s
.
ConnsToPeer
(
s2
.
LocalPeer
()))
!=
len
(
actual
)
{
notifs
:=
make
(
map
[
peer
.
ID
][]
inet
.
Conn
)
for
j
,
s2
:=
range
nets
{
if
i
==
j
{
continue
}
// this feels a little sketchy, but its probably okay
for
len
(
s
.
ConnsToPeer
(
s2
.
LocalPeer
()))
!=
len
(
notifs
[
s2
.
LocalPeer
()])
{
select
{
case
c
:=
<-
n
.
connected
:
actual
=
append
(
actual
,
c
)
nfp
:=
notifs
[
c
.
RemotePeer
()]
notifs
[
c
.
RemotePeer
()]
=
append
(
nfp
,
c
)
case
<-
time
.
After
(
timeout
)
:
t
.
Fatal
(
"timeout"
)
}
}
}
for
p
,
cons
:=
range
notifs
{
expect
:=
s
.
ConnsToPeer
(
p
)
if
len
(
expect
)
!=
len
(
cons
)
{
t
.
Fatal
(
"got different number of connections"
)
}
expect
:=
s
.
ConnsToPeer
(
s2
.
LocalPeer
())
for
_
,
c1
:=
range
actual
{
found
:=
false
for
_
,
c
:=
range
cons
{
var
found
bool
for
_
,
c2
:=
range
expect
{
if
c
1
==
c2
{
if
c
==
c2
{
found
=
true
break
}
}
if
!
found
{
t
.
Error
(
"connection not found"
,
c1
,
len
(
expect
),
len
(
actual
)
)
t
.
Fatal
(
"connection not found
!
"
)
}
}
}
}
...
...
p2p/net/swarm/swarm_notif_test.go
View file @
ebfdb3a4
...
...
@@ -8,6 +8,7 @@ import (
context
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/golang.org/x/net/context"
inet
"github.com/ipfs/go-ipfs/p2p/net"
peer
"github.com/ipfs/go-ipfs/p2p/peer"
)
func
TestNotifications
(
t
*
testing
.
T
)
{
...
...
@@ -37,35 +38,43 @@ func TestNotifications(t *testing.T) {
// test everyone got the correct connection opened calls
for
i
,
s
:=
range
swarms
{
n
:=
notifiees
[
i
]
for
_
,
s2
:=
range
swarms
{
if
s
==
s2
{
notifs
:=
make
(
map
[
peer
.
ID
][]
inet
.
Conn
)
for
j
,
s2
:=
range
swarms
{
if
i
==
j
{
continue
}
var
actual
[]
inet
.
Conn
for
len
(
s
.
ConnectionsToPeer
(
s2
.
LocalPeer
()))
!=
len
(
actual
)
{
// this feels a little sketchy, but its probably okay
for
len
(
s
.
ConnectionsToPeer
(
s2
.
LocalPeer
()))
!=
len
(
notifs
[
s2
.
LocalPeer
()]
)
{
select
{
case
c
:=
<-
n
.
connected
:
actual
=
append
(
actual
,
c
)
nfp
:=
notifs
[
c
.
RemotePeer
()]
notifs
[
c
.
RemotePeer
()]
=
append
(
nfp
,
c
)
case
<-
time
.
After
(
timeout
)
:
t
.
Fatal
(
"timeout"
)
}
}
}
for
p
,
cons
:=
range
notifs
{
expect
:=
s
.
ConnectionsToPeer
(
p
)
if
len
(
expect
)
!=
len
(
cons
)
{
t
.
Fatal
(
"got different number of connections"
)
}
expect
:=
s
.
ConnectionsToPeer
(
s2
.
LocalPeer
())
for
_
,
c1
:=
range
actual
{
found
:=
false
for
_
,
c
:=
range
cons
{
var
found
bool
for
_
,
c2
:=
range
expect
{
if
c
1
==
c2
{
if
c
==
c2
{
found
=
true
break
}
}
if
!
found
{
t
.
Error
(
"connection not found"
)
t
.
Fatal
(
"connection not found
!
"
)
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment