mirror of
https://github.com/fluencelabs/js-libp2p-tcp
synced 2025-06-13 21:11:31 +00:00
fix: hanging close promise (#140)
This commit is contained in:
@ -78,7 +78,10 @@ module.exports = (socket, options) => {
|
|||||||
resolve()
|
resolve()
|
||||||
}, CLOSE_TIMEOUT)
|
}, CLOSE_TIMEOUT)
|
||||||
|
|
||||||
socket.once('close', () => clearTimeout(timeout))
|
socket.once('close', () => {
|
||||||
|
clearTimeout(timeout)
|
||||||
|
resolve()
|
||||||
|
})
|
||||||
socket.end(err => {
|
socket.end(err => {
|
||||||
maConn.timeline.close = Date.now()
|
maConn.timeline.close = Date.now()
|
||||||
if (err) return reject(err)
|
if (err) return reject(err)
|
||||||
|
@ -50,4 +50,36 @@ describe('valid localAddr and remoteAddr', () => {
|
|||||||
expect(dialerConn.remoteAddr.toString())
|
expect(dialerConn.remoteAddr.toString())
|
||||||
.to.equal(listenerConn.localAddr.toString())
|
.to.equal(listenerConn.localAddr.toString())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('should handle multiple simultaneous closes', async () => {
|
||||||
|
// Create a Promise that resolves when a connection is handled
|
||||||
|
let handled
|
||||||
|
const handlerPromise = new Promise(resolve => { handled = resolve })
|
||||||
|
|
||||||
|
const handler = conn => handled(conn)
|
||||||
|
|
||||||
|
// Create a listener with the handler
|
||||||
|
const listener = tcp.createListener(handler)
|
||||||
|
|
||||||
|
// Listen on the multi-address
|
||||||
|
await listener.listen(ma)
|
||||||
|
|
||||||
|
const localAddrs = listener.getAddrs()
|
||||||
|
expect(localAddrs.length).to.equal(1)
|
||||||
|
|
||||||
|
// Dial to that address
|
||||||
|
const dialerConn = await tcp.dial(localAddrs[0])
|
||||||
|
|
||||||
|
// Wait for the incoming dial to be handled
|
||||||
|
await handlerPromise
|
||||||
|
|
||||||
|
// Close the listener with two simultaneous calls to `close`
|
||||||
|
await Promise.race([
|
||||||
|
new Promise((resolve, reject) => setTimeout(() => reject(new Error('Timed out waiting for connection close')), 500)),
|
||||||
|
await Promise.all([
|
||||||
|
dialerConn.close(),
|
||||||
|
dialerConn.close()
|
||||||
|
])
|
||||||
|
])
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
Reference in New Issue
Block a user