'use strict' /* eslint-env mocha */ const chai = require('chai') chai.use(require('dirty-chai')) chai.use(require('chai-as-promised')) const { expect } = chai const sinon = require('sinon') const peerUtils = require('../utils/creators/peer') const mockConnection = require('../utils/mockConnection') const baseOptions = require('../utils/base-options.browser') const listenMultiaddr = '/ip4/127.0.0.1/tcp/15002/ws' describe('Connection Manager', () => { let libp2p beforeEach(async () => { [libp2p] = await peerUtils.createPeer({ config: { addresses: { listen: [listenMultiaddr] }, modules: baseOptions.modules } }) }) afterEach(() => libp2p.stop()) it('should filter connections on disconnect, removing the closed one', async () => { const [localPeer, remotePeer] = await peerUtils.createPeerId({ number: 2 }) const conn1 = await mockConnection({ localPeer, remotePeer }) const conn2 = await mockConnection({ localPeer, remotePeer }) const id = remotePeer.toB58String() // Add connection to the connectionManager libp2p.connectionManager.onConnect(conn1) libp2p.connectionManager.onConnect(conn2) expect(libp2p.connectionManager.connections.get(id).length).to.eql(2) conn2._stat.status = 'closed' libp2p.connectionManager.onDisconnect(conn2) const peerConnections = libp2p.connectionManager.connections.get(id) expect(peerConnections.length).to.eql(1) expect(peerConnections[0]._stat.status).to.eql('open') }) it('should add connection on dial and remove on node stop', async () => { const [remoteLibp2p] = await peerUtils.createPeer({ config: { addresses: { listen: ['/ip4/127.0.0.1/tcp/15003/ws'] }, modules: baseOptions.modules } }) // Spy on emit for easy verification sinon.spy(libp2p.connectionManager, 'emit') sinon.spy(remoteLibp2p.connectionManager, 'emit') libp2p.peerStore.addressBook.set(remoteLibp2p.peerId, remoteLibp2p.multiaddrs) await libp2p.dial(remoteLibp2p.peerId) // check connect event expect(libp2p.connectionManager.emit.callCount).to.equal(1) const [event, connection] = libp2p.connectionManager.emit.getCall(0).args expect(event).to.equal('peer:connect') expect(connection.remotePeer.isEqual(remoteLibp2p.peerId)).to.equal(true) const libp2pConn = libp2p.connectionManager.get(remoteLibp2p.peerId) expect(libp2pConn).to.exist() const remoteConn = remoteLibp2p.connectionManager.get(libp2p.peerId) expect(remoteConn).to.exist() await remoteLibp2p.stop() expect(remoteLibp2p.connectionManager.size).to.eql(0) }) }) describe('libp2p.connections', () => { it('libp2p.connections gets the connectionManager conns', async () => { const [libp2p] = await peerUtils.createPeer({ config: { addresses: { listen: ['/ip4/127.0.0.1/tcp/15003/ws'] }, modules: baseOptions.modules } }) const [remoteLibp2p] = await peerUtils.createPeer({ config: { addresses: { listen: ['/ip4/127.0.0.1/tcp/15004/ws'] }, modules: baseOptions.modules } }) libp2p.peerStore.addressBook.set(remoteLibp2p.peerId, remoteLibp2p.multiaddrs) await libp2p.dial(remoteLibp2p.peerId) expect(libp2p.connections.size).to.eql(1) await libp2p.stop() await remoteLibp2p.stop() }) })