js-libp2p/tests/swarm-test.js

255 lines
6.6 KiB
JavaScript
Raw Normal View History

2015-07-08 23:01:36 -07:00
var Lab = require('lab')
var Code = require('code')
2015-07-31 23:13:05 +02:00
var sinon = require('sinon')
2015-07-08 23:01:36 -07:00
var lab = exports.lab = Lab.script()
var experiment = lab.experiment
var test = lab.test
var beforeEach = lab.beforeEach
var afterEach = lab.afterEach
var expect = Code.expect
var multiaddr = require('multiaddr')
var Id = require('ipfs-peer-id')
var Peer = require('ipfs-peer')
2015-07-10 14:06:51 -07:00
var Swarm = require('../src/')
var Identify = require('../src/identify')
2015-07-08 23:01:36 -07:00
2015-07-09 13:53:03 -07:00
var swarmA
var swarmB
var peerA
var peerB
beforeEach(function (done) {
swarmA = new Swarm()
swarmB = new Swarm()
var c = new Counter(2, done)
2015-07-09 20:00:54 -07:00
swarmA.listen(8100, function () {
2015-07-09 13:53:03 -07:00
peerA = new Peer(Id.create(), [multiaddr('/ip4/127.0.0.1/tcp/' + swarmA.port)])
c.hit()
})
2015-07-09 20:00:54 -07:00
swarmB.listen(8101, function () {
2015-07-09 13:53:03 -07:00
peerB = new Peer(Id.create(), [multiaddr('/ip4/127.0.0.1/tcp/' + swarmB.port)])
c.hit()
2015-07-08 23:01:36 -07:00
})
2015-07-10 12:28:40 -07:00
})
2015-07-09 20:00:54 -07:00
2015-07-10 12:28:40 -07:00
afterEach(function (done) {
// This should be 2, but for some reason
// that will fail in most of the tests
var c = new Counter(1, done)
swarmA.closeListener(function () {
c.hit()
})
swarmB.closeListener(function () {
c.hit()
})
2015-07-09 13:53:03 -07:00
})
2015-07-15 12:20:52 -07:00
2015-07-30 20:44:10 +02:00
experiment('BASICS', function () {
experiment('Swarm', function () {
test('enforces instantiation with new', function (done) {
expect(function () {
Swarm()
}).to.throw('Swarm must be called with new')
done()
})
test('parses $IPFS_SWARM_PORT', function (done) {
process.env.IPFS_SWARM_PORT = 1111
var swarm = new Swarm()
expect(swarm.port).to.be.equal(1111)
process.env.IPFS_SWARM_PORT = undefined
done()
})
})
experiment('Swarm.listen', function (done) {
test('handles missing port', function (done) {
var swarm = new Swarm()
swarm.listen(done)
})
test('handles passed in port', function (done) {
var swarm = new Swarm()
swarm.listen(1234)
expect(swarm.port).to.be.equal(1234)
done()
})
})
2015-07-31 17:56:36 +02:00
experiment('Swarm.registerHandler', function () {
test('throws when registering a protcol handler twice', function (done) {
var swarm = new Swarm()
swarm.registerHandler('/sparkles/1.1.1', function () {})
swarm.registerHandler('/sparkles/1.1.1', function (err) {
expect(err).to.be.an.instanceOf(Error)
expect(err.message).to.be.equal('Handle for protocol already exists')
done()
})
})
})
2015-07-31 23:13:05 +02:00
experiment('Swarm.closeConns', function () {
test('calls end on all connections', function (done) {
swarmA.openConnection(peerB, function () {
var key = Object.keys(swarmA.connections)[0]
sinon.spy(swarmA.connections[key].conn, 'end')
swarmA.closeConns(function () {
expect(swarmA.connections[key].conn.end.called).to.be.equal(true)
done()
})
})
})
})
2015-07-30 20:44:10 +02:00
})
2015-07-09 13:53:03 -07:00
experiment('BASE', function () {
2015-07-10 12:28:40 -07:00
test('Open a stream', function (done) {
2015-07-08 23:01:36 -07:00
var protocol = '/sparkles/3.3.3'
var c = new Counter(2, done)
2015-07-10 12:28:40 -07:00
swarmB.registerHandler(protocol, function (stream) {
2015-07-09 13:53:03 -07:00
c.hit()
2015-07-08 23:01:36 -07:00
})
2015-07-09 13:53:03 -07:00
swarmA.openStream(peerB, protocol, function (err, stream) {
2015-07-08 23:01:36 -07:00
expect(err).to.not.be.instanceof(Error)
2015-07-09 13:53:03 -07:00
c.hit()
2015-07-08 23:01:36 -07:00
})
})
2015-07-09 20:00:54 -07:00
2015-07-10 12:28:40 -07:00
test('Reuse connection (from dialer)', function (done) {
2015-07-09 20:00:54 -07:00
var protocol = '/sparkles/3.3.3'
2015-07-15 11:34:37 -07:00
swarmB.registerHandler(protocol, function (stream) {})
2015-07-09 20:00:54 -07:00
swarmA.openStream(peerB, protocol, function (err, stream) {
expect(err).to.not.be.instanceof(Error)
2015-07-10 12:28:40 -07:00
swarmA.openStream(peerB, protocol, function (err, stream) {
expect(err).to.not.be.instanceof(Error)
expect(swarmA.connections.length === 1)
done()
})
2015-07-09 20:00:54 -07:00
})
})
test('Check for lastSeen', function (done) {
var protocol = '/sparkles/3.3.3'
swarmB.registerHandler(protocol, function (stream) {})
swarmA.openStream(peerB, protocol, function (err, stream) {
expect(err).to.not.be.instanceof(Error)
expect(peerB.lastSeen).to.be.instanceof(Date)
done()
})
})
2015-07-09 13:53:03 -07:00
})
2015-07-15 12:20:52 -07:00
2015-07-10 14:06:51 -07:00
experiment('IDENTIFY', function () {
test('Attach Identify, open a stream, see a peer update', function (done) {
2015-07-15 11:34:37 -07:00
swarmA.on('error', function (err) {
console.log('A - ', err)
})
swarmB.on('error', function (err) {
console.log('B - ', err)
})
2015-07-10 14:06:51 -07:00
var protocol = '/sparkles/3.3.3'
var identifyA = new Identify(swarmA, peerA)
var identifyB = new Identify(swarmB, peerB)
2015-07-15 11:34:37 -07:00
setTimeout(function () {
swarmB.registerHandler(protocol, function (stream) {})
2015-07-10 14:06:51 -07:00
2015-07-15 11:34:37 -07:00
swarmA.openStream(peerB, protocol, function (err, stream) {
expect(err).to.not.be.instanceof(Error)
})
2015-07-10 14:06:51 -07:00
2015-07-15 11:34:37 -07:00
identifyB.on('peer-update', function (answer) {
done()
})
identifyA.on('peer-update', function (answer) {})
}, 500)
2015-07-10 14:06:51 -07:00
})
2015-07-15 12:20:52 -07:00
test('Attach Identify, open a stream, reuse stream', function (done) {
var protocol = '/sparkles/3.3.3'
2015-07-10 14:06:51 -07:00
2015-07-15 12:20:52 -07:00
var identifyA = new Identify(swarmA, peerA)
var identifyB = new Identify(swarmB, peerB)
2015-07-10 14:06:51 -07:00
2015-07-15 12:20:52 -07:00
swarmA.registerHandler(protocol, function (stream) {})
swarmB.registerHandler(protocol, function (stream) {})
2015-07-10 14:06:51 -07:00
swarmA.openStream(peerB, protocol, function (err, stream) {
2015-07-15 11:34:40 -07:00
expect(err).to.not.be.instanceof(Error)
2015-07-15 12:20:52 -07:00
})
identifyB.on('peer-update', function (answer) {
2015-07-10 14:06:51 -07:00
expect(Object.keys(swarmB.connections).length).to.equal(1)
swarmB.openStream(peerA, protocol, function (err, stream) {
2015-07-15 12:20:52 -07:00
expect(err).to.not.be.instanceof(Error)
expect(Object.keys(swarmB.connections).length).to.equal(1)
done()
})
2015-07-10 14:06:51 -07:00
})
2015-07-15 12:20:52 -07:00
identifyA.on('peer-update', function (answer) {})
2015-07-10 14:06:51 -07:00
})
2015-07-15 12:20:52 -07:00
test('Attach Identify, reuse peer', function (done) {
var protocol = '/sparkles/3.3.3'
var identifyA = new Identify(swarmA, peerA)
var identifyB = new Identify(swarmB, peerB) // eslint-disable-line no-unused-vars
swarmA.registerHandler(protocol, function (stream) {})
swarmB.registerHandler(protocol, function (stream) {})
var restartA = function (cb) {
swarmA.openStream(peerB, protocol, function (err, stream) {
expect(err).to.not.be.instanceof(Error)
stream.end(cb)
})
}
restartA(function () {
identifyA.once('peer-update', function () {
expect(peerA.previousObservedAddrs.length).to.be.equal(1)
var c = new Counter(2, done)
swarmA.closeConns(c.hit.bind(c))
swarmB.closeConns(c.hit.bind(c))
})
})
})
2015-07-10 14:06:51 -07:00
})
2015-07-08 23:01:36 -07:00
2015-07-09 13:53:09 -07:00
experiment('HARDNESS', function () {})
2015-07-09 13:53:03 -07:00
function Counter (target, callback) {
var c = 0
this.hit = count
2015-07-08 23:01:36 -07:00
2015-07-09 13:53:03 -07:00
function count () {
c += 1
if (c === target) {
callback()
2015-07-08 23:01:36 -07:00
}
}
2015-07-09 13:53:03 -07:00
}
2015-07-10 12:28:40 -07:00
2015-07-10 14:06:51 -07:00
// function checkErr (err) {
// console.log('err')
// expect(err).to.be.instanceof(Error)
// }