You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
148 lines
4.2 KiB
148 lines
4.2 KiB
var Dicer = require('..');
|
|
var assert = require('assert'),
|
|
fs = require('fs'),
|
|
path = require('path'),
|
|
inspect = require('util').inspect;
|
|
|
|
var FIXTURES_ROOT = __dirname + '/fixtures/';
|
|
|
|
var t = 0,
|
|
group = path.basename(__filename, '.js') + '/';
|
|
|
|
var tests = [
|
|
{ source: 'many',
|
|
opts: { boundary: '----WebKitFormBoundaryWLHCs9qmcJJoyjKR' },
|
|
chsize: 16,
|
|
nparts: 7,
|
|
what: 'Extra trailer data pushed after finished'
|
|
},
|
|
];
|
|
|
|
function next() {
|
|
if (t === tests.length)
|
|
return;
|
|
var v = tests[t],
|
|
fixtureBase = FIXTURES_ROOT + v.source,
|
|
fd,
|
|
n = 0,
|
|
buffer = new Buffer(v.chsize),
|
|
state = { parts: [] };
|
|
|
|
fd = fs.openSync(fixtureBase + '/original', 'r');
|
|
|
|
var dicer = new Dicer(v.opts),
|
|
error,
|
|
partErrors = 0,
|
|
finishes = 0;
|
|
|
|
dicer.on('part', function(p) {
|
|
var part = {
|
|
body: undefined,
|
|
bodylen: 0,
|
|
error: undefined,
|
|
header: undefined
|
|
};
|
|
|
|
p.on('header', function(h) {
|
|
part.header = h;
|
|
}).on('data', function(data) {
|
|
// make a copy because we are using readSync which re-uses a buffer ...
|
|
var copy = new Buffer(data.length);
|
|
data.copy(copy);
|
|
data = copy;
|
|
if (!part.body)
|
|
part.body = [ data ];
|
|
else
|
|
part.body.push(data);
|
|
part.bodylen += data.length;
|
|
}).on('error', function(err) {
|
|
part.error = err;
|
|
++partErrors;
|
|
}).on('end', function() {
|
|
if (part.body)
|
|
part.body = Buffer.concat(part.body, part.bodylen);
|
|
state.parts.push(part);
|
|
});
|
|
}).on('error', function(err) {
|
|
error = err;
|
|
}).on('finish', function() {
|
|
assert(finishes++ === 0, makeMsg(v.what, 'finish emitted multiple times'));
|
|
|
|
if (v.dicerError)
|
|
assert(error !== undefined, makeMsg(v.what, 'Expected error'));
|
|
else
|
|
assert(error === undefined, makeMsg(v.what, 'Unexpected error'));
|
|
|
|
if (v.events && v.events.indexOf('part') > -1) {
|
|
assert.equal(state.parts.length,
|
|
v.nparts,
|
|
makeMsg(v.what,
|
|
'Part count mismatch:\nActual: '
|
|
+ state.parts.length
|
|
+ '\nExpected: '
|
|
+ v.nparts));
|
|
|
|
if (!v.npartErrors)
|
|
v.npartErrors = 0;
|
|
assert.equal(partErrors,
|
|
v.npartErrors,
|
|
makeMsg(v.what,
|
|
'Part errors mismatch:\nActual: '
|
|
+ partErrors
|
|
+ '\nExpected: '
|
|
+ v.npartErrors));
|
|
|
|
for (var i = 0, header, body; i < v.nparts; ++i) {
|
|
if (fs.existsSync(fixtureBase + '/part' + (i+1))) {
|
|
body = fs.readFileSync(fixtureBase + '/part' + (i+1));
|
|
if (body.length === 0)
|
|
body = undefined;
|
|
} else
|
|
body = undefined;
|
|
assert.deepEqual(state.parts[i].body,
|
|
body,
|
|
makeMsg(v.what,
|
|
'Part #' + (i+1) + ' body mismatch'));
|
|
if (fs.existsSync(fixtureBase + '/part' + (i+1) + '.header')) {
|
|
header = fs.readFileSync(fixtureBase
|
|
+ '/part' + (i+1) + '.header', 'binary');
|
|
header = JSON.parse(header);
|
|
} else
|
|
header = undefined;
|
|
assert.deepEqual(state.parts[i].header,
|
|
header,
|
|
makeMsg(v.what,
|
|
'Part #' + (i+1)
|
|
+ ' parsed header mismatch:\nActual: '
|
|
+ inspect(state.parts[i].header)
|
|
+ '\nExpected: '
|
|
+ inspect(header)));
|
|
}
|
|
}
|
|
++t;
|
|
next();
|
|
});
|
|
|
|
while (true) {
|
|
n = fs.readSync(fd, buffer, 0, buffer.length, null);
|
|
if (n === 0) {
|
|
setTimeout(function() {
|
|
dicer.write('\r\n\r\n\r\n');
|
|
dicer.end();
|
|
}, 50);
|
|
break;
|
|
}
|
|
dicer.write(n === buffer.length ? buffer : buffer.slice(0, n));
|
|
}
|
|
fs.closeSync(fd);
|
|
}
|
|
next();
|
|
|
|
function makeMsg(what, msg) {
|
|
return '[' + group + what + ']: ' + msg;
|
|
}
|
|
|
|
process.on('exit', function() {
|
|
assert(t === tests.length,
|
|
makeMsg('_exit', 'Only ran ' + t + '/' + tests.length + ' tests'));
|
|
});
|