mirror of
https://github.com/fluencelabs/js-libp2p
synced 2025-04-22 00:52:14 +00:00
fix: stop discoveries (#530)
* fix: stop discoveries * test: add discovery stop test * chore: fix lint Co-authored-by: Jacob Heun <jacobheun@gmail.com>
This commit is contained in:
parent
2f2ba420ef
commit
4222c49556
@ -218,7 +218,14 @@ class Libp2p extends EventEmitter {
|
|||||||
log('libp2p is stopping')
|
log('libp2p is stopping')
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
for (const service of this._discovery.values()) {
|
||||||
|
service.removeListener('peer', this._onDiscoveryPeer)
|
||||||
|
}
|
||||||
|
|
||||||
|
await Promise.all(Array.from(this._discovery.values(), s => s.stop()))
|
||||||
|
|
||||||
this.connectionManager.stop()
|
this.connectionManager.stop()
|
||||||
|
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
this.pubsub && this.pubsub.stop(),
|
this.pubsub && this.pubsub.stop(),
|
||||||
this._dht && this._dht.stop(),
|
this._dht && this._dht.stop(),
|
||||||
|
@ -65,6 +65,32 @@ describe('peer discovery', () => {
|
|||||||
|
|
||||||
expect(discoverySpy.called).to.eql(false)
|
expect(discoverySpy.called).to.eql(false)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should stop discovery on libp2p start/stop', async () => {
|
||||||
|
const mockDiscovery = {
|
||||||
|
tag: 'mock',
|
||||||
|
start: () => {},
|
||||||
|
stop: () => {},
|
||||||
|
on: () => {},
|
||||||
|
removeListener: () => {}
|
||||||
|
}
|
||||||
|
const startSpy = sinon.spy(mockDiscovery, 'start')
|
||||||
|
const stopSpy = sinon.spy(mockDiscovery, 'stop')
|
||||||
|
|
||||||
|
libp2p = new Libp2p(mergeOptions(baseOptions, {
|
||||||
|
peerInfo,
|
||||||
|
modules: {
|
||||||
|
peerDiscovery: [mockDiscovery]
|
||||||
|
}
|
||||||
|
}))
|
||||||
|
|
||||||
|
await libp2p.start()
|
||||||
|
expect(startSpy).to.have.property('callCount', 1)
|
||||||
|
expect(stopSpy).to.have.property('callCount', 0)
|
||||||
|
await libp2p.stop()
|
||||||
|
expect(startSpy).to.have.property('callCount', 1)
|
||||||
|
expect(stopSpy).to.have.property('callCount', 1)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('discovery modules from transports', () => {
|
describe('discovery modules from transports', () => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user