94 lines
2.2 KiB
JavaScript
Raw Normal View History

2021-04-07 09:39:48 +02:00
// @ts-nocheck interface tests
2019-09-26 11:27:39 +02:00
/* eslint-env mocha */
'use strict'
2020-04-06 20:20:27 +02:00
const chai = require('chai')
const expect = chai.expect
chai.use(require('dirty-chai'))
2021-04-08 17:28:49 +02:00
const { Multiaddr } = require('multiaddr')
2020-04-06 20:20:27 +02:00
const PeerId = require('peer-id')
const delay = require('delay')
const pDefer = require('p-defer')
2019-09-26 11:27:39 +02:00
module.exports = (common) => {
describe('interface-peer-discovery', () => {
let discovery
2020-04-06 20:20:27 +02:00
beforeEach(async () => {
2019-09-27 13:32:45 +02:00
discovery = await common.setup()
2019-09-26 11:27:39 +02:00
})
2020-04-06 20:20:27 +02:00
afterEach('ensure discovery was stopped', async () => {
await discovery.stop()
discovery.removeAllListeners()
common.teardown && common.teardown()
2020-04-06 20:20:27 +02:00
})
2019-09-27 13:32:45 +02:00
2019-09-26 11:27:39 +02:00
it('can start the service', async () => {
await discovery.start()
})
it('can start and stop the service', async () => {
await discovery.start()
await discovery.stop()
})
it('should not fail to stop the service if it was not started', async () => {
await discovery.stop()
})
it('should not fail to start the service if it is already started', async () => {
await discovery.start()
await discovery.start()
})
2020-04-06 20:20:27 +02:00
it('should emit a peer event after start', async () => {
2020-04-06 20:20:27 +02:00
const defer = pDefer()
await discovery.start()
discovery.on('peer', ({ id, multiaddrs }) => {
2020-04-06 20:20:27 +02:00
expect(id).to.exist()
expect(PeerId.isPeerId(id)).to.eql(true)
expect(multiaddrs).to.exist()
2021-04-08 17:28:49 +02:00
multiaddrs.forEach((m) => expect(Multiaddr.isMultiaddr(m)).to.eql(true))
2020-04-06 20:20:27 +02:00
defer.resolve()
})
await defer.promise
2020-04-06 20:20:27 +02:00
})
it('should not receive a peer event before start', async () => {
discovery.on('peer', () => {
2020-04-06 20:20:27 +02:00
throw new Error('should not receive a peer event before start')
})
await delay(2000)
})
it('should not receive a peer event after stop', async () => {
const deferStart = pDefer()
await discovery.start()
discovery.on('peer', () => {
2020-04-06 20:20:27 +02:00
deferStart.resolve()
})
await deferStart.promise
await discovery.stop()
discovery.on('peer', () => {
2020-04-06 20:20:27 +02:00
throw new Error('should not receive a peer event after stop')
})
await delay(2000)
})
2019-09-26 11:27:39 +02:00
})
}