2017-07-04 11:43:45 +01:00
|
|
|
/* eslint-env mocha */
|
|
|
|
'use strict'
|
|
|
|
|
|
|
|
const chai = require('chai')
|
|
|
|
chai.use(require('dirty-chai'))
|
|
|
|
const expect = chai.expect
|
|
|
|
const signalling = require('libp2p-webrtc-star/src/sig-server')
|
|
|
|
const parallel = require('async/parallel')
|
2017-11-27 10:10:36 +01:00
|
|
|
const utils = require('./utils/node')
|
2017-07-04 11:43:45 +01:00
|
|
|
const createNode = utils.createNode
|
|
|
|
const echo = utils.echo
|
|
|
|
|
2017-11-27 10:10:36 +01:00
|
|
|
describe('peer discovery', () => {
|
2017-07-04 11:43:45 +01:00
|
|
|
let nodeA
|
|
|
|
let nodeB
|
|
|
|
let port = 24642
|
|
|
|
let ss
|
|
|
|
|
|
|
|
function setup (options) {
|
|
|
|
before((done) => {
|
|
|
|
port++
|
|
|
|
parallel([
|
|
|
|
(cb) => {
|
|
|
|
signalling.start({ port: port }, (err, server) => {
|
|
|
|
expect(err).to.not.exist()
|
|
|
|
ss = server
|
|
|
|
cb()
|
|
|
|
})
|
|
|
|
},
|
|
|
|
(cb) => createNode([
|
|
|
|
'/ip4/0.0.0.0/tcp/0',
|
2017-09-03 14:39:55 +01:00
|
|
|
`/ip4/127.0.0.1/tcp/${port}/ws/p2p-webrtc-star`
|
2017-07-04 11:43:45 +01:00
|
|
|
], options, (err, node) => {
|
|
|
|
expect(err).to.not.exist()
|
|
|
|
nodeA = node
|
|
|
|
node.handle('/echo/1.0.0', echo)
|
|
|
|
node.start(cb)
|
|
|
|
}),
|
|
|
|
(cb) => createNode([
|
|
|
|
'/ip4/0.0.0.0/tcp/0',
|
2017-09-03 14:39:55 +01:00
|
|
|
`/ip4/127.0.0.1/tcp/${port}/ws/p2p-webrtc-star`
|
2017-07-04 11:43:45 +01:00
|
|
|
], options, (err, node) => {
|
|
|
|
expect(err).to.not.exist()
|
|
|
|
nodeB = node
|
|
|
|
node.handle('/echo/1.0.0', echo)
|
|
|
|
node.start(cb)
|
|
|
|
})
|
|
|
|
], done)
|
|
|
|
})
|
|
|
|
|
|
|
|
after((done) => {
|
|
|
|
parallel([
|
|
|
|
(cb) => nodeA.stop(cb),
|
|
|
|
(cb) => nodeB.stop(cb),
|
|
|
|
(cb) => ss.stop(done)
|
|
|
|
], done)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('MulticastDNS', () => {
|
|
|
|
setup({ mdns: true })
|
|
|
|
|
2017-10-26 04:51:36 -07:00
|
|
|
it('find a peer', function (done) {
|
2017-11-27 10:10:36 +01:00
|
|
|
this.timeout(15 * 1000)
|
|
|
|
|
2017-07-04 11:43:45 +01:00
|
|
|
nodeA.once('peer:discovery', (peerInfo) => {
|
|
|
|
expect(nodeB.peerInfo.id.toB58String())
|
|
|
|
.to.eql(peerInfo.id.toB58String())
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
// TODO needs a delay (this test is already long)
|
|
|
|
describe.skip('WebRTCStar', () => {
|
|
|
|
setup({ webRTCStar: true })
|
|
|
|
|
2017-10-26 04:51:36 -07:00
|
|
|
it('find a peer', function (done) {
|
2017-11-27 10:10:36 +01:00
|
|
|
this.timeout(15 * 1000)
|
2017-07-04 11:43:45 +01:00
|
|
|
nodeA.once('peer:discovery', (peerInfo) => {
|
|
|
|
expect(nodeB.peerInfo.id.toB58String())
|
|
|
|
.to.eql(peerInfo.id.toB58String())
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('MulticastDNS + WebRTCStar', () => {
|
|
|
|
setup({
|
|
|
|
webRTCStar: true,
|
|
|
|
mdns: true
|
|
|
|
})
|
|
|
|
|
2017-10-26 04:51:36 -07:00
|
|
|
it('find a peer', function (done) {
|
2017-11-27 10:10:36 +01:00
|
|
|
this.timeout(15 * 1000)
|
2017-07-04 11:43:45 +01:00
|
|
|
nodeA.once('peer:discovery', (peerInfo) => {
|
|
|
|
expect(nodeB.peerInfo.id.toB58String())
|
|
|
|
.to.eql(peerInfo.id.toB58String())
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|