Skip to content
This repository has been archived by the owner on Jul 21, 2023. It is now read-only.

Commit

Permalink
fix: add error event handler (#118)
Browse files Browse the repository at this point in the history
  • Loading branch information
vasco-santos authored Feb 9, 2021
1 parent 757a48f commit 577d350
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 4 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@
"mafmt": "^8.0.1",
"multiaddr": "^8.1.1",
"multiaddr-to-uri": "^6.0.0",
"p-defer": "^3.0.0",
"p-timeout": "^3.2.0"
},
"devDependencies": {
Expand Down
28 changes: 24 additions & 4 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,11 @@ const connect = require('it-ws/client')
const withIs = require('class-is')
const toUri = require('multiaddr-to-uri')
const { AbortError } = require('abortable-iterator')
const pDefer = require('p-defer')

const log = require('debug')('libp2p:websockets')
const debug = require('debug')
const log = debug('libp2p:websockets')
log.error = debug('libp2p:websockets:error')
const env = require('ipfs-utils/src/env')

const createListener = require('./listener')
Expand Down Expand Up @@ -63,10 +66,24 @@ class WebSockets {
const cOpts = ma.toOptions()
log('dialing %s:%s', cOpts.host, cOpts.port)

const errorPromise = pDefer()
const errfn = (err) => {
const msg = `connection error: ${err.message}`
log.error(msg)

errorPromise.reject(err)
}

const rawSocket = connect(toUri(ma), Object.assign({ binary: true }, options))

if (rawSocket.socket.on) {
rawSocket.socket.on('error', errfn)
} else {
rawSocket.socket.onerror = errfn
}

if (!options.signal) {
await rawSocket.connected()
await Promise.race([rawSocket.connected(), errorPromise.promise])

log('connected %s', ma)
return rawSocket
Expand All @@ -77,7 +94,10 @@ class WebSockets {
const abort = new Promise((resolve, reject) => {
onAbort = () => {
reject(new AbortError())
rawSocket.close()
// FIXME: https://github.com/libp2p/js-libp2p-websockets/issues/121
setTimeout(() => {
rawSocket.close()
})
}

// Already aborted?
Expand All @@ -86,7 +106,7 @@ class WebSockets {
})

try {
await Promise.race([abort, rawSocket.connected()])
await Promise.race([abort, errorPromise.promise, rawSocket.connected()])
} finally {
options.signal.removeEventListener('abort', onAbort)
}
Expand Down
11 changes: 11 additions & 0 deletions test/node.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
const https = require('https')
const fs = require('fs')

const AbortController = require('abort-controller').default
const { expect } = require('aegir/utils/chai')
const multiaddr = require('multiaddr')
const goodbye = require('it-goodbye')
Expand Down Expand Up @@ -224,6 +225,16 @@ describe('dial', () => {
expect(result).to.be.eql([uint8ArrayFromString('hey')])
})

it('dial should throw on immediate abort', async () => {
const ma = multiaddr('/ip4/127.0.0.1/tcp/0/ws')
const controller = new AbortController()

const conn = ws.dial(ma, { signal: controller.signal })
controller.abort()

await expect(conn).to.eventually.be.rejected()
})

it('should resolve port 0', async () => {
const ma = multiaddr('/ip4/127.0.0.1/tcp/0/ws')
const ws = new WS({ upgrader: mockUpgrader })
Expand Down

0 comments on commit 577d350

Please sign in to comment.