Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
adam.huang
go-libp2p
Commits
73f16a9f
Commit
73f16a9f
authored
Nov 22, 2016
by
Jeromy Johnson
Committed by
GitHub
Nov 22, 2016
Browse files
Merge pull request #159 from libp2p/feat/set-protos
address protocol downgrade bug
parents
4855e003
f4ea270c
Changes
3
Hide whitespace changes
Inline
Side-by-side
p2p/host/basic/basic_host_test.go
View file @
73f16a9f
...
...
@@ -241,3 +241,62 @@ func TestNewDialOld(t *testing.T) {
s
.
Close
()
}
func
TestProtoDowngrade
(
t
*
testing
.
T
)
{
ctx
,
cancel
:=
context
.
WithCancel
(
context
.
Background
())
defer
cancel
()
h1
,
h2
:=
getHostPair
(
ctx
,
t
)
defer
h1
.
Close
()
defer
h2
.
Close
()
connectedOn
:=
make
(
chan
protocol
.
ID
,
16
)
h1
.
SetStreamHandler
(
"/testing/1.0.0"
,
func
(
s
inet
.
Stream
)
{
connectedOn
<-
s
.
Protocol
()
s
.
Close
()
})
s
,
err
:=
h2
.
NewStream
(
ctx
,
h1
.
ID
(),
"/testing/1.0.0"
,
"/testing"
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
assertWait
(
t
,
connectedOn
,
"/testing/1.0.0"
)
if
s
.
Protocol
()
!=
"/testing/1.0.0"
{
t
.
Fatal
(
"shoould have gotten /testing"
)
}
s
.
Close
()
h1
.
Network
()
.
ConnsToPeer
(
h2
.
ID
())[
0
]
.
Close
()
time
.
Sleep
(
time
.
Millisecond
*
50
)
// allow notifications to propogate
h1
.
RemoveStreamHandler
(
"/testing/1.0.0"
)
h1
.
SetStreamHandler
(
"/testing"
,
func
(
s
inet
.
Stream
)
{
connectedOn
<-
s
.
Protocol
()
s
.
Close
()
})
h2pi
:=
h2
.
Peerstore
()
.
PeerInfo
(
h2
.
ID
())
if
err
:=
h1
.
Connect
(
ctx
,
h2pi
);
err
!=
nil
{
t
.
Fatal
(
err
)
}
s2
,
err
:=
h2
.
NewStream
(
ctx
,
h1
.
ID
(),
"/testing/1.0.0"
,
"/testing"
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
_
,
err
=
s2
.
Write
(
nil
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
assertWait
(
t
,
connectedOn
,
"/testing"
)
if
s2
.
Protocol
()
!=
"/testing"
{
t
.
Fatal
(
"shoould have gotten /testing"
)
}
s2
.
Close
()
}
p2p/protocol/identify/id.go
View file @
73f16a9f
...
...
@@ -193,7 +193,7 @@ func (ids *IDService) consumeMessage(mes *pb.Identify, c inet.Conn) {
p
:=
c
.
RemotePeer
()
// mes.Protocols
ids
.
Host
.
Peerstore
()
.
Add
Protocols
(
p
,
mes
.
Protocols
...
)
ids
.
Host
.
Peerstore
()
.
Set
Protocols
(
p
,
mes
.
Protocols
...
)
// mes.ObservedAddr
ids
.
consumeObservedAddress
(
mes
.
GetObservedAddr
(),
c
)
...
...
package.json
View file @
73f16a9f
...
...
@@ -139,9 +139,9 @@
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
XXCcQ7CLg5a81Ui9TTR35QcR4y7ZyihxwfjqaHfUVcVo
"
,
"hash"
:
"Qm
eXj9VAjmYQZxpmVz7VzccbJrpmr8qkCDSjfVNsPTWTYU
"
,
"name"
:
"go-libp2p-peerstore"
,
"version"
:
"1.
3
.0"
"version"
:
"1.
4
.0"
},
{
"author"
:
"whyrusleeping"
,
...
...
@@ -193,15 +193,15 @@
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
U3pGGVT1riXp5dBJbNrGpxssVScfvk9236drRHZZbKJ1
"
,
"hash"
:
"Qm
Qx1dHDDYENugYgqA22BaBrRfuv1coSsuPiM7rYh1wwGH
"
,
"name"
:
"go-libp2p-net"
,
"version"
:
"1.6.
0
"
"version"
:
"1.6.
1
"
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
X4j1JhubdEt4EB1JY1mMKTvJwPZSRzTv3uwh5zaDqyAi
"
,
"hash"
:
"Qm
Y2otvyPM2sTaDsczo7Yuosg98sUMCJ9qx1gpPaAPTS9B
"
,
"name"
:
"go-libp2p-metrics"
,
"version"
:
"1.6.
0
"
"version"
:
"1.6.
1
"
},
{
"author"
:
"whyrusleeping"
,
...
...
@@ -211,15 +211,15 @@
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
b6UFbVu1grhv5o5KnouvtZ6cqdrjXj6zLejAHWunxgCt
"
,
"hash"
:
"Qm
PTGbC34bPKaUm9wTxBo7zSCac7pDuG42ZmnXC718CKZZ
"
,
"name"
:
"go-libp2p-host"
,
"version"
:
"1.3.
0
"
"version"
:
"1.3.
1
"
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
NafAGBU21iQmLudMT2z1kqgEGhjUrNoK9a3v4azd8ei4
"
,
"hash"
:
"Qm
V82zccDVU2fPv7E6wBD6cPy55brSFGHNeTVg5MZ6ZDQ8
"
,
"name"
:
"go-libp2p-swarm"
,
"version"
:
"1.5.
0
"
"version"
:
"1.5.
1
"
},
{
"author"
:
"whyrusleeping"
,
...
...
@@ -229,15 +229,15 @@
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
cDTquYLTYirqj71RRWKUWEEw3nJt11Awzun5ep8kfY7W
"
,
"hash"
:
"Qm
bUDXBMqSe4VCRgTMeAfyBh1T3GBnELEBXobZDL7cjVgs
"
,
"name"
:
"go-libp2p-netutil"
,
"version"
:
"0.1.
0
"
"version"
:
"0.1.
1
"
},
{
"author"
:
"whyrusleeping"
,
"hash"
:
"Qm
YjDhB1VkuP5ATkqjdnPHfA2huyfcydNMXoGdtEvTNcYL
"
,
"hash"
:
"Qm
SzhYTPRvh5nUJnRfYBW52QGX6jekULCRQcrxRs8hmzj4
"
,
"name"
:
"go-libp2p-blankhost"
,
"version"
:
"0.1.
0
"
"version"
:
"0.1.
1
"
}
],
"gxVersion"
:
"0.4.0"
,
...
...
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