Skip to content

Commit

Permalink
chore: address review
Browse files Browse the repository at this point in the history
  • Loading branch information
vasco-santos committed Nov 6, 2019
1 parent 221f613 commit 0de3426
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 22 deletions.
15 changes: 15 additions & 0 deletions src/pubsub.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,12 @@ module.exports = (node, Pubsub, config) => {
}
},

/**
* Publish messages to the given topics.
* @param {Array<string>|string} topic
* @param {Buffer} data
* @returns {Promise<void>}
*/
publish: (topic, data) => {
if (!node.isStarted() && !pubsub.started) {
throw errCode(new Error(messages.NOT_STARTED_YET), codes.PUBSUB_NOT_STARTED)
Expand All @@ -60,6 +66,10 @@ module.exports = (node, Pubsub, config) => {
return pubsub.publish(topic, data)
},

/**
* Get a list of topics the node is subscribed to.
* @returns {Array<String>} topics
*/
getTopics: () => {
if (!node.isStarted() && !pubsub.started) {
throw errCode(new Error(messages.NOT_STARTED_YET), codes.PUBSUB_NOT_STARTED)
Expand All @@ -68,6 +78,11 @@ module.exports = (node, Pubsub, config) => {
return pubsub.getTopics()
},

/**
* Get a list of the peer-ids that are subscribed to one topic.
* @param {string} topic
* @returns {Array<string>}
*/
getPeersSubscribed: (topic) => {
if (!node.isStarted() && !pubsub.started) {
throw errCode(new Error(messages.NOT_STARTED_YET), codes.PUBSUB_NOT_STARTED)
Expand Down
9 changes: 4 additions & 5 deletions test/pubsub/configuration.node.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,11 @@ chai.use(require('dirty-chai'))
const { expect } = chai

const mergeOptions = require('merge-options')

const multiaddr = require('multiaddr')
const PeerInfo = require('peer-info')

const { create } = require('../../src')
const { baseOptions, subsystemOptions } = require('./utils')
const peerUtils = require('../utils/creators/peer')

const listenAddr = multiaddr('/ip4/127.0.0.1/tcp/0')

Expand All @@ -33,7 +32,7 @@ describe('Pubsub subsystem is configurable', () => {
})

it('should start and stop by default once libp2p starts', async () => {
const peerInfo = await PeerInfo.create()
const [peerInfo] = await peerUtils.createPeerInfoFromFixture(1)
peerInfo.multiaddrs.add(listenAddr)

const customOptions = mergeOptions(subsystemOptions, {
Expand All @@ -51,7 +50,7 @@ describe('Pubsub subsystem is configurable', () => {
})

it('should not start if disabled once libp2p starts', async () => {
const peerInfo = await PeerInfo.create()
const [peerInfo] = await peerUtils.createPeerInfoFromFixture(1)
peerInfo.multiaddrs.add(listenAddr)

const customOptions = mergeOptions(subsystemOptions, {
Expand All @@ -71,7 +70,7 @@ describe('Pubsub subsystem is configurable', () => {
})

it('should allow a manual start', async () => {
const peerInfo = await PeerInfo.create()
const [peerInfo] = await peerUtils.createPeerInfoFromFixture(1)
peerInfo.multiaddrs.add(listenAddr)

const customOptions = mergeOptions(subsystemOptions, {
Expand Down
12 changes: 3 additions & 9 deletions test/pubsub/implementations.node.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,10 @@ const { multicodec: floodsubMulticodec } = require('libp2p-floodsub')
const { multicodec: gossipsubMulticodec } = require('libp2p-gossipsub')

const multiaddr = require('multiaddr')
const PeerInfo = require('peer-info')

const { create } = require('../../src')
const { baseOptions } = require('./utils')
const peerUtils = require('../utils/creators/peer')

const listenAddr = multiaddr('/ip4/127.0.0.1/tcp/0')
const remoteListenAddr = multiaddr('/ip4/127.0.0.1/tcp/0')
Expand All @@ -29,10 +29,7 @@ describe('Pubsub subsystem is able to use different implementations', () => {
let remAddr

beforeEach(async () => {
[peerInfo, remotePeerInfo] = await Promise.all([
PeerInfo.create(),
PeerInfo.create()
])
[peerInfo, remotePeerInfo] = await peerUtils.createPeerInfoFromFixture(2)

peerInfo.multiaddrs.add(listenAddr)
remotePeerInfo.multiaddrs.add(remoteListenAddr)
Expand Down Expand Up @@ -79,8 +76,6 @@ describe('Pubsub subsystem is able to use different implementations', () => {
remAddr = remoteLibp2p.transportManager.getAddrs()[0]

const connection = await libp2p.dialProtocol(remAddr, multicodec)

await new Promise((resolve) => setTimeout(resolve, 1000))
expect(connection).to.exist()

libp2p.pubsub.subscribe(topic, (msg) => {
Expand All @@ -93,9 +88,8 @@ describe('Pubsub subsystem is able to use different implementations', () => {
const subscribedPeers = remoteLibp2p.pubsub.getPeersSubscribed(topic)
return subscribedPeers.includes(libp2pId)
})
await new Promise((resolve) => setTimeout(resolve, 1000))
remoteLibp2p.pubsub.publish(topic, data)

remoteLibp2p.pubsub.publish(topic, data)
await defer.promise
}
})
14 changes: 6 additions & 8 deletions test/pubsub/operation.node.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,11 @@ const sinon = require('sinon')
const pWaitFor = require('p-wait-for')
const pDefer = require('p-defer')
const mergeOptions = require('merge-options')

const multiaddr = require('multiaddr')
const PeerInfo = require('peer-info')

const { create } = require('../../src')
const { subsystemOptions, subsystemMulticodecs } = require('./utils')
const peerUtils = require('../utils/creators/peer')

const listenAddr = multiaddr('/ip4/127.0.0.1/tcp/0')
const remoteListenAddr = multiaddr('/ip4/127.0.0.1/tcp/0')
Expand All @@ -25,10 +24,7 @@ describe('Pubsub subsystem operates correctly', () => {
let remAddr

beforeEach(async () => {
[peerInfo, remotePeerInfo] = await Promise.all([
PeerInfo.create(),
PeerInfo.create()
])
[peerInfo, remotePeerInfo] = await peerUtils.createPeerInfoFromFixture(2)

peerInfo.multiaddrs.add(listenAddr)
remotePeerInfo.multiaddrs.add(remoteListenAddr)
Expand All @@ -44,8 +40,10 @@ describe('Pubsub subsystem operates correctly', () => {
peerInfo: remotePeerInfo
}))

await libp2p.start()
await remoteLibp2p.start()
await Promise.all([
libp2p.start(),
remoteLibp2p.start()
])

remAddr = remoteLibp2p.transportManager.getAddrs()[0]
})
Expand Down

0 comments on commit 0de3426

Please sign in to comment.