js-libp2p-tcp/test/index.spec.js

510 lines
13 KiB
JavaScript
Raw Normal View History

/* eslint-env mocha */
'use strict'
2016-08-05 14:22:18 +02:00
const pull = require('pull-stream')
2017-03-21 14:27:16 +00:00
const chai = require('chai')
const dirtyChai = require('dirty-chai')
const expect = chai.expect
chai.use(dirtyChai)
const TCP = require('../src')
const net = require('net')
const multiaddr = require('multiaddr')
const Connection = require('interface-connection').Connection
describe('instantiate the transport', () => {
2016-08-05 14:22:18 +02:00
it('create', () => {
const tcp = new TCP()
2017-03-21 14:27:16 +00:00
expect(tcp).to.exist()
})
})
describe('listen', () => {
let tcp
beforeEach(() => {
tcp = new TCP()
})
it('close listener with connections, through timeout', (done) => {
const mh = multiaddr('/ip4/127.0.0.1/tcp/9090/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw')
const listener = tcp.createListener((conn) => {
2016-08-05 14:22:18 +02:00
pull(conn, conn)
})
2016-08-05 14:22:18 +02:00
listener.listen(mh, () => {
const socket1 = net.connect(9090)
const socket2 = net.connect(9090)
2016-08-05 14:22:18 +02:00
socket1.write('Some data that is never handled')
socket1.end()
socket1.on('error', () => {})
socket2.on('error', () => {})
socket1.on('connect', () => {
listener.close(done)
})
})
})
it('listen on port 0', (done) => {
const mh = multiaddr('/ip4/127.0.0.1/tcp/0')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.close(done)
})
})
it('listen on IPv6 addr', (done) => {
const mh = multiaddr('/ip6/::/tcp/9090')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.close(done)
})
})
it('listen on any Interface', (done) => {
const mh = multiaddr('/ip4/0.0.0.0/tcp/9090')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.close(done)
})
})
it('getAddrs', (done) => {
const mh = multiaddr('/ip4/127.0.0.1/tcp/9090')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.getAddrs((err, multiaddrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(multiaddrs.length).to.equal(1)
expect(multiaddrs[0]).to.deep.equal(mh)
listener.close(done)
})
})
})
it('getAddrs on port 0 listen', (done) => {
const mh = multiaddr('/ip4/127.0.0.1/tcp/0')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.getAddrs((err, multiaddrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(multiaddrs.length).to.equal(1)
listener.close(done)
})
})
})
it('getAddrs from listening on 0.0.0.0', (done) => {
const mh = multiaddr('/ip4/0.0.0.0/tcp/9090')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.getAddrs((err, multiaddrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(multiaddrs.length > 0).to.equal(true)
expect(multiaddrs[0].toString().indexOf('0.0.0.0')).to.equal(-1)
listener.close(done)
})
})
})
it('getAddrs from listening on 0.0.0.0 and port 0', (done) => {
const mh = multiaddr('/ip4/0.0.0.0/tcp/0')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.getAddrs((err, multiaddrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(multiaddrs.length > 0).to.equal(true)
expect(multiaddrs[0].toString().indexOf('0.0.0.0')).to.equal(-1)
listener.close(done)
})
})
})
it('getAddrs preserves IPFS Id', (done) => {
const mh = multiaddr('/ip4/127.0.0.1/tcp/9090/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw')
const listener = tcp.createListener((conn) => {})
listener.listen(mh, () => {
listener.getAddrs((err, multiaddrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(multiaddrs.length).to.equal(1)
expect(multiaddrs[0]).to.deep.equal(mh)
listener.close(done)
})
})
})
})
describe('dial', () => {
let tcp
let listener
const ma = multiaddr('/ip4/127.0.0.1/tcp/9090')
beforeEach((done) => {
tcp = new TCP()
listener = tcp.createListener((conn) => {
2016-08-05 14:22:18 +02:00
pull(
conn,
2017-10-13 17:17:11 +02:00
pull.map((x) => Buffer.from(x.toString() + '!')),
2016-08-05 14:22:18 +02:00
conn
)
})
2016-08-05 14:22:18 +02:00
listener.listen(ma, done)
})
afterEach((done) => {
listener.close(done)
})
it('dial on IPv4', (done) => {
2016-08-05 14:22:18 +02:00
pull(
pull.values(['hey']),
tcp.dial(ma),
pull.collect((err, values) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(values).to.eql([Buffer.from('hey!')])
2016-08-05 14:22:18 +02:00
done()
})
)
})
2016-06-23 08:35:49 +01:00
it('dial to non existent listener', (done) => {
const ma = multiaddr('/ip4/127.0.0.1/tcp/8989')
2016-08-05 14:22:18 +02:00
pull(
tcp.dial(ma),
pull.onEnd((err) => {
2017-03-21 14:27:16 +00:00
expect(err).to.exist()
2016-08-05 14:22:18 +02:00
done()
})
)
2016-06-23 08:35:49 +01:00
})
it('dial on IPv6', (done) => {
const ma = multiaddr('/ip6/::/tcp/9066')
const listener = tcp.createListener((conn) => {
2016-08-05 14:22:18 +02:00
pull(conn, conn)
})
2016-08-05 14:22:18 +02:00
listener.listen(ma, () => {
pull(
pull.values(['hey']),
tcp.dial(ma),
pull.collect((err, values) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(values).to.be.eql([Buffer.from('hey')])
2016-08-05 14:22:18 +02:00
listener.close(done)
})
)
})
})
2016-08-05 14:22:18 +02:00
it.skip('dial and destroy on listener', (done) => {
// TODO: why is this failing
let count = 0
2016-08-05 14:22:18 +02:00
const closed = ++count === 2 ? finish() : null
const ma = multiaddr('/ip6/::/tcp/9067')
const listener = tcp.createListener((conn) => {
2016-08-05 14:22:18 +02:00
pull(
pull.empty(),
conn,
pull.onEnd(closed)
)
})
2016-08-05 14:22:18 +02:00
listener.listen(ma, () => {
pull(tcp.dial(ma), pull.onEnd(closed))
})
function finish () {
listener.close(done)
}
})
it('dial and destroy on dialer', (done) => {
let count = 0
const destroyed = () => ++count === 2 ? finish() : null
const ma = multiaddr('/ip6/::/tcp/9068')
const listener = tcp.createListener((conn) => {
2016-08-05 14:22:18 +02:00
pull(conn, pull.onEnd(destroyed))
})
2016-08-05 14:22:18 +02:00
listener.listen(ma, () => {
pull(
pull.empty(),
tcp.dial(ma),
pull.onEnd(destroyed)
)
})
function finish () {
listener.close(done)
}
})
it('dial on IPv4 with IPFS Id', (done) => {
const ma = multiaddr('/ip4/127.0.0.1/tcp/9090/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw')
const conn = tcp.dial(ma)
2016-08-05 14:22:18 +02:00
pull(
pull.values(['hey']),
conn,
pull.collect((err, res) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(res).to.be.eql([Buffer.from('hey!')])
2016-08-05 14:22:18 +02:00
done()
})
)
})
})
describe('filter addrs', () => {
let tcp
before(() => {
tcp = new TCP()
})
2016-08-05 14:22:18 +02:00
it('filter valid addrs for this transport', () => {
const mh1 = multiaddr('/ip4/127.0.0.1/tcp/9090')
const mh2 = multiaddr('/ip4/127.0.0.1/udp/9090')
const mh3 = multiaddr('/ip4/127.0.0.1/tcp/9090/http')
const mh4 = multiaddr('/ip4/127.0.0.1/tcp/9090/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw')
const mh5 = multiaddr('/ip4/127.0.0.1/tcp/9090/http/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw')
const mh6 = multiaddr('/ip4/127.0.0.1/tcp/9090/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw' +
'/p2p-circuit/ipfs/Qmb6owHp6eaWArVbcJJbQSyifyJBttMMjYV76N2hMbf5Vw')
const valid = tcp.filter([mh1, mh2, mh3, mh4, mh5, mh6])
expect(valid.length).to.equal(2)
expect(valid[0]).to.deep.equal(mh1)
expect(valid[1]).to.deep.equal(mh4)
})
2016-08-05 14:22:18 +02:00
it('filter a single addr for this transport', () => {
const mh1 = multiaddr('/ip4/127.0.0.1/tcp/9090')
const valid = tcp.filter(mh1)
expect(valid.length).to.equal(1)
expect(valid[0]).to.deep.equal(mh1)
})
})
describe('valid Connection', () => {
let tcp
beforeEach(() => {
tcp = new TCP()
})
const ma = multiaddr('/ip4/127.0.0.1/tcp/9090')
it('get observed addrs', (done) => {
2016-08-05 14:22:18 +02:00
let dialerObsAddrs
const listener = tcp.createListener((conn) => {
2017-03-21 14:27:16 +00:00
expect(conn).to.exist()
conn.getObservedAddrs((err, addrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
dialerObsAddrs = addrs
2016-08-05 14:22:18 +02:00
pull(pull.empty(), conn)
})
})
listener.listen(ma, () => {
const conn = tcp.dial(ma)
2016-08-05 14:22:18 +02:00
pull(
conn,
pull.onEnd(endHandler)
)
2016-08-05 14:22:18 +02:00
function endHandler () {
conn.getObservedAddrs((err, addrs) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2016-08-05 14:22:18 +02:00
pull(pull.empty(), conn)
closeAndAssert(listener, addrs)
})
2016-08-05 14:22:18 +02:00
}
function closeAndAssert (listener, addrs) {
listener.close(() => {
expect(addrs[0]).to.deep.equal(ma)
expect(dialerObsAddrs.length).to.equal(1)
done()
})
}
})
})
it('get Peer Info', (done) => {
const listener = tcp.createListener((conn) => {
2017-03-21 14:27:16 +00:00
expect(conn).to.exist()
conn.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.exist()
expect(peerInfo).to.not.exist()
2016-08-05 14:22:18 +02:00
pull(pull.empty(), conn)
})
})
listener.listen(ma, () => {
const conn = tcp.dial(ma)
2016-08-05 14:22:18 +02:00
pull(conn, pull.onEnd(endHandler))
2016-08-05 14:22:18 +02:00
function endHandler () {
conn.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.exist()
expect(peerInfo).to.not.exist()
listener.close(done)
})
2016-08-05 14:22:18 +02:00
}
})
})
it('set Peer Info', (done) => {
const listener = tcp.createListener((conn) => {
2017-03-21 14:27:16 +00:00
expect(conn).to.exist()
conn.setPeerInfo('batatas')
conn.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(peerInfo).to.equal('batatas')
2016-08-05 14:22:18 +02:00
pull(pull.empty(), conn)
})
})
listener.listen(ma, () => {
const conn = tcp.dial(ma)
2016-08-05 14:22:18 +02:00
pull(conn, pull.onEnd(endHandler))
2016-08-05 14:22:18 +02:00
function endHandler () {
conn.setPeerInfo('arroz')
conn.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(peerInfo).to.equal('arroz')
listener.close(done)
})
2016-08-05 14:22:18 +02:00
}
})
})
})
describe.skip('turbolence', () => {
it('dialer - emits error on the other end is terminated abruptly', (done) => {})
it('listener - emits error on the other end is terminated abruptly', (done) => {})
})
describe('Connection wrap', () => {
let tcp
let listener
const ma = multiaddr('/ip4/127.0.0.1/tcp/9090')
beforeEach((done) => {
tcp = new TCP()
listener = tcp.createListener((conn) => {
2016-08-05 14:22:18 +02:00
pull(conn, conn)
})
listener.on('listening', done)
listener.listen(ma)
})
afterEach((done) => {
listener.close(done)
})
it('simple wrap', (done) => {
const conn = tcp.dial(ma)
conn.setPeerInfo('peerInfo')
const connWrap = new Connection(conn)
2016-08-05 14:22:18 +02:00
pull(
pull.values(['hey']),
connWrap,
pull.collect((err, chunks) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(chunks).to.be.eql([Buffer.from('hey')])
2016-08-05 14:22:18 +02:00
connWrap.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2016-08-05 14:22:18 +02:00
expect(peerInfo).to.equal('peerInfo')
done()
})
})
2016-08-05 14:22:18 +02:00
)
})
it('buffer wrap', (done) => {
const conn = tcp.dial(ma)
const connWrap = new Connection()
2016-08-05 14:22:18 +02:00
pull(
pull.values(['hey']),
connWrap,
pull.collect((err, chunks) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(chunks).to.be.eql([Buffer.from('hey')])
2016-08-05 14:22:18 +02:00
done()
})
)
connWrap.setInnerConn(conn)
})
it('overload wrap', (done) => {
const conn = tcp.dial(ma)
const connWrap = new Connection(conn)
connWrap.getPeerInfo = (callback) => {
callback(null, 'none')
}
conn.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.exist()
})
connWrap.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
expect(peerInfo).to.equal('none')
})
2016-08-05 14:22:18 +02:00
pull(
pull.values(['hey']),
connWrap,
pull.collect((err, chunks) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(chunks).to.be.eql([Buffer.from('hey')])
2016-08-05 14:22:18 +02:00
done()
})
)
})
it('dial error', (done) => {
tcp.dial(multiaddr('/ip4/999.0.0.1/tcp/1234'), (err) => {
expect(err).to.exist()
done()
})
})
it('matryoshka wrap', (done) => {
const conn = tcp.dial(ma)
const connWrap1 = new Connection(conn)
const connWrap2 = new Connection(connWrap1)
const connWrap3 = new Connection(connWrap2)
conn.getPeerInfo = (callback) => {
callback(null, 'inner doll')
}
2016-08-05 14:22:18 +02:00
pull(
pull.values(['hey']),
connWrap3,
pull.collect((err, chunks) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2017-10-13 17:17:11 +02:00
expect(chunks).to.be.eql([Buffer.from('hey')])
2016-08-05 14:22:18 +02:00
connWrap3.getPeerInfo((err, peerInfo) => {
2017-03-21 14:27:16 +00:00
expect(err).to.not.exist()
2016-08-05 14:22:18 +02:00
expect(peerInfo).to.equal('inner doll')
done()
})
})
2016-08-05 14:22:18 +02:00
)
})
})