bittorrent-tracker/test/client-ws-socket-pool.js
Cas e6d3189edf
feat: esm (#431)
BREAKING CHANGE: ESM only

* feat: esm

* fix: linter oops
2022-12-05 23:06:54 +01:00

57 lines
1.5 KiB
JavaScript

import Client from '../index.js'
import common from './common.js'
import fixtures from 'webtorrent-fixtures'
import test from 'tape'
const peerId = Buffer.from('01234567890123456789')
const port = 6681
test('ensure client.destroy() callback is called with re-used websockets in socketPool', t => {
t.plan(4)
common.createServer(t, 'ws', (server, announceUrl) => {
const client1 = new Client({
infoHash: fixtures.leaves.parsedTorrent.infoHash,
announce: announceUrl,
peerId,
port,
wrtc: {}
})
common.mockWebsocketTracker(client1)
client1.on('error', err => { t.error(err) })
client1.on('warning', err => { t.error(err) })
client1.start()
client1.once('update', () => {
t.pass('got client1 update')
// second ws client using same announce url will re-use the same websocket
const client2 = new Client({
infoHash: fixtures.alice.parsedTorrent.infoHash, // different info hash
announce: announceUrl,
peerId,
port,
wrtc: {}
})
common.mockWebsocketTracker(client2)
client2.on('error', err => { t.error(err) })
client2.on('warning', err => { t.error(err) })
client2.start()
client2.once('update', () => {
t.pass('got client2 update')
client1.destroy(err => {
t.error(err, 'got client1 destroy callback')
client2.destroy(err => {
t.error(err, 'got client2 destroy callback')
server.close()
})
})
})
})
})
})