nav tabs on admin dashboard
This commit is contained in:
178
node_modules/handle-thing/test/api-test.js
generated
vendored
178
node_modules/handle-thing/test/api-test.js
generated
vendored
@@ -1,116 +1,110 @@
|
||||
var assert = require('assert');
|
||||
var net = require('net');
|
||||
var streamPair = require('stream-pair');
|
||||
/* eslint-env mocha */
|
||||
|
||||
var thing = require('../');
|
||||
var assert = require('assert')
|
||||
var net = require('net')
|
||||
var streamPair = require('stream-pair')
|
||||
|
||||
describe('Handle Thing', function() {
|
||||
var handle;
|
||||
var pair;
|
||||
var thing = require('../')
|
||||
|
||||
describe('Handle Thing', function () {
|
||||
var handle
|
||||
var pair
|
||||
var socket;
|
||||
|
||||
[ 'normal', 'lazy' ].forEach(function(mode) {
|
||||
describe(mode, function() {
|
||||
beforeEach(function() {
|
||||
pair = streamPair.create();
|
||||
handle = thing.create(mode === 'normal' ? pair.other : null);
|
||||
socket = new net.Socket({ handle: handle });
|
||||
[ 'normal', 'lazy' ].forEach(function (mode) {
|
||||
describe(mode, function () {
|
||||
beforeEach(function () {
|
||||
pair = streamPair.create()
|
||||
handle = thing.create(mode === 'normal' ? pair.other : null)
|
||||
socket = new net.Socket({
|
||||
handle: handle,
|
||||
readable: true,
|
||||
writable: true
|
||||
})
|
||||
|
||||
if (mode === 'lazy') {
|
||||
setTimeout(function() {
|
||||
handle.setStream(pair.other);
|
||||
}, 50);
|
||||
setTimeout(function () {
|
||||
handle.setStream(pair.other)
|
||||
}, 50)
|
||||
}
|
||||
})
|
||||
|
||||
// For v0.8
|
||||
socket.readable = true;
|
||||
socket.writable = true;
|
||||
});
|
||||
afterEach(function () {
|
||||
assert(handle._stream)
|
||||
})
|
||||
|
||||
afterEach(function() {
|
||||
assert(handle._stream);
|
||||
});
|
||||
it('should write data to Socket', function (done) {
|
||||
pair.write('hello')
|
||||
pair.write(' world')
|
||||
pair.end('... ok')
|
||||
|
||||
it('should write data to Socket', function(done) {
|
||||
pair.write('hello');
|
||||
pair.write(' world');
|
||||
pair.end('... ok');
|
||||
|
||||
var chunks = '';
|
||||
socket.on('data', function(chunk) {
|
||||
chunks += chunk;
|
||||
});
|
||||
socket.on('end', function() {
|
||||
assert.equal(chunks, 'hello world... ok');
|
||||
var chunks = ''
|
||||
socket.on('data', function (chunk) {
|
||||
chunks += chunk
|
||||
})
|
||||
socket.on('end', function () {
|
||||
assert.strictEqual(chunks, 'hello world... ok')
|
||||
|
||||
// allowHalfOpen is `false`, so the `end` should be followed by `close`
|
||||
socket.once('close', function() {
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
socket.once('close', function () {
|
||||
done()
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
it('should read data from Socket', function(done) {
|
||||
socket.write('hello');
|
||||
socket.write(' world');
|
||||
socket.end('... ok');
|
||||
it('should read data from Socket', function (done) {
|
||||
socket.write('hello')
|
||||
socket.write(' world')
|
||||
socket.end('... ok')
|
||||
|
||||
var chunks = '';
|
||||
pair.on('data', function(chunk) {
|
||||
chunks += chunk;
|
||||
});
|
||||
pair.on('end', function() {
|
||||
assert.equal(chunks, 'hello world... ok');
|
||||
var chunks = ''
|
||||
pair.on('data', function (chunk) {
|
||||
chunks += chunk
|
||||
})
|
||||
pair.on('end', function () {
|
||||
assert.strictEqual(chunks, 'hello world... ok')
|
||||
|
||||
done();
|
||||
});
|
||||
});
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
||||
it('should invoke `close` callback', function(done) {
|
||||
handle._options.close = function(callback) {
|
||||
done();
|
||||
process.nextTick(callback);
|
||||
};
|
||||
it('should invoke `close` callback', function (done) {
|
||||
handle._options.close = function (callback) {
|
||||
done()
|
||||
process.nextTick(callback)
|
||||
}
|
||||
|
||||
pair.end('hello');
|
||||
socket.resume();
|
||||
});
|
||||
pair.end('hello')
|
||||
socket.resume()
|
||||
})
|
||||
|
||||
it('should kill pending requests', function(done) {
|
||||
handle._options.close = function() {
|
||||
setTimeout(done, 75);
|
||||
};
|
||||
it('should kill pending requests', function (done) {
|
||||
handle._options.close = function () {
|
||||
setTimeout(done, 75)
|
||||
}
|
||||
|
||||
socket.write('hello');
|
||||
socket.destroy();
|
||||
});
|
||||
socket.write('hello')
|
||||
socket.destroy()
|
||||
})
|
||||
|
||||
if (mode === 'normal') {
|
||||
it('should invoke `getPeerName` callback', function() {
|
||||
handle._options.getPeerName = function() {
|
||||
return { address: 'ohai' };
|
||||
};
|
||||
|
||||
assert.equal(socket.remoteAddress, 'ohai');
|
||||
});
|
||||
|
||||
it('should emit ECONNRESET at `close` event', function(done) {
|
||||
pair.other.emit('close');
|
||||
|
||||
// No error emitted in v0.8
|
||||
if (thing.mode === 'rusty') {
|
||||
socket.on('close', function() {
|
||||
done();
|
||||
});
|
||||
return;
|
||||
it('should invoke `getPeerName` callback', function () {
|
||||
handle._options.getPeerName = function () {
|
||||
return { address: 'ohai' }
|
||||
}
|
||||
|
||||
socket.on('error', function(err) {
|
||||
assert(/ECONNRESET/.test(err.message));
|
||||
done();
|
||||
});
|
||||
});
|
||||
assert.strictEqual(socket.remoteAddress, 'ohai')
|
||||
})
|
||||
|
||||
it('should emit ECONNRESET at `close` event', function (done) {
|
||||
pair.other.emit('close')
|
||||
|
||||
socket.on('error', function (err) {
|
||||
assert(/ECONNRESET/.test(err.message))
|
||||
done()
|
||||
})
|
||||
})
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user