mirror of
https://github.com/fluencelabs/js-libp2p
synced 2025-03-30 06:11:05 +00:00
119 lines
2.4 KiB
JavaScript
119 lines
2.4 KiB
JavaScript
/* eslint-env mocha */
|
|
'use strict'
|
|
|
|
const chai = require('chai')
|
|
const dirtyChai = require('dirty-chai')
|
|
const expect = chai.expect
|
|
chai.use(dirtyChai)
|
|
const PeerInfo = require('peer-info')
|
|
const PeerBook = require('peer-book')
|
|
|
|
const Swarm = require('../../src/switch')
|
|
const TCP = require('libp2p-tcp')
|
|
const series = require('async/series')
|
|
const parallel = require('async/parallel')
|
|
|
|
const Ping = require('../../src/ping')
|
|
|
|
describe('libp2p ping', () => {
|
|
let swarmA
|
|
let swarmB
|
|
let peerA
|
|
let peerB
|
|
|
|
before(function (done) {
|
|
this.timeout(20 * 1000)
|
|
series([
|
|
(cb) => PeerInfo.create((err, peerInfo) => {
|
|
expect(err).to.not.exist()
|
|
peerA = peerInfo
|
|
peerA.multiaddrs.add('/ip4/127.0.0.1/tcp/0')
|
|
cb()
|
|
}),
|
|
(cb) => PeerInfo.create((err, peerInfo) => {
|
|
expect(err).to.not.exist()
|
|
peerB = peerInfo
|
|
peerB.multiaddrs.add('/ip4/127.0.0.1/tcp/0')
|
|
cb()
|
|
}),
|
|
(cb) => {
|
|
swarmA = new Swarm(peerA, new PeerBook())
|
|
swarmB = new Swarm(peerB, new PeerBook())
|
|
swarmA.transport.add('tcp', new TCP())
|
|
swarmB.transport.add('tcp', new TCP())
|
|
cb()
|
|
},
|
|
(cb) => swarmA.start(cb),
|
|
(cb) => swarmB.start(cb),
|
|
(cb) => {
|
|
Ping.mount(swarmA)
|
|
Ping.mount(swarmB)
|
|
cb()
|
|
}
|
|
], done)
|
|
})
|
|
|
|
after((done) => {
|
|
parallel([
|
|
(cb) => swarmA.stop(cb),
|
|
(cb) => swarmB.stop(cb)
|
|
], done)
|
|
})
|
|
|
|
it('ping once from peerA to peerB', (done) => {
|
|
const p = new Ping(swarmA, peerB)
|
|
|
|
p.on('error', (err) => {
|
|
expect(err).to.not.exist()
|
|
})
|
|
|
|
p.on('ping', (time) => {
|
|
expect(time).to.be.a('Number')
|
|
p.stop()
|
|
done()
|
|
})
|
|
|
|
p.start()
|
|
})
|
|
|
|
it('ping 5 times from peerB to peerA', (done) => {
|
|
const p = new Ping(swarmB, peerA)
|
|
|
|
p.on('error', (err) => {
|
|
expect(err).to.not.exist()
|
|
})
|
|
|
|
let counter = 0
|
|
|
|
p.on('ping', (time) => {
|
|
expect(time).to.be.a('Number')
|
|
if (++counter === 5) {
|
|
p.stop()
|
|
done()
|
|
}
|
|
})
|
|
|
|
p.start()
|
|
})
|
|
|
|
it('cannot ping itself', (done) => {
|
|
const p = new Ping(swarmA, peerA)
|
|
|
|
p.on('error', (err) => {
|
|
expect(err).to.exist()
|
|
done()
|
|
})
|
|
|
|
p.on('ping', () => {
|
|
expect.fail('should not be called')
|
|
})
|
|
|
|
p.start()
|
|
})
|
|
|
|
it('unmount PING protocol', () => {
|
|
Ping.unmount(swarmA)
|
|
Ping.unmount(swarmB)
|
|
})
|
|
})
|