mirror of
https://github.com/fluencelabs/js-libp2p
synced 2025-03-30 06:11:05 +00:00
* refactor: add js-libp2p-connection-manager to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Pedro Teixeira <i@pgte.me> Co-authored-by: Vasco Santos <vasco.santos@ua.pt> * test(conn-mgr): only run in node * refactor: add js-libp2p-identify to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Friedel Ziegelmayer <dignifiedquire@gmail.com> Co-authored-by: Hugo Dias <hugomrdias@gmail.com> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Maciej Krüger <mkg20001@gmail.com> Co-authored-by: Richard Littauer <richard.littauer@gmail.com> Co-authored-by: Vasco Santos <vasco.santos@moxy.studio> Co-authored-by: Yusef Napora <yusef@protocol.ai> Co-authored-by: ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com> * refactor: add libp2p-pnet to repo Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Vasco Santos <vasco.santos@moxy.studio> * refactor: add libp2p-ping to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Francisco Baio Dias <xicombd@gmail.com> Co-authored-by: Friedel Ziegelmayer <dignifiedquire@gmail.com> Co-authored-by: Hugo Dias <mail@hugodias.me> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: João Antunes <j.goncalo.antunes@gmail.com> Co-authored-by: Richard Littauer <richard.littauer@gmail.com> Co-authored-by: Vasco Santos <vasco.santos@moxy.studio> Co-authored-by: Vasco Santos <vasco.santos@ua.pt> Co-authored-by: ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com> * refactor: add libp2p-circuit to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Dmitriy Ryajov <dryajov@gmail.com> Co-authored-by: Friedel Ziegelmayer <dignifiedquire@gmail.com> Co-authored-by: Hugo Dias <mail@hugodias.me> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Maciej Krüger <mkg20001@gmail.com> Co-authored-by: Oli Evans <oli@tableflip.io> Co-authored-by: Pedro Teixeira <i@pgte.me> Co-authored-by: Vasco Santos <vasco.santos@ua.pt> Co-authored-by: Victor Bjelkholm <victorbjelkholm@gmail.com> Co-authored-by: Yusef Napora <yusef@napora.org> Co-authored-by: dirkmc <dirk@mccormick.cx> * test(switch): avoid using instanceof * chore(switch): update bignumber dep * refactor(circuit): clean up tests * refactor(switch): consolidate get peer utils * test(identify): do deep checks of addresses * test(identify): bump timeout for identify test * test(switch): tidy up limit dialer test * refactor(switch): remove redundant circuit tests * chore: add coverage script * refactor(circuit): consolidate get peer info * docs: reference original repositories in each sub readme * docs: fix comment * refactor: clean up sub package.json files and readmes
193 lines
4.7 KiB
JavaScript
193 lines
4.7 KiB
JavaScript
/* eslint-env mocha */
|
|
'use strict'
|
|
|
|
const pull = require('pull-stream/pull')
|
|
const values = require('pull-stream/sources/values')
|
|
const chai = require('chai')
|
|
const dirtyChai = require('dirty-chai')
|
|
const expect = chai.expect
|
|
chai.use(dirtyChai)
|
|
const pair = require('pull-pair/duplex')
|
|
const PeerInfo = require('peer-info')
|
|
const lp = require('pull-length-prefixed')
|
|
const multiaddr = require('multiaddr')
|
|
|
|
const msg = require('libp2p-identify').message
|
|
const identify = require('libp2p-identify')
|
|
|
|
describe('identify.dialer', () => {
|
|
let original
|
|
|
|
before(function (done) {
|
|
this.timeout(20 * 1000)
|
|
|
|
PeerInfo.create((err, info) => {
|
|
if (err) {
|
|
return done(err)
|
|
}
|
|
|
|
original = info
|
|
done()
|
|
})
|
|
})
|
|
|
|
afterEach(() => {
|
|
original.multiaddrs.clear()
|
|
original.protocols.clear()
|
|
})
|
|
|
|
it('works', (done) => {
|
|
const p = pair()
|
|
original.multiaddrs.add(multiaddr('/ip4/127.0.0.1/tcp/5002'))
|
|
original.protocols.add('/echo/1.0.0')
|
|
original.protocols.add('/ping/1.0.0')
|
|
|
|
const input = msg.encode({
|
|
protocolVersion: 'ipfs/0.1.0',
|
|
agentVersion: 'na',
|
|
publicKey: original.id.pubKey.bytes,
|
|
listenAddrs: [multiaddr('/ip4/127.0.0.1/tcp/5002').buffer],
|
|
observedAddr: multiaddr('/ip4/127.0.0.1/tcp/5001').buffer,
|
|
protocols: Array.from(original.protocols)
|
|
})
|
|
|
|
pull(
|
|
values([input]),
|
|
lp.encode(),
|
|
p[0]
|
|
)
|
|
|
|
identify.dialer(p[1], (err, info, observedAddrs) => {
|
|
expect(err).to.not.exist()
|
|
expect(info.id.pubKey.bytes)
|
|
.to.eql(original.id.pubKey.bytes)
|
|
|
|
expect(info.multiaddrs.has(original.multiaddrs.toArray()[0]))
|
|
.to.eql(true)
|
|
|
|
expect(multiaddr('/ip4/127.0.0.1/tcp/5001').equals(observedAddrs[0]))
|
|
.to.eql(true)
|
|
|
|
expect(info.protocols).to.eql(original.protocols)
|
|
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('should handle missing protocols', (done) => {
|
|
const p = pair()
|
|
original.multiaddrs.add(multiaddr('/ip4/127.0.0.1/tcp/5002'))
|
|
|
|
const input = msg.encode({
|
|
protocolVersion: 'ipfs/0.1.0',
|
|
agentVersion: 'na',
|
|
publicKey: original.id.pubKey.bytes,
|
|
listenAddrs: [multiaddr('/ip4/127.0.0.1/tcp/5002').buffer],
|
|
observedAddr: multiaddr('/ip4/127.0.0.1/tcp/5001').buffer,
|
|
protocols: Array.from(original.protocols)
|
|
})
|
|
|
|
pull(
|
|
values([input]),
|
|
lp.encode(),
|
|
p[0]
|
|
)
|
|
|
|
identify.dialer(p[1], (err, info, observedAddrs) => {
|
|
expect(err).to.not.exist()
|
|
expect(info.id.pubKey.bytes)
|
|
.to.eql(original.id.pubKey.bytes)
|
|
|
|
expect(info.multiaddrs.has(original.multiaddrs.toArray()[0]))
|
|
.to.eql(true)
|
|
|
|
expect(multiaddr('/ip4/127.0.0.1/tcp/5001').equals(observedAddrs[0]))
|
|
.to.eql(true)
|
|
|
|
expect(Array.from(info.protocols)).to.eql([])
|
|
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('does not crash with invalid listen addresses', (done) => {
|
|
const p = pair()
|
|
original.multiaddrs.add(multiaddr('/ip4/127.0.0.1/tcp/5002'))
|
|
const input = msg.encode({
|
|
protocolVersion: 'ipfs/0.1.0',
|
|
agentVersion: 'na',
|
|
publicKey: original.id.pubKey.bytes,
|
|
listenAddrs: [Buffer.from('ffac010203')],
|
|
observedAddr: Buffer.from('ffac010203')
|
|
})
|
|
|
|
pull(
|
|
values([input]),
|
|
lp.encode(),
|
|
p[0]
|
|
)
|
|
|
|
identify.dialer(p[1], (err, info, observedAddrs) => {
|
|
expect(err).to.exist()
|
|
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('does not crash with invalid observed address', (done) => {
|
|
const p = pair()
|
|
original.multiaddrs.add(multiaddr('/ip4/127.0.0.1/tcp/5002'))
|
|
const input = msg.encode({
|
|
protocolVersion: 'ipfs/0.1.0',
|
|
agentVersion: 'na',
|
|
publicKey: original.id.pubKey.bytes,
|
|
listenAddrs: [multiaddr('/ip4/127.0.0.1/tcp/5002').buffer],
|
|
observedAddr: Buffer.from('ffac010203')
|
|
})
|
|
|
|
pull(
|
|
values([input]),
|
|
lp.encode(),
|
|
p[0]
|
|
)
|
|
|
|
identify.dialer(p[1], (err, info, observedAddrs) => {
|
|
expect(err).to.exist()
|
|
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('should return an error with mismatched peerInfo data', function (done) {
|
|
this.timeout(10e3)
|
|
|
|
const p = pair()
|
|
original.multiaddrs.add(multiaddr('/ip4/127.0.0.1/tcp/5002'))
|
|
const input = msg.encode({
|
|
protocolVersion: 'ipfs/0.1.0',
|
|
agentVersion: 'na',
|
|
publicKey: original.id.pubKey.bytes,
|
|
listenAddrs: [multiaddr('/ip4/127.0.0.1/tcp/5002').buffer],
|
|
observedAddr: multiaddr('/ip4/127.0.0.1/tcp/5001').buffer
|
|
})
|
|
|
|
PeerInfo.create((err, info) => {
|
|
if (err) {
|
|
return done(err)
|
|
}
|
|
|
|
pull(
|
|
values([input]),
|
|
lp.encode(),
|
|
p[0]
|
|
)
|
|
|
|
identify.dialer(p[1], info, (err, peerInfo) => {
|
|
expect(err).to.exist()
|
|
expect(peerInfo).to.not.exist()
|
|
done()
|
|
})
|
|
})
|
|
})
|
|
})
|