mirror of
https://github.com/idanoo/GoScrobble
synced 2025-07-01 21:52:19 +00:00
0.2.0 - Mid migration
This commit is contained in:
parent
139e6a915e
commit
7e38fdbd7d
42393 changed files with 5358157 additions and 62 deletions
110
web/node_modules/handle-thing/test/api-test.js
generated
vendored
Normal file
110
web/node_modules/handle-thing/test/api-test.js
generated
vendored
Normal file
|
@ -0,0 +1,110 @@
|
|||
/* eslint-env mocha */
|
||||
|
||||
var assert = require('assert')
|
||||
var net = require('net')
|
||||
var streamPair = require('stream-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,
|
||||
readable: true,
|
||||
writable: true
|
||||
})
|
||||
|
||||
if (mode === 'lazy') {
|
||||
setTimeout(function () {
|
||||
handle.setStream(pair.other)
|
||||
}, 50)
|
||||
}
|
||||
})
|
||||
|
||||
afterEach(function () {
|
||||
assert(handle._stream)
|
||||
})
|
||||
|
||||
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.strictEqual(chunks, 'hello world... ok')
|
||||
|
||||
// allowHalfOpen is `false`, so the `end` should be followed by `close`
|
||||
socket.once('close', function () {
|
||||
done()
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
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.strictEqual(chunks, 'hello world... ok')
|
||||
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
||||
it('should invoke `close` callback', function (done) {
|
||||
handle._options.close = function (callback) {
|
||||
done()
|
||||
process.nextTick(callback)
|
||||
}
|
||||
|
||||
pair.end('hello')
|
||||
socket.resume()
|
||||
})
|
||||
|
||||
it('should kill pending requests', function (done) {
|
||||
handle._options.close = function () {
|
||||
setTimeout(done, 75)
|
||||
}
|
||||
|
||||
socket.write('hello')
|
||||
socket.destroy()
|
||||
})
|
||||
|
||||
if (mode === 'normal') {
|
||||
it('should invoke `getPeerName` callback', function () {
|
||||
handle._options.getPeerName = function () {
|
||||
return { address: 'ohai' }
|
||||
}
|
||||
|
||||
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()
|
||||
})
|
||||
})
|
||||
}
|
||||
})
|
||||
})
|
||||
})
|
Loading…
Add table
Add a link
Reference in a new issue