2014-07-11 04:30:30 +00:00
|
|
|
var bencode = require('bencode')
|
2016-05-30 06:12:23 +00:00
|
|
|
var Buffer = require('safe-buffer').Buffer
|
2014-07-11 04:30:30 +00:00
|
|
|
var Client = require('../')
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
var common = require('./common')
|
2014-07-22 05:58:13 +00:00
|
|
|
var commonLib = require('../lib/common')
|
|
|
|
var commonTest = require('./common')
|
2016-03-16 19:22:33 +00:00
|
|
|
var fixtures = require('webtorrent-fixtures')
|
2015-01-22 22:23:53 +00:00
|
|
|
var get = require('simple-get')
|
2014-07-11 04:30:30 +00:00
|
|
|
var test = require('tape')
|
|
|
|
|
2016-05-30 06:12:23 +00:00
|
|
|
var peerId = Buffer.from('01234567890123456789')
|
2014-07-11 04:30:30 +00:00
|
|
|
|
2014-07-22 05:58:13 +00:00
|
|
|
function testSingle (t, serverType) {
|
|
|
|
commonTest.createServer(t, serverType, function (server, announceUrl) {
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
var client = new Client({
|
|
|
|
infoHash: fixtures.leaves.parsedTorrent.infoHash,
|
|
|
|
announce: announceUrl,
|
|
|
|
peerId: peerId,
|
|
|
|
port: 6881,
|
|
|
|
wrtc: {}
|
2015-05-02 00:36:07 +00:00
|
|
|
})
|
|
|
|
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
if (serverType === 'ws') common.mockWebsocketTracker(client)
|
|
|
|
client.on('error', function (err) { t.error(err) })
|
|
|
|
client.on('warning', function (err) { t.error(err) })
|
2015-05-02 00:36:07 +00:00
|
|
|
|
|
|
|
client.scrape()
|
|
|
|
|
|
|
|
client.on('scrape', function (data) {
|
2015-01-29 22:59:08 +00:00
|
|
|
t.equal(data.announce, announceUrl)
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
t.equal(data.infoHash, fixtures.leaves.parsedTorrent.infoHash)
|
2015-01-29 22:59:08 +00:00
|
|
|
t.equal(typeof data.complete, 'number')
|
|
|
|
t.equal(typeof data.incomplete, 'number')
|
|
|
|
t.equal(typeof data.downloaded, 'number')
|
2015-05-17 06:24:20 +00:00
|
|
|
client.destroy()
|
2015-01-29 22:59:08 +00:00
|
|
|
server.close(function () {
|
|
|
|
t.end()
|
2014-07-22 05:58:13 +00:00
|
|
|
})
|
|
|
|
})
|
2014-07-11 04:30:30 +00:00
|
|
|
})
|
2014-07-22 05:58:13 +00:00
|
|
|
}
|
2014-07-11 04:30:30 +00:00
|
|
|
|
2014-07-22 05:58:13 +00:00
|
|
|
test('http: single info_hash scrape', function (t) {
|
|
|
|
testSingle(t, 'http')
|
|
|
|
})
|
2014-07-11 04:30:30 +00:00
|
|
|
|
2014-07-22 05:58:13 +00:00
|
|
|
test('udp: single info_hash scrape', function (t) {
|
|
|
|
testSingle(t, 'udp')
|
|
|
|
})
|
2014-07-11 04:30:30 +00:00
|
|
|
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
test('ws: single info_hash scrape', function (t) {
|
|
|
|
testSingle(t, 'ws')
|
|
|
|
})
|
|
|
|
|
2014-07-22 05:58:13 +00:00
|
|
|
function clientScrapeStatic (t, serverType) {
|
|
|
|
commonTest.createServer(t, serverType, function (server, announceUrl) {
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
var client = Client.scrape({
|
|
|
|
announce: announceUrl,
|
|
|
|
infoHash: fixtures.leaves.parsedTorrent.infoHash,
|
|
|
|
wrtc: {}
|
|
|
|
}, function (err, data) {
|
2015-01-29 22:59:08 +00:00
|
|
|
t.error(err)
|
|
|
|
t.equal(data.announce, announceUrl)
|
2016-03-16 19:22:33 +00:00
|
|
|
t.equal(data.infoHash, fixtures.leaves.parsedTorrent.infoHash)
|
2015-01-29 22:59:08 +00:00
|
|
|
t.equal(typeof data.complete, 'number')
|
|
|
|
t.equal(typeof data.incomplete, 'number')
|
|
|
|
t.equal(typeof data.downloaded, 'number')
|
|
|
|
server.close(function () {
|
|
|
|
t.end()
|
2014-07-11 04:30:30 +00:00
|
|
|
})
|
|
|
|
})
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
if (serverType === 'ws') common.mockWebsocketTracker(client)
|
2014-07-11 04:30:30 +00:00
|
|
|
})
|
2014-07-22 05:58:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
test('http: scrape using Client.scrape static method', function (t) {
|
|
|
|
clientScrapeStatic(t, 'http')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('udp: scrape using Client.scrape static method', function (t) {
|
|
|
|
clientScrapeStatic(t, 'udp')
|
2014-07-11 04:30:30 +00:00
|
|
|
})
|
|
|
|
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
test('ws: scrape using Client.scrape static method', function (t) {
|
|
|
|
clientScrapeStatic(t, 'ws')
|
|
|
|
})
|
|
|
|
|
2016-08-06 01:23:43 +00:00
|
|
|
// Ensure the callback function gets called when an invalid url is passed
|
|
|
|
function clientScrapeStaticInvalid (t, serverType) {
|
|
|
|
var announceUrl = serverType + '://invalid.lol'
|
|
|
|
if (serverType === 'http') announceUrl += '/announce'
|
|
|
|
|
|
|
|
var client = Client.scrape({
|
|
|
|
announce: announceUrl,
|
|
|
|
infoHash: fixtures.leaves.parsedTorrent.infoHash,
|
|
|
|
wrtc: {}
|
|
|
|
}, function (err, data) {
|
|
|
|
t.ok(err instanceof Error)
|
|
|
|
t.end()
|
|
|
|
})
|
|
|
|
if (serverType === 'ws') common.mockWebsocketTracker(client)
|
|
|
|
}
|
|
|
|
|
|
|
|
test.only('http: scrape using Client.scrape static method (invalid url)', function (t) {
|
|
|
|
clientScrapeStaticInvalid(t, 'http')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('udp: scrape using Client.scrape static method (invalid url)', function (t) {
|
|
|
|
clientScrapeStaticInvalid(t, 'udp')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('ws: scrape using Client.scrape static method (invalid url)', function (t) {
|
|
|
|
clientScrapeStaticInvalid(t, 'ws')
|
|
|
|
})
|
|
|
|
|
2015-05-02 00:36:07 +00:00
|
|
|
function clientScrapeMulti (t, serverType) {
|
2016-03-16 19:22:33 +00:00
|
|
|
var infoHash1 = fixtures.leaves.parsedTorrent.infoHash
|
|
|
|
var infoHash2 = fixtures.alice.parsedTorrent.infoHash
|
|
|
|
|
2015-05-02 00:36:07 +00:00
|
|
|
commonTest.createServer(t, serverType, function (server, announceUrl) {
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
Client.scrape({
|
|
|
|
infoHash: [ infoHash1, infoHash2 ],
|
|
|
|
announce: announceUrl
|
|
|
|
}, function (err, results) {
|
2015-05-02 00:36:07 +00:00
|
|
|
t.error(err)
|
|
|
|
|
|
|
|
t.equal(results[infoHash1].announce, announceUrl)
|
2015-12-02 23:35:42 +00:00
|
|
|
t.equal(results[infoHash1].infoHash, infoHash1)
|
2015-05-02 00:36:07 +00:00
|
|
|
t.equal(typeof results[infoHash1].complete, 'number')
|
|
|
|
t.equal(typeof results[infoHash1].incomplete, 'number')
|
|
|
|
t.equal(typeof results[infoHash1].downloaded, 'number')
|
|
|
|
|
|
|
|
t.equal(results[infoHash2].announce, announceUrl)
|
2015-12-02 23:35:42 +00:00
|
|
|
t.equal(results[infoHash2].infoHash, infoHash2)
|
2015-05-02 00:36:07 +00:00
|
|
|
t.equal(typeof results[infoHash2].complete, 'number')
|
|
|
|
t.equal(typeof results[infoHash2].incomplete, 'number')
|
|
|
|
t.equal(typeof results[infoHash2].downloaded, 'number')
|
|
|
|
|
|
|
|
server.close(function () {
|
|
|
|
t.end()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
test('http: MULTI scrape using Client.scrape static method', function (t) {
|
|
|
|
clientScrapeMulti(t, 'http')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('udp: MULTI scrape using Client.scrape static method', function (t) {
|
|
|
|
clientScrapeMulti(t, 'udp')
|
|
|
|
})
|
2014-07-22 05:58:13 +00:00
|
|
|
|
2015-05-02 00:36:07 +00:00
|
|
|
test('server: multiple info_hash scrape (manual http request)', function (t) {
|
2016-03-01 01:55:31 +00:00
|
|
|
t.plan(13)
|
|
|
|
|
2016-03-16 19:22:33 +00:00
|
|
|
var binaryInfoHash1 = commonLib.hexToBinary(fixtures.leaves.parsedTorrent.infoHash)
|
|
|
|
var binaryInfoHash2 = commonLib.hexToBinary(fixtures.alice.parsedTorrent.infoHash)
|
|
|
|
|
2016-03-01 01:55:31 +00:00
|
|
|
commonTest.createServer(t, 'http', function (server, announceUrl) {
|
|
|
|
var scrapeUrl = announceUrl.replace('/announce', '/scrape')
|
2014-07-11 04:30:30 +00:00
|
|
|
|
2015-01-29 22:59:08 +00:00
|
|
|
var url = scrapeUrl + '?' + commonLib.querystringStringify({
|
|
|
|
info_hash: [ binaryInfoHash1, binaryInfoHash2 ]
|
|
|
|
})
|
2016-03-01 01:55:31 +00:00
|
|
|
|
2016-02-14 08:31:44 +00:00
|
|
|
get.concat(url, function (err, res, data) {
|
2016-03-01 01:55:31 +00:00
|
|
|
t.error(err)
|
|
|
|
|
2015-01-29 22:59:08 +00:00
|
|
|
t.equal(res.statusCode, 200)
|
|
|
|
|
|
|
|
data = bencode.decode(data)
|
|
|
|
t.ok(data.files)
|
|
|
|
t.equal(Object.keys(data.files).length, 2)
|
|
|
|
|
|
|
|
t.ok(data.files[binaryInfoHash1])
|
|
|
|
t.equal(typeof data.files[binaryInfoHash1].complete, 'number')
|
|
|
|
t.equal(typeof data.files[binaryInfoHash1].incomplete, 'number')
|
|
|
|
t.equal(typeof data.files[binaryInfoHash1].downloaded, 'number')
|
|
|
|
|
|
|
|
t.ok(data.files[binaryInfoHash2])
|
|
|
|
t.equal(typeof data.files[binaryInfoHash2].complete, 'number')
|
|
|
|
t.equal(typeof data.files[binaryInfoHash2].incomplete, 'number')
|
|
|
|
t.equal(typeof data.files[binaryInfoHash2].downloaded, 'number')
|
|
|
|
|
2016-03-01 01:55:31 +00:00
|
|
|
server.close(function () { t.pass('server closed') })
|
2014-07-11 04:30:30 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2015-05-17 06:24:20 +00:00
|
|
|
test('server: all info_hash scrape (manual http request)', function (t) {
|
2016-03-01 01:55:31 +00:00
|
|
|
t.plan(10)
|
2016-03-16 19:22:33 +00:00
|
|
|
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
var binaryInfoHash = commonLib.hexToBinary(fixtures.leaves.parsedTorrent.infoHash)
|
2016-03-16 19:22:33 +00:00
|
|
|
|
2016-03-01 01:55:31 +00:00
|
|
|
commonTest.createServer(t, 'http', function (server, announceUrl) {
|
|
|
|
var scrapeUrl = announceUrl.replace('/announce', '/scrape')
|
2014-07-11 04:30:30 +00:00
|
|
|
|
2015-01-29 22:59:08 +00:00
|
|
|
// announce a torrent to the tracker
|
BREAKING: Client() takes single opts object now
To use the client, you used to pass in four arguments:
`new Client(peerId, port, parsedTorrent, opts)`
Now, passing in the torrent is no longer required, just the `announce`
and `infoHash` properties. This decouples this package from
`parse-torrent`.
All options get passed in together now:
new Client({
infoHash: '', // hex string or Buffer
peerId: '', // hex string or Buffer
announce: [], // list of tracker server urls
port: 6881 // torrent client port, (in browser, optional)
})
All the normal optional arguments (rtcConfig, wrtc, etc.) can still be
passed in with the rest of these options.
Fixes #118. Fixes #115.
Added ws tests for scrape.
2016-04-01 04:37:51 +00:00
|
|
|
var client = new Client({
|
|
|
|
infoHash: fixtures.leaves.parsedTorrent.infoHash,
|
|
|
|
announce: announceUrl,
|
|
|
|
peerId: peerId,
|
|
|
|
port: 6881
|
|
|
|
})
|
2016-03-01 01:55:31 +00:00
|
|
|
client.on('error', function (err) { t.error(err) })
|
|
|
|
client.on('warning', function (err) { t.error(err) })
|
|
|
|
|
2015-01-29 22:59:08 +00:00
|
|
|
client.start()
|
2015-01-29 20:24:17 +00:00
|
|
|
|
2015-01-29 22:59:08 +00:00
|
|
|
server.once('start', function () {
|
|
|
|
// now do a scrape of everything by omitting the info_hash param
|
2016-02-14 08:31:44 +00:00
|
|
|
get.concat(scrapeUrl, function (err, res, data) {
|
2016-03-01 01:55:31 +00:00
|
|
|
t.error(err)
|
2015-01-29 20:24:17 +00:00
|
|
|
|
2015-01-29 22:59:08 +00:00
|
|
|
t.equal(res.statusCode, 200)
|
|
|
|
data = bencode.decode(data)
|
|
|
|
t.ok(data.files)
|
|
|
|
t.equal(Object.keys(data.files).length, 1)
|
2015-01-29 20:24:17 +00:00
|
|
|
|
2016-03-16 19:22:33 +00:00
|
|
|
t.ok(data.files[binaryInfoHash])
|
|
|
|
t.equal(typeof data.files[binaryInfoHash].complete, 'number')
|
|
|
|
t.equal(typeof data.files[binaryInfoHash].incomplete, 'number')
|
|
|
|
t.equal(typeof data.files[binaryInfoHash].downloaded, 'number')
|
2015-01-29 20:24:17 +00:00
|
|
|
|
2016-03-01 01:55:31 +00:00
|
|
|
client.destroy(function () { t.pass('client destroyed') })
|
|
|
|
server.close(function () { t.pass('server closed') })
|
2015-01-29 20:24:17 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|