From 275434f873d43fcb881f50c5f8b4dbfcb4b5436a Mon Sep 17 00:00:00 2001 From: Friedel Ziegelmayer Date: Sun, 8 May 2016 21:35:04 +0200 Subject: [PATCH 1/6] cleanup close handling --- src/index.js | 13 ++++++---- test/01-transport-tcp.node.js | 14 ++++------- test/03-transport-websockets.node.js | 14 ++++------- test/04-muxing-multiplex.node.js | 34 +++++++++---------------- test/05-muxing-spdy.node.js | 37 ++++++++++------------------ test/08-swarm-without-muxing.node.js | 15 ++++------- test/09-swarm-with-muxing.node.js | 25 +++++++++---------- test/browser.js | 3 +-- 8 files changed, 59 insertions(+), 96 deletions(-) diff --git a/src/index.js b/src/index.js index 676575d..514791b 100644 --- a/src/index.js +++ b/src/index.js @@ -118,7 +118,13 @@ function Swarm (peerInfo) { } this.transport.close = (key, callback) => { - this.transports[key].close(callback) + const transport = this.transports[key] + + if (!transport) { + return callback(new Error(`Trying to close non existing transport: ${key}`)) + } + + transport.close(callback) } // connections -- @@ -375,10 +381,7 @@ function Swarm (peerInfo) { async.each( Object.keys(this.transports), (key, cb) => this.transports[key].close(cb), - () => { - // Ignoring close errors - callback() - } + callback ) } } diff --git a/test/01-transport-tcp.node.js b/test/01-transport-tcp.node.js index 3358210..15a8452 100644 --- a/test/01-transport-tcp.node.js +++ b/test/01-transport-tcp.node.js @@ -3,6 +3,7 @@ const expect = require('chai').expect +const async = require('async') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -92,15 +93,10 @@ describe('transport - tcp', function () { }) it('close', (done) => { - var count = 0 - swarmA.transport.close('tcp', closed) - swarmB.transport.close('tcp', closed) - - function closed () { - if (++count === 2) { - done() - } - } + async.parallel([ + (cb) => swarmA.transport.close('tcp', cb), + (cb) => swarmB.transport.close('tcp', cb) + ], done) }) it('support port 0', (done) => { diff --git a/test/03-transport-websockets.node.js b/test/03-transport-websockets.node.js index 926f4c7..6fdca5d 100644 --- a/test/03-transport-websockets.node.js +++ b/test/03-transport-websockets.node.js @@ -3,6 +3,7 @@ const expect = require('chai').expect +const async = require('async') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -88,14 +89,9 @@ describe('transport - websockets', function () { }) it('close', (done) => { - var count = 0 - swarmA.transport.close('ws', closed) - swarmB.transport.close('ws', closed) - - function closed () { - if (++count === 2) { - done() - } - } + async.parallel([ + (cb) => swarmA.transport.close('ws', cb), + (cb) => swarmB.transport.close('ws', cb) + ], done) }) }) diff --git a/test/04-muxing-multiplex.node.js b/test/04-muxing-multiplex.node.js index d8a8507..e1d772f 100644 --- a/test/04-muxing-multiplex.node.js +++ b/test/04-muxing-multiplex.node.js @@ -3,6 +3,7 @@ const expect = require('chai').expect +const async = require('async') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -37,35 +38,22 @@ describe('stream muxing with multiplex (on TCP)', function () { swarmC = new Swarm(peerC) swarmA.transport.add('tcp', new TCP()) - swarmA.transport.listen('tcp', {}, null, ready) - swarmB.transport.add('tcp', new TCP()) - swarmB.transport.listen('tcp', {}, null, ready) - swarmC.transport.add('tcp', new TCP()) - swarmC.transport.listen('tcp', {}, null, ready) - var counter = 0 - - function ready () { - if (++counter === 3) { - done() - } - } + async.series([ + (cb) => swarmA.transport.listen('tcp', {}, null, cb), + (cb) => swarmB.transport.listen('tcp', {}, null, cb), + (cb) => swarmC.transport.listen('tcp', {}, null, cb) + ], done) }) after((done) => { - var counter = 0 - - swarmA.close(closed) - swarmB.close(closed) - swarmC.close(closed) - - function closed () { - if (++counter === 3) { - done() - } - } + async.parallel([ + (cb) => swarmA.close(cb), + (cb) => swarmB.close(cb), + (cb) => swarmC.close(cb) + ], done) }) it('add', (done) => { diff --git a/test/05-muxing-spdy.node.js b/test/05-muxing-spdy.node.js index a824dc2..250e5b5 100644 --- a/test/05-muxing-spdy.node.js +++ b/test/05-muxing-spdy.node.js @@ -3,6 +3,7 @@ const expect = require('chai').expect +const async = require('async') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -37,35 +38,22 @@ describe('stream muxing with spdy (on TCP)', function () { swarmC = new Swarm(peerC) swarmA.transport.add('tcp', new TCP()) - swarmA.transport.listen('tcp', {}, null, ready) - swarmB.transport.add('tcp', new TCP()) - swarmB.transport.listen('tcp', {}, null, ready) - swarmC.transport.add('tcp', new TCP()) - swarmC.transport.listen('tcp', {}, null, ready) - var counter = 0 - - function ready () { - if (++counter === 3) { - done() - } - } + async.parallel([ + (cb) => swarmA.transport.listen('tcp', {}, null, cb), + (cb) => swarmB.transport.listen('tcp', {}, null, cb), + (cb) => swarmC.transport.listen('tcp', {}, null, cb) + ], done) }) after((done) => { - var counter = 0 - - swarmA.close(closed) - swarmB.close(closed) - // swarmC.close(closed) - - function closed () { - if (++counter === 2) { - done() - } - } + async.parallel([ + (cb) => swarmA.close(cb), + (cb) => swarmB.close(cb), + (cb) => swarmC.close(cb) + ], done) }) it('add', (done) => { @@ -130,7 +118,8 @@ describe('stream muxing with spdy (on TCP)', function () { }) it('close one end, make sure the other does not blow', (done) => { - swarmC.close(() => { + swarmC.close((err) => { + if (err) throw err // to make sure it has time to propagate setTimeout(done, 1000) }) diff --git a/test/08-swarm-without-muxing.node.js b/test/08-swarm-without-muxing.node.js index 39f4675..f16d409 100644 --- a/test/08-swarm-without-muxing.node.js +++ b/test/08-swarm-without-muxing.node.js @@ -3,6 +3,7 @@ const expect = require('chai').expect +const async = require('async') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -42,16 +43,10 @@ describe('high level API - 1st without stream multiplexing (on TCP)', function ( }) after((done) => { - var counter = 0 - - swarmA.close(closed) - swarmB.close(closed) - - function closed () { - if (++counter === 2) { - done() - } - } + async.parallel([ + (cb) => swarmA.close(cb), + (cb) => swarmB.close(cb) + ], done) }) it('handle a protocol', (done) => { diff --git a/test/09-swarm-with-muxing.node.js b/test/09-swarm-with-muxing.node.js index 3c5a00f..a58cdcf 100644 --- a/test/09-swarm-with-muxing.node.js +++ b/test/09-swarm-with-muxing.node.js @@ -3,6 +3,7 @@ const expect = require('chai').expect +const async = require('async') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -45,19 +46,13 @@ describe('high level API - with everything mixed all together!', function () { }) after((done) => { - var counter = 0 - - swarmA.close(closed) - swarmB.close(closed) - // swarmC.close(closed) - swarmD.close(closed) - swarmE.close(closed) - - function closed () { - if (++counter === 4) { - done() - } - } + async.parallel([ + (cb) => swarmA.close(cb), + (cb) => swarmB.close(cb), + // (cb) => swarmC.close(cb), + (cb) => swarmD.close(cb), + (cb) => swarmE.close(cb) + ], done) }) it('add tcp', (done) => { @@ -214,7 +209,9 @@ describe('high level API - with everything mixed all together!', function () { }) it('close a muxer emits event', (done) => { - swarmC.close(() => {}) + swarmC.close((err) => { + if (err) throw err + }) swarmA.once('peer-mux-closed', (peerInfo) => { done() }) diff --git a/test/browser.js b/test/browser.js index bcd92cb..dc3ea2b 100644 --- a/test/browser.js +++ b/test/browser.js @@ -73,8 +73,7 @@ describe('high level API - 1st without stream multiplexing (on websockets)', fun }) after((done) => { - done() - // swarm.close(done) + swarm.close(done) }) it('add ws', (done) => { From dbf0d2c42284b83a205c1e0736c3b4d643841190 Mon Sep 17 00:00:00 2001 From: Friedel Ziegelmayer Date: Sun, 8 May 2016 21:44:22 +0200 Subject: [PATCH 2/6] fix dependencies --- package.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/package.json b/package.json index 79f291f..6017e65 100644 --- a/package.json +++ b/package.json @@ -47,9 +47,6 @@ "libp2p-spdy": "^0.3.1", "libp2p-tcp": "^0.5.0", "libp2p-websockets": "^0.4.1", - "multiaddr": "^1.4.0", - "peer-id": "^0.6.6", - "peer-info": "^0.6.2", "pre-commit": "^1.1.2", "stream-pair": "^1.0.3" }, @@ -60,6 +57,9 @@ "ip-address": "^5.8.0", "lodash.contains": "^2.4.3", "multistream-select": "^0.6.5", + "multiaddr": "^1.4.0", + "peer-id": "^0.6.6", + "peer-info": "^0.6.2", "protocol-buffers-stream": "^1.3.1" }, "aegir": { @@ -79,4 +79,4 @@ "Pau Ramon Revilla ", "Richard Littauer " ] -} \ No newline at end of file +} From 594b770d8e1a340bd76fa7869db93781739fe848 Mon Sep 17 00:00:00 2001 From: Friedel Ziegelmayer Date: Sun, 8 May 2016 22:19:43 +0200 Subject: [PATCH 3/6] try to appease the travis gods --- test/04-muxing-multiplex.node.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/04-muxing-multiplex.node.js b/test/04-muxing-multiplex.node.js index e1d772f..860a0f9 100644 --- a/test/04-muxing-multiplex.node.js +++ b/test/04-muxing-multiplex.node.js @@ -11,7 +11,7 @@ const TCP = require('libp2p-tcp') const multiplex = require('libp2p-spdy') describe('stream muxing with multiplex (on TCP)', function () { - this.timeout(20000) + this.timeout(60 * 1000) var swarmA var peerA @@ -41,7 +41,7 @@ describe('stream muxing with multiplex (on TCP)', function () { swarmB.transport.add('tcp', new TCP()) swarmC.transport.add('tcp', new TCP()) - async.series([ + async.parallel([ (cb) => swarmA.transport.listen('tcp', {}, null, cb), (cb) => swarmB.transport.listen('tcp', {}, null, cb), (cb) => swarmC.transport.listen('tcp', {}, null, cb) From a6ba60a5c42dbca5ecf70c60ac183a004c4b84cd Mon Sep 17 00:00:00 2001 From: Friedel Ziegelmayer Date: Sun, 8 May 2016 22:22:46 +0200 Subject: [PATCH 4/6] handle errors when closing --- src/index.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/index.js b/src/index.js index 514791b..304d6cc 100644 --- a/src/index.js +++ b/src/index.js @@ -380,7 +380,13 @@ function Swarm (peerInfo) { async.each( Object.keys(this.transports), - (key, cb) => this.transports[key].close(cb), + (key, cb) => { + // avoid unhandled error messages + this.transports[key].once('error', (err) => { + console.log('got error', err) + }) + this.transports[key].close(cb) + }, callback ) } From a81c328bf7d9218ecb971db503c52465dbd1865c Mon Sep 17 00:00:00 2001 From: Friedel Ziegelmayer Date: Sun, 8 May 2016 22:57:19 +0200 Subject: [PATCH 5/6] actually fix things --- package.json | 6 +++--- src/index.js | 16 ++++------------ test/01-transport-tcp.node.js | 4 ++-- test/03-transport-websockets.node.js | 4 ++-- test/04-muxing-multiplex.node.js | 6 +++--- test/05-muxing-spdy.node.js | 8 ++++---- test/08-swarm-without-muxing.node.js | 4 ++-- test/09-swarm-with-muxing.node.js | 4 ++-- 8 files changed, 22 insertions(+), 30 deletions(-) diff --git a/package.json b/package.json index 6017e65..5c3e0c0 100644 --- a/package.json +++ b/package.json @@ -51,16 +51,16 @@ "stream-pair": "^1.0.3" }, "dependencies": { - "async": "^2.0.0-rc.4", "babel-runtime": "^6.6.1", "duplex-passthrough": "github:diasdavid/duplex-passthrough", "ip-address": "^5.8.0", "lodash.contains": "^2.4.3", - "multistream-select": "^0.6.5", "multiaddr": "^1.4.0", + "multistream-select": "^0.6.5", "peer-id": "^0.6.6", "peer-info": "^0.6.2", - "protocol-buffers-stream": "^1.3.1" + "protocol-buffers-stream": "^1.3.1", + "run-parallel": "^1.1.6" }, "aegir": { "webpack": { diff --git a/src/index.js b/src/index.js index 304d6cc..0f0bb3d 100644 --- a/src/index.js +++ b/src/index.js @@ -1,12 +1,12 @@ 'use strict' -const async = require('async') const multistream = require('multistream-select') const identify = require('./identify') const DuplexPassThrough = require('duplex-passthrough') const contains = require('lodash.contains') const util = require('util') const EE = require('events').EventEmitter +const parallel = require('run-parallel') exports = module.exports = Swarm @@ -378,17 +378,9 @@ function Swarm (peerInfo) { this.muxedConns[key].muxer.end() }) - async.each( - Object.keys(this.transports), - (key, cb) => { - // avoid unhandled error messages - this.transports[key].once('error', (err) => { - console.log('got error', err) - }) - this.transports[key].close(cb) - }, - callback - ) + parallel(Object.keys(this.transports).map((key) => { + return (cb) => this.transports[key].close(cb) + }), callback) } } diff --git a/test/01-transport-tcp.node.js b/test/01-transport-tcp.node.js index 15a8452..2b18105 100644 --- a/test/01-transport-tcp.node.js +++ b/test/01-transport-tcp.node.js @@ -3,7 +3,7 @@ const expect = require('chai').expect -const async = require('async') +const parallel = require('run-parallel') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -93,7 +93,7 @@ describe('transport - tcp', function () { }) it('close', (done) => { - async.parallel([ + parallel([ (cb) => swarmA.transport.close('tcp', cb), (cb) => swarmB.transport.close('tcp', cb) ], done) diff --git a/test/03-transport-websockets.node.js b/test/03-transport-websockets.node.js index 6fdca5d..a1a06e1 100644 --- a/test/03-transport-websockets.node.js +++ b/test/03-transport-websockets.node.js @@ -3,7 +3,7 @@ const expect = require('chai').expect -const async = require('async') +const parallel = require('run-parallel') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -89,7 +89,7 @@ describe('transport - websockets', function () { }) it('close', (done) => { - async.parallel([ + parallel([ (cb) => swarmA.transport.close('ws', cb), (cb) => swarmB.transport.close('ws', cb) ], done) diff --git a/test/04-muxing-multiplex.node.js b/test/04-muxing-multiplex.node.js index 860a0f9..0f0e18d 100644 --- a/test/04-muxing-multiplex.node.js +++ b/test/04-muxing-multiplex.node.js @@ -3,7 +3,7 @@ const expect = require('chai').expect -const async = require('async') +const parallel = require('run-parallel') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -41,7 +41,7 @@ describe('stream muxing with multiplex (on TCP)', function () { swarmB.transport.add('tcp', new TCP()) swarmC.transport.add('tcp', new TCP()) - async.parallel([ + parallel([ (cb) => swarmA.transport.listen('tcp', {}, null, cb), (cb) => swarmB.transport.listen('tcp', {}, null, cb), (cb) => swarmC.transport.listen('tcp', {}, null, cb) @@ -49,7 +49,7 @@ describe('stream muxing with multiplex (on TCP)', function () { }) after((done) => { - async.parallel([ + parallel([ (cb) => swarmA.close(cb), (cb) => swarmB.close(cb), (cb) => swarmC.close(cb) diff --git a/test/05-muxing-spdy.node.js b/test/05-muxing-spdy.node.js index 250e5b5..9ed39a4 100644 --- a/test/05-muxing-spdy.node.js +++ b/test/05-muxing-spdy.node.js @@ -3,7 +3,7 @@ const expect = require('chai').expect -const async = require('async') +const parallel = require('run-parallel') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -11,7 +11,7 @@ const TCP = require('libp2p-tcp') const spdy = require('libp2p-spdy') describe('stream muxing with spdy (on TCP)', function () { - this.timeout(20000) + this.timeout(60 * 1000) var swarmA var peerA @@ -41,7 +41,7 @@ describe('stream muxing with spdy (on TCP)', function () { swarmB.transport.add('tcp', new TCP()) swarmC.transport.add('tcp', new TCP()) - async.parallel([ + parallel([ (cb) => swarmA.transport.listen('tcp', {}, null, cb), (cb) => swarmB.transport.listen('tcp', {}, null, cb), (cb) => swarmC.transport.listen('tcp', {}, null, cb) @@ -49,7 +49,7 @@ describe('stream muxing with spdy (on TCP)', function () { }) after((done) => { - async.parallel([ + parallel([ (cb) => swarmA.close(cb), (cb) => swarmB.close(cb), (cb) => swarmC.close(cb) diff --git a/test/08-swarm-without-muxing.node.js b/test/08-swarm-without-muxing.node.js index f16d409..7463eb0 100644 --- a/test/08-swarm-without-muxing.node.js +++ b/test/08-swarm-without-muxing.node.js @@ -3,7 +3,7 @@ const expect = require('chai').expect -const async = require('async') +const parallel = require('run-parallel') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -43,7 +43,7 @@ describe('high level API - 1st without stream multiplexing (on TCP)', function ( }) after((done) => { - async.parallel([ + parallel([ (cb) => swarmA.close(cb), (cb) => swarmB.close(cb) ], done) diff --git a/test/09-swarm-with-muxing.node.js b/test/09-swarm-with-muxing.node.js index a58cdcf..f904ea8 100644 --- a/test/09-swarm-with-muxing.node.js +++ b/test/09-swarm-with-muxing.node.js @@ -3,7 +3,7 @@ const expect = require('chai').expect -const async = require('async') +const parallel = require('run-parallel') const multiaddr = require('multiaddr') const Peer = require('peer-info') const Swarm = require('../src') @@ -46,7 +46,7 @@ describe('high level API - with everything mixed all together!', function () { }) after((done) => { - async.parallel([ + parallel([ (cb) => swarmA.close(cb), (cb) => swarmB.close(cb), // (cb) => swarmC.close(cb), From 05f799f983a39a43982d71f52292c2b357bd9a8e Mon Sep 17 00:00:00 2001 From: Friedel Ziegelmayer Date: Sun, 8 May 2016 23:10:09 +0200 Subject: [PATCH 6/6] update deps --- package.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index 5c3e0c0..adbfaf8 100644 --- a/package.json +++ b/package.json @@ -45,8 +45,8 @@ "istanbul": "^0.4.3", "libp2p-multiplex": "^0.2.1", "libp2p-spdy": "^0.3.1", - "libp2p-tcp": "^0.5.0", - "libp2p-websockets": "^0.4.1", + "libp2p-tcp": "^0.5.1", + "libp2p-websockets": "^0.4.3", "pre-commit": "^1.1.2", "stream-pair": "^1.0.3" },