mirror of
https://github.com/fluencelabs/js-libp2p
synced 2025-04-05 01:01:05 +00:00
fix: dont call callback before it's properly set
This commit is contained in:
parent
c18d2a4147
commit
17b5f73b3d
@ -24,10 +24,6 @@ module.exports = (node) => {
|
|||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
findProviders: (key, options, callback) => {
|
findProviders: (key, options, callback) => {
|
||||||
if (!routers.length) {
|
|
||||||
return callback(errCode(new Error('No content routers available'), 'NO_ROUTERS_AVAILABLE'))
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof options === 'function') {
|
if (typeof options === 'function') {
|
||||||
callback = options
|
callback = options
|
||||||
options = {}
|
options = {}
|
||||||
@ -37,6 +33,10 @@ module.exports = (node) => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!routers.length) {
|
||||||
|
return callback(errCode(new Error('No content routers available'), 'NO_ROUTERS_AVAILABLE'))
|
||||||
|
}
|
||||||
|
|
||||||
const tasks = routers.map((router) => {
|
const tasks = routers.map((router) => {
|
||||||
return (cb) => router.findProviders(key, options, (err, results) => {
|
return (cb) => router.findProviders(key, options, (err, results) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -22,15 +22,15 @@ module.exports = (node) => {
|
|||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
findPeer: (id, options, callback) => {
|
findPeer: (id, options, callback) => {
|
||||||
if (!routers.length) {
|
|
||||||
callback(errCode(new Error('No peer routers available'), 'NO_ROUTERS_AVAILABLE'))
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof options === 'function') {
|
if (typeof options === 'function') {
|
||||||
callback = options
|
callback = options
|
||||||
options = {}
|
options = {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!routers.length) {
|
||||||
|
callback(errCode(new Error('No peer routers available'), 'NO_ROUTERS_AVAILABLE'))
|
||||||
|
}
|
||||||
|
|
||||||
const tasks = routers.map((router) => {
|
const tasks = routers.map((router) => {
|
||||||
return (cb) => router.findPeer(id, options, (err, result) => {
|
return (cb) => router.findPeer(id, options, (err, result) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -367,4 +367,29 @@ describe('.contentRouting', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('no routers', () => {
|
||||||
|
let nodeA
|
||||||
|
before((done) => {
|
||||||
|
createNode('/ip4/0.0.0.0/tcp/0', (err, node) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
nodeA = node
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('.findProviders should return an error with no options', (done) => {
|
||||||
|
nodeA.contentRouting.findProviders('a cid', (err) => {
|
||||||
|
expect(err).to.exist()
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('.findProviders should return an error with options', (done) => {
|
||||||
|
nodeA.contentRouting.findProviders('a cid', { maxTimeout: 5000 }, (err) => {
|
||||||
|
expect(err).to.exist()
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
@ -266,4 +266,29 @@ describe('.peerRouting', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('no routers', () => {
|
||||||
|
let nodeA
|
||||||
|
before((done) => {
|
||||||
|
createNode('/ip4/0.0.0.0/tcp/0', (err, node) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
nodeA = node
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('.findPeer should return an error with no options', (done) => {
|
||||||
|
nodeA.peerRouting.findPeer('a cid', (err) => {
|
||||||
|
expect(err).to.exist()
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('.findPeer should return an error with options', (done) => {
|
||||||
|
nodeA.peerRouting.findPeer('a cid', { maxTimeout: 5000 }, (err) => {
|
||||||
|
expect(err).to.exist()
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user