-
Notifications
You must be signed in to change notification settings - Fork 437
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add
MessageIO.readMessage
and MessageIO.writeMessage
.
- Loading branch information
1 parent
2ecdc11
commit 4f03851
Showing
6 changed files
with
747 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
const { createBenchmark } = require('../common'); | ||
const { Readable } = require('stream'); | ||
|
||
const Debug = require('tedious/lib/debug'); | ||
const IncomingMessageStream = require('tedious/lib/incoming-message-stream'); | ||
const { Packet } = require('tedious/lib/packet'); | ||
|
||
const bench = createBenchmark(main, { | ||
n: [100, 1000, 10000, 100000] | ||
}); | ||
|
||
function main({ n }) { | ||
const debug = new Debug(); | ||
|
||
const stream = Readable.from((async function*() { | ||
for (let i = 0; i < n; i++) { | ||
const packet = new Packet(2); | ||
packet.last(true); | ||
packet.addData(Buffer.from([1, 2, 3, 4, 5, 6, 7, 8, 9])); | ||
|
||
yield packet.buffer; | ||
} | ||
})()); | ||
|
||
const incoming = new IncomingMessageStream(debug); | ||
stream.pipe(incoming); | ||
|
||
bench.start(); | ||
console.profile('incoming-message-stream'); | ||
|
||
(async function() { | ||
let total = 0; | ||
|
||
for await (m of incoming) { | ||
for await (const buf of m) { | ||
total += buf.length; | ||
} | ||
} | ||
|
||
console.profileEnd('incoming-message-stream'); | ||
bench.end(n); | ||
})(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
const { createBenchmark } = require('../common'); | ||
const { Duplex } = require('stream'); | ||
|
||
const Debug = require('../../lib/debug'); | ||
const OutgoingMessageStream = require('../../lib/outgoing-message-stream'); | ||
const Message = require('../../lib/message'); | ||
|
||
const bench = createBenchmark(main, { | ||
n: [100, 1000, 10000, 100000] | ||
}); | ||
|
||
function main({ n }) { | ||
const debug = new Debug(); | ||
|
||
const stream = new Duplex({ | ||
read() {}, | ||
write(chunk, encoding, callback) { | ||
// Just consume the data | ||
callback(); | ||
} | ||
}); | ||
|
||
const payload = [ | ||
Buffer.alloc(1024), | ||
Buffer.alloc(1024), | ||
Buffer.alloc(1024), | ||
Buffer.alloc(256), | ||
Buffer.alloc(256), | ||
Buffer.alloc(256), | ||
Buffer.alloc(256), | ||
]; | ||
|
||
const out = new OutgoingMessageStream(debug, { | ||
packetSize: 8 + 1024 | ||
}); | ||
out.pipe(stream); | ||
|
||
bench.start(); | ||
console.profile('write-message'); | ||
|
||
function writeNextMessage(i) { | ||
if (i == n) { | ||
out.end(); | ||
out.once('finish', () => { | ||
console.profileEnd('write-message'); | ||
bench.end(n); | ||
}); | ||
return; | ||
} | ||
|
||
const m = new Message({ type: 2, resetConnection: false }); | ||
out.write(m); | ||
|
||
for (const buf of payload) { | ||
m.write(buf); | ||
} | ||
|
||
m.end(); | ||
|
||
if (out.needsDrain) { | ||
out.once('drain', () => { | ||
writeNextMessage(i + 1); | ||
}); | ||
} else { | ||
process.nextTick(() => { | ||
writeNextMessage(i + 1); | ||
}); | ||
} | ||
} | ||
|
||
writeNextMessage(0); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
const { createBenchmark } = require('../common'); | ||
const { Readable } = require('stream'); | ||
|
||
const Debug = require('tedious/lib/debug'); | ||
const MessageIO = require('tedious/lib/message-io'); | ||
const { Packet } = require('tedious/lib/packet'); | ||
|
||
const bench = createBenchmark(main, { | ||
n: [100, 1000, 10000, 100000] | ||
}); | ||
|
||
function main({ n }) { | ||
const debug = new Debug(); | ||
|
||
const stream = Readable.from((async function*() { | ||
for (let i = 0; i < n; i++) { | ||
const packet = new Packet(2); | ||
packet.last(true); | ||
packet.addData(Buffer.from([1, 2, 3, 4, 5, 6, 7, 8, 9])); | ||
|
||
yield packet.buffer; | ||
} | ||
})()); | ||
|
||
(async function() { | ||
bench.start(); | ||
console.profile('read-message'); | ||
|
||
let total = 0; | ||
for (let i = 0; i < n; i++) { | ||
for await (const chunk of MessageIO.readMessage(stream, debug)) { | ||
total += chunk.length; | ||
} | ||
} | ||
|
||
console.profileEnd('read-message'); | ||
bench.end(n); | ||
})(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
const { createBenchmark, createConnection } = require('../common'); | ||
const { Duplex } = require('stream'); | ||
|
||
const Debug = require('tedious/lib/debug'); | ||
const MessageIO = require('tedious/lib/message-io'); | ||
|
||
const bench = createBenchmark(main, { | ||
n: [100, 1000, 10000, 100000] | ||
}); | ||
|
||
function main({ n }) { | ||
const debug = new Debug(); | ||
|
||
const stream = new Duplex({ | ||
read() {}, | ||
write(chunk, encoding, callback) { | ||
// Just consume the data | ||
callback(); | ||
} | ||
}); | ||
|
||
const payload = [ | ||
Buffer.alloc(1024), | ||
Buffer.alloc(1024), | ||
Buffer.alloc(1024), | ||
Buffer.alloc(256), | ||
Buffer.alloc(256), | ||
Buffer.alloc(256), | ||
Buffer.alloc(256), | ||
]; | ||
|
||
(async function() { | ||
bench.start(); | ||
console.profile('bench'); | ||
|
||
for (let i = 0; i <= n; i++) { | ||
await MessageIO.writeMessage(stream, debug, 8 + 1024, 2, payload); | ||
} | ||
|
||
console.profileEnd('bench'); | ||
bench.end(n); | ||
})(); | ||
} |
Oops, something went wrong.