mirror of
https://github.com/fluencelabs/js-libp2p-interfaces
synced 2025-04-25 12:02:17 +00:00
63 lines
1.4 KiB
JavaScript
63 lines
1.4 KiB
JavaScript
|
var streamPair = require('stream-pair')
|
||
|
|
||
|
module.exports.all = function (test, common) {
|
||
|
|
||
|
test('10000 messages of 10000 streams', function (t) {
|
||
|
common.setup(test, function (err, Muxer) {
|
||
|
t.ifError(err, 'should not throw')
|
||
|
var pair = streamPair.create()
|
||
|
|
||
|
spawnGeneration(t, Muxer, pair, pair.other, 10000, 10000)
|
||
|
})
|
||
|
})
|
||
|
|
||
|
}
|
||
|
|
||
|
function spawnGeneration (t, Muxer, dialerSocket, listenerSocket, nStreams, nMsg, size) {
|
||
|
t.plan(1 + (5 * nStreams) + (nStreams * nMsg))
|
||
|
|
||
|
var msg = !size ? 'simple msg' : 'make the msg bigger'
|
||
|
|
||
|
var listenerMuxer = new Muxer()
|
||
|
var dialerMuxer = new Muxer()
|
||
|
|
||
|
var listenerConn = listenerMuxer.attach(listenerSocket, true)
|
||
|
var dialerConn = dialerMuxer.attach(dialerSocket, false)
|
||
|
|
||
|
listenerConn.on('stream', function (stream) {
|
||
|
t.pass('Incoming stream')
|
||
|
|
||
|
stream.on('data', function (chunk) {
|
||
|
t.pass('Received message')
|
||
|
})
|
||
|
|
||
|
stream.on('end', function () {
|
||
|
t.pass('Stream ended on Listener')
|
||
|
stream.end()
|
||
|
})
|
||
|
|
||
|
})
|
||
|
|
||
|
for (var i = 0; i < nStreams; i++) {
|
||
|
dialerConn.dialStream(function (err, stream) {
|
||
|
t.ifError(err, 'Should not throw')
|
||
|
t.pass('Dialed stream')
|
||
|
|
||
|
for (var j = 0; j < nMsg; j++) {
|
||
|
stream.write(msg)
|
||
|
}
|
||
|
|
||
|
stream.on('data', function (chunk) {
|
||
|
t.fail('Should not happen')
|
||
|
})
|
||
|
|
||
|
stream.on('end', function () {
|
||
|
t.pass('Stream ended on Dialer')
|
||
|
})
|
||
|
|
||
|
stream.end()
|
||
|
})
|
||
|
}
|
||
|
|
||
|
}
|