mirror of
https://github.com/webtorrent/bittorrent-tracker.git
synced 2025-01-18 20:21:36 +00:00
bce64e155d
BREAKING CHANGE: drop simple-get * perf: drop simple-get * feat: undici agent and socks * fix: undici as dev dependency * feat: require user passed proxy objects for http and ws * chore: include undici for tests
198 lines
5.3 KiB
JavaScript
198 lines
5.3 KiB
JavaScript
import Client from '../index.js'
|
|
import commonTest from './common.js'
|
|
import fixtures from 'webtorrent-fixtures'
|
|
import fetch from 'cross-fetch-ponyfill'
|
|
import test from 'tape'
|
|
|
|
const peerId = Buffer.from('-WW0091-4ea5886ce160')
|
|
const unknownPeerId = Buffer.from('01234567890123456789')
|
|
|
|
function parseHtml (html) {
|
|
const extractValue = /[^v^h](\d+)/
|
|
const array = html.replace('torrents', '\n').split('\n').filter(line => line && line.trim().length > 0).map(line => {
|
|
const a = extractValue.exec(line)
|
|
if (a) {
|
|
return parseInt(a[1])
|
|
}
|
|
return null
|
|
})
|
|
let i = 0
|
|
return {
|
|
torrents: array[i++],
|
|
activeTorrents: array[i++],
|
|
peersAll: array[i++],
|
|
peersSeederOnly: array[i++],
|
|
peersLeecherOnly: array[i++],
|
|
peersSeederAndLeecher: array[i++],
|
|
peersIPv4: array[i++],
|
|
peersIPv6: array[i]
|
|
}
|
|
}
|
|
|
|
test('server: get empty stats', t => {
|
|
t.plan(10)
|
|
|
|
commonTest.createServer(t, 'http', async (server, announceUrl) => {
|
|
const url = announceUrl.replace('/announce', '/stats')
|
|
|
|
let res
|
|
try {
|
|
res = await fetch(url)
|
|
} catch (err) {
|
|
t.error(err)
|
|
}
|
|
const data = Buffer.from(await res.arrayBuffer())
|
|
|
|
const stats = parseHtml(data.toString())
|
|
t.equal(res.status, 200)
|
|
t.equal(stats.torrents, 0)
|
|
t.equal(stats.activeTorrents, 0)
|
|
t.equal(stats.peersAll, 0)
|
|
t.equal(stats.peersSeederOnly, 0)
|
|
t.equal(stats.peersLeecherOnly, 0)
|
|
t.equal(stats.peersSeederAndLeecher, 0)
|
|
t.equal(stats.peersIPv4, 0)
|
|
t.equal(stats.peersIPv6, 0)
|
|
|
|
server.close(() => { t.pass('server closed') })
|
|
})
|
|
})
|
|
|
|
test('server: get empty stats with json header', t => {
|
|
t.plan(10)
|
|
|
|
commonTest.createServer(t, 'http', async (server, announceUrl) => {
|
|
const opts = {
|
|
url: announceUrl.replace('/announce', '/stats'),
|
|
headers: {
|
|
accept: 'application/json'
|
|
}
|
|
}
|
|
let res
|
|
try {
|
|
res = await fetch(announceUrl.replace('/announce', '/stats'), opts)
|
|
} catch (err) {
|
|
t.error(err)
|
|
}
|
|
const stats = await res.json()
|
|
|
|
t.equal(res.status, 200)
|
|
t.equal(stats.torrents, 0)
|
|
t.equal(stats.activeTorrents, 0)
|
|
t.equal(stats.peersAll, 0)
|
|
t.equal(stats.peersSeederOnly, 0)
|
|
t.equal(stats.peersLeecherOnly, 0)
|
|
t.equal(stats.peersSeederAndLeecher, 0)
|
|
t.equal(stats.peersIPv4, 0)
|
|
t.equal(stats.peersIPv6, 0)
|
|
|
|
server.close(() => { t.pass('server closed') })
|
|
})
|
|
})
|
|
|
|
test('server: get empty stats on stats.json', t => {
|
|
t.plan(10)
|
|
|
|
commonTest.createServer(t, 'http', async (server, announceUrl) => {
|
|
let res
|
|
try {
|
|
res = await fetch(announceUrl.replace('/announce', '/stats.json'))
|
|
} catch (err) {
|
|
t.error(err)
|
|
}
|
|
const stats = await res.json()
|
|
|
|
t.equal(res.status, 200)
|
|
t.equal(stats.torrents, 0)
|
|
t.equal(stats.activeTorrents, 0)
|
|
t.equal(stats.peersAll, 0)
|
|
t.equal(stats.peersSeederOnly, 0)
|
|
t.equal(stats.peersLeecherOnly, 0)
|
|
t.equal(stats.peersSeederAndLeecher, 0)
|
|
t.equal(stats.peersIPv4, 0)
|
|
t.equal(stats.peersIPv6, 0)
|
|
|
|
server.close(() => { t.pass('server closed') })
|
|
})
|
|
})
|
|
|
|
test('server: get leecher stats.json', t => {
|
|
t.plan(10)
|
|
|
|
commonTest.createServer(t, 'http', (server, announceUrl) => {
|
|
// announce a torrent to the tracker
|
|
const client = new Client({
|
|
infoHash: fixtures.leaves.parsedTorrent.infoHash,
|
|
announce: announceUrl,
|
|
peerId,
|
|
port: 6881
|
|
})
|
|
client.on('error', err => { t.error(err) })
|
|
client.on('warning', err => { t.error(err) })
|
|
|
|
client.start()
|
|
|
|
server.once('start', async () => {
|
|
let res
|
|
try {
|
|
res = await fetch(announceUrl.replace('/announce', '/stats.json'))
|
|
} catch (err) {
|
|
t.error(err)
|
|
}
|
|
const stats = await res.json()
|
|
|
|
t.equal(res.status, 200)
|
|
t.equal(stats.torrents, 1)
|
|
t.equal(stats.activeTorrents, 1)
|
|
t.equal(stats.peersAll, 1)
|
|
t.equal(stats.peersSeederOnly, 0)
|
|
t.equal(stats.peersLeecherOnly, 1)
|
|
t.equal(stats.peersSeederAndLeecher, 0)
|
|
t.equal(stats.clients.WebTorrent['0.91'], 1)
|
|
|
|
client.destroy(() => { t.pass('client destroyed') })
|
|
server.close(() => { t.pass('server closed') })
|
|
})
|
|
})
|
|
})
|
|
|
|
test('server: get leecher stats.json (unknown peerId)', t => {
|
|
t.plan(10)
|
|
|
|
commonTest.createServer(t, 'http', (server, announceUrl) => {
|
|
// announce a torrent to the tracker
|
|
const client = new Client({
|
|
infoHash: fixtures.leaves.parsedTorrent.infoHash,
|
|
announce: announceUrl,
|
|
peerId: unknownPeerId,
|
|
port: 6881
|
|
})
|
|
client.on('error', err => { t.error(err) })
|
|
client.on('warning', err => { t.error(err) })
|
|
|
|
client.start()
|
|
|
|
server.once('start', async () => {
|
|
let res
|
|
try {
|
|
res = await fetch(announceUrl.replace('/announce', '/stats.json'))
|
|
} catch (err) {
|
|
t.error(err)
|
|
}
|
|
const stats = await res.json()
|
|
|
|
t.equal(res.status, 200)
|
|
t.equal(stats.torrents, 1)
|
|
t.equal(stats.activeTorrents, 1)
|
|
t.equal(stats.peersAll, 1)
|
|
t.equal(stats.peersSeederOnly, 0)
|
|
t.equal(stats.peersLeecherOnly, 1)
|
|
t.equal(stats.peersSeederAndLeecher, 0)
|
|
t.equal(stats.clients.unknown['01234567'], 1)
|
|
|
|
client.destroy(() => { t.pass('client destroyed') })
|
|
server.close(() => { t.pass('server closed') })
|
|
})
|
|
})
|
|
})
|