bittorrent-tracker/test/server.js

185 lines
5.1 KiB
JavaScript
Raw Normal View History

var Buffer = require('safe-buffer').Buffer
var Client = require('../')
2016-03-01 02:09:04 +00:00
var common = require('./common')
var test = require('tape')
var electronWebrtc = require('electron-webrtc')
var wrtc
var infoHash = '4cb67059ed6bd08362da625b3ae77f6f4a075705'
var peerId = Buffer.from('01234567890123456789')
var peerId2 = Buffer.from('12345678901234567890')
2016-06-08 23:28:49 +00:00
var peerId3 = Buffer.from('23456789012345678901')
function serverTest (t, serverType, serverFamily) {
t.plan(36)
2016-03-01 02:09:04 +00:00
var hostname = serverFamily === 'inet6'
? '[::1]'
: '127.0.0.1'
var clientIp = serverFamily === 'inet6'
? '::1'
: '127.0.0.1'
2016-06-08 23:28:49 +00:00
var opts = {
2017-02-03 04:28:38 +00:00
serverType: serverType
2016-06-08 23:28:49 +00:00
}
common.createServer(t, opts, function (server) {
// Not using announceUrl param from `common.createServer()` since we
// want to control IPv4 vs IPv6.
var port = server[serverType].address().port
2016-03-01 02:09:04 +00:00
var announceUrl = serverType + '://' + hostname + ':' + port + '/announce'
var client1 = new Client({
infoHash: infoHash,
announce: [ announceUrl ],
peerId: peerId,
port: 6881,
wrtc: wrtc
})
if (serverType === 'ws') common.mockWebsocketTracker(client1)
client1.start()
2014-05-19 01:35:12 +00:00
server.once('start', function () {
t.pass('got start message from client1')
})
client1.once('update', function (data) {
t.equal(data.announce, announceUrl)
t.equal(data.complete, 0)
t.equal(data.incomplete, 1)
server.getSwarm(infoHash, function (err, swarm) {
t.error(err)
t.equal(Object.keys(server.torrents).length, 1)
t.equal(swarm.complete, 0)
t.equal(swarm.incomplete, 1)
t.equal(swarm.peers.length, 1)
2016-03-13 22:57:39 +00:00
2016-03-17 00:58:47 +00:00
var id = serverType === 'ws'
? peerId.toString('hex')
: hostname + ':6881'
var peer = swarm.peers.peek(id)
t.equal(peer.type, serverType)
t.equal(peer.ip, clientIp)
t.equal(peer.peerId, peerId.toString('hex'))
t.equal(peer.complete, false)
2016-03-17 00:58:47 +00:00
if (serverType === 'ws') {
t.equal(typeof peer.port, 'number')
t.ok(peer.socket)
2016-03-13 22:57:39 +00:00
} else {
t.equal(peer.port, 6881)
t.notOk(peer.socket)
2016-03-13 22:57:39 +00:00
}
2014-04-19 06:00:40 +00:00
client1.complete()
client1.once('update', function (data) {
t.equal(data.announce, announceUrl)
t.equal(data.complete, 1)
t.equal(data.incomplete, 0)
client1.scrape()
2014-05-12 00:32:57 +00:00
client1.once('scrape', function (data) {
t.equal(data.announce, announceUrl)
t.equal(data.complete, 1)
t.equal(data.incomplete, 0)
t.equal(typeof data.downloaded, 'number')
2014-05-18 16:15:20 +00:00
var client2 = new Client({
infoHash: infoHash,
announce: [ announceUrl ],
peerId: peerId2,
port: 6882,
wrtc: wrtc
})
if (serverType === 'ws') common.mockWebsocketTracker(client2)
2014-05-19 01:35:12 +00:00
client2.start()
2014-05-19 01:35:12 +00:00
server.once('start', function () {
t.pass('got start message from client2')
})
2014-05-12 00:32:57 +00:00
client2.once('update', function (data) {
t.equal(data.announce, announceUrl)
t.equal(data.complete, 1)
t.equal(data.incomplete, 1)
2016-06-08 23:28:49 +00:00
var client3 = new Client({
infoHash: infoHash,
announce: [ announceUrl ],
peerId: peerId3,
port: 6880,
wrtc: wrtc
2016-06-08 23:28:49 +00:00
})
if (serverType === 'ws') common.mockWebsocketTracker(client3)
2016-06-08 23:28:49 +00:00
client3.start()
server.once('start', function () {
t.pass('got start message from client3')
})
client3.once('update', function (data) {
t.equal(data.announce, announceUrl)
t.equal(data.complete, 1)
t.equal(data.incomplete, 2)
2016-06-08 23:28:49 +00:00
client2.stop()
client2.once('update', function (data) {
t.equal(data.announce, announceUrl)
2016-06-08 23:28:49 +00:00
t.equal(data.complete, 1)
t.equal(data.incomplete, 1)
client2.destroy(function () {
client3.stop()
client3.once('update', function (data) {
t.equal(data.announce, announceUrl)
t.equal(data.complete, 1)
t.equal(data.incomplete, 0)
client3.destroy(function () {
client1.destroy(function () {
server.close()
})
2016-06-08 23:28:49 +00:00
})
})
2016-03-27 03:29:05 +00:00
})
})
2014-05-19 01:35:12 +00:00
})
2014-05-18 16:15:20 +00:00
})
})
})
})
})
})
2014-07-11 10:49:45 +00:00
}
2014-12-12 23:09:40 +00:00
test('http ipv4 server', function (t) {
serverTest(t, 'http', 'inet')
})
test('http ipv6 server', function (t) {
serverTest(t, 'http', 'inet6')
2014-07-11 10:49:45 +00:00
})
test('udp server', function (t) {
2014-12-12 23:09:40 +00:00
serverTest(t, 'udp', 'inet')
})
test('ws server', function (t) {
wrtc = electronWebrtc()
wrtc.electronDaemon.once('ready', function () {
serverTest(t, 'ws', 'inet')
})
t.once('end', function () {
wrtc.close()
})
})