use webtorrent-fixtures
This commit is contained in:
parent
dfcbfdf1d2
commit
c91d132b6b
|
@ -20,9 +20,9 @@
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"bittorrent-protocol": "^2.0.0",
|
"bittorrent-protocol": "^2.0.0",
|
||||||
"brfs": "^1.2.0",
|
"brfs": "^1.2.0",
|
||||||
"parse-torrent": "^5.7.1",
|
|
||||||
"standard": "^6.0.4",
|
"standard": "^6.0.4",
|
||||||
"tape": "^4.0.0",
|
"tape": "^4.0.0",
|
||||||
|
"webtorrent-fixtures": "^1.3.0",
|
||||||
"zuul": "^3.8.0"
|
"zuul": "^3.8.0"
|
||||||
},
|
},
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|
|
@ -1,13 +1,9 @@
|
||||||
var bencode = require('bencode')
|
var bencode = require('bencode')
|
||||||
var fs = require('fs')
|
var fixtures = require('webtorrent-fixtures')
|
||||||
var path = require('path')
|
|
||||||
var Protocol = require('bittorrent-protocol')
|
var Protocol = require('bittorrent-protocol')
|
||||||
var test = require('tape')
|
var test = require('tape')
|
||||||
var ut_metadata = require('../')
|
var ut_metadata = require('../')
|
||||||
|
|
||||||
// Used in multiple tests
|
|
||||||
var metadata = fs.readFileSync(path.join(__dirname, 'torrents/leaves-magnet.torrent'))
|
|
||||||
|
|
||||||
test('wire.use(ut_metadata())', function (t) {
|
test('wire.use(ut_metadata())', function (t) {
|
||||||
var wire = new Protocol()
|
var wire = new Protocol()
|
||||||
wire.pipe(wire)
|
wire.pipe(wire)
|
||||||
|
@ -25,11 +21,11 @@ test('wire.use(ut_metadata(metadata))', function (t) {
|
||||||
var wire = new Protocol()
|
var wire = new Protocol()
|
||||||
wire.pipe(wire)
|
wire.pipe(wire)
|
||||||
|
|
||||||
wire.use(ut_metadata(metadata))
|
wire.use(ut_metadata(fixtures.leavesMetadata.torrent))
|
||||||
|
|
||||||
t.ok(wire.ut_metadata)
|
t.ok(wire.ut_metadata)
|
||||||
t.ok(wire.ut_metadata.fetch)
|
t.ok(wire.ut_metadata.fetch)
|
||||||
t.ok(wire.ut_metadata.cancel)
|
t.ok(wire.ut_metadata.cancel)
|
||||||
t.equal(wire.ut_metadata.metadata.toString('hex'), bencode.encode(bencode.decode(metadata).info).toString('hex'))
|
t.equal(wire.ut_metadata.metadata.toString('hex'), bencode.encode(bencode.decode(fixtures.leavesMetadata.torrent).info).toString('hex'))
|
||||||
t.end()
|
t.end()
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,18 +1,9 @@
|
||||||
var bencode = require('bencode')
|
var bencode = require('bencode')
|
||||||
var fs = require('fs')
|
var fixtures = require('webtorrent-fixtures')
|
||||||
var parseTorrent = require('parse-torrent')
|
|
||||||
var path = require('path')
|
|
||||||
var Protocol = require('bittorrent-protocol')
|
var Protocol = require('bittorrent-protocol')
|
||||||
var test = require('tape')
|
var test = require('tape')
|
||||||
var ut_metadata = require('../')
|
var ut_metadata = require('../')
|
||||||
|
|
||||||
// Used in multiple tests
|
|
||||||
var metadata = fs.readFileSync(path.join(__dirname, 'torrents/leaves-magnet.torrent'))
|
|
||||||
var parsedTorrent = parseTorrent(metadata)
|
|
||||||
|
|
||||||
var largeMetadata = fs.readFileSync(path.join(__dirname, 'torrents/ubuntu-12.04.4-alternate-amd64.iso.torrent'))
|
|
||||||
var largeParsedTorrent = parseTorrent(largeMetadata)
|
|
||||||
|
|
||||||
var id1 = new Buffer('01234567890123456789')
|
var id1 = new Buffer('01234567890123456789')
|
||||||
var id2 = new Buffer('12345678901234567890')
|
var id2 = new Buffer('12345678901234567890')
|
||||||
|
|
||||||
|
@ -23,18 +14,18 @@ test('fetch()', function (t) {
|
||||||
var wire2 = new Protocol()
|
var wire2 = new Protocol()
|
||||||
wire1.pipe(wire2).pipe(wire1)
|
wire1.pipe(wire2).pipe(wire1)
|
||||||
|
|
||||||
wire1.use(ut_metadata(metadata)) // wire1 already has metadata
|
wire1.use(ut_metadata(fixtures.leavesMetadata.torrent)) // wire1 already has metadata
|
||||||
wire2.use(ut_metadata()) // wire2 does not
|
wire2.use(ut_metadata()) // wire2 does not
|
||||||
|
|
||||||
wire2.ut_metadata.fetch()
|
wire2.ut_metadata.fetch()
|
||||||
|
|
||||||
wire2.ut_metadata.on('metadata', function (_metadata) {
|
wire2.ut_metadata.on('metadata', function (_metadata) {
|
||||||
// got metadata!
|
// got metadata!
|
||||||
t.equal(_metadata.toString('hex'), bencode.encode({ info: bencode.decode(metadata).info }).toString('hex'))
|
t.equal(_metadata.toString('hex'), bencode.encode({ info: bencode.decode(fixtures.leavesMetadata.torrent).info }).toString('hex'))
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
||||||
wire2.handshake(parsedTorrent.infoHash, id2)
|
wire2.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id2)
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('extended', function (ext) {
|
wire2.on('extended', function (ext) {
|
||||||
|
@ -50,7 +41,7 @@ test('fetch()', function (t) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
wire1.handshake(parsedTorrent.infoHash, id1)
|
wire1.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id1)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('fetch() from peer without metadata', function (t) {
|
test('fetch() from peer without metadata', function (t) {
|
||||||
|
@ -80,7 +71,7 @@ test('fetch() from peer without metadata', function (t) {
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
||||||
wire2.handshake(parsedTorrent.infoHash, id2)
|
wire2.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id2)
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('extended', function (ext) {
|
wire2.on('extended', function (ext) {
|
||||||
|
@ -93,7 +84,7 @@ test('fetch() from peer without metadata', function (t) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
wire1.handshake(parsedTorrent.infoHash, id1)
|
wire1.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id1)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('fetch when peer gets metadata later (setMetadata)', function (t) {
|
test('fetch when peer gets metadata later (setMetadata)', function (t) {
|
||||||
|
@ -106,7 +97,7 @@ test('fetch when peer gets metadata later (setMetadata)', function (t) {
|
||||||
wire1.use(ut_metadata()) // wire1 starts without metadata
|
wire1.use(ut_metadata()) // wire1 starts without metadata
|
||||||
|
|
||||||
process.nextTick(function () {
|
process.nextTick(function () {
|
||||||
wire1.ut_metadata.setMetadata(metadata) // wire1 gets metadata later
|
wire1.ut_metadata.setMetadata(fixtures.leavesMetadata.torrent) // wire1 gets metadata later
|
||||||
|
|
||||||
process.nextTick(function () {
|
process.nextTick(function () {
|
||||||
// wire2 does not start with metadata, but connects to wire1 after it gets metadata
|
// wire2 does not start with metadata, but connects to wire1 after it gets metadata
|
||||||
|
@ -115,11 +106,11 @@ test('fetch when peer gets metadata later (setMetadata)', function (t) {
|
||||||
|
|
||||||
wire2.ut_metadata.on('metadata', function (_metadata) {
|
wire2.ut_metadata.on('metadata', function (_metadata) {
|
||||||
// got metadata!
|
// got metadata!
|
||||||
t.equal(_metadata.toString('hex'), bencode.encode({ info: bencode.decode(metadata).info }).toString('hex'))
|
t.equal(_metadata.toString('hex'), bencode.encode({ info: bencode.decode(fixtures.leavesMetadata.torrent).info }).toString('hex'))
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
||||||
wire2.handshake(parsedTorrent.infoHash, id2)
|
wire2.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id2)
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('extended', function (ext) {
|
wire2.on('extended', function (ext) {
|
||||||
|
@ -135,7 +126,7 @@ test('fetch when peer gets metadata later (setMetadata)', function (t) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
wire1.handshake(parsedTorrent.infoHash, id1)
|
wire1.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id1)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -147,25 +138,25 @@ test('fetch() large torrent', function (t) {
|
||||||
var wire2 = new Protocol()
|
var wire2 = new Protocol()
|
||||||
wire1.pipe(wire2).pipe(wire1)
|
wire1.pipe(wire2).pipe(wire1)
|
||||||
|
|
||||||
wire1.use(ut_metadata(largeMetadata)) // wire1 already has metadata
|
wire1.use(ut_metadata(fixtures.sintel.torrent)) // wire1 already has metadata
|
||||||
wire2.use(ut_metadata()) // wire2 does not
|
wire2.use(ut_metadata()) // wire2 does not
|
||||||
|
|
||||||
wire2.ut_metadata.fetch()
|
wire2.ut_metadata.fetch()
|
||||||
|
|
||||||
wire2.ut_metadata.on('metadata', function (_metadata) {
|
wire2.ut_metadata.on('metadata', function (_metadata) {
|
||||||
// got metadata!
|
// got metadata!
|
||||||
t.equal(_metadata.toString('hex'), bencode.encode({ info: bencode.decode(largeMetadata).info }).toString('hex'))
|
t.equal(_metadata.toString('hex'), bencode.encode({ info: bencode.decode(fixtures.sintel.torrent).info }).toString('hex'))
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
||||||
wire2.handshake(largeParsedTorrent.infoHash, id2)
|
wire2.handshake(fixtures.sintel.parsedTorrent.infoHash, id2)
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('extended', function (ext) {
|
wire2.on('extended', function (ext) {
|
||||||
if (ext === 'handshake') {
|
if (ext === 'handshake') {
|
||||||
t.pass('got extended handshake')
|
t.pass('got extended handshake')
|
||||||
} else if (ext === 'ut_metadata') {
|
} else if (ext === 'ut_metadata') {
|
||||||
// note: this should get called twice, once for each block of the ubuntu metadata
|
// note: this should get called twice, once for each block of the sintel metadata
|
||||||
t.pass('got extended ut_metadata message')
|
t.pass('got extended ut_metadata message')
|
||||||
|
|
||||||
// this is emitted for consistency's sake, but it's ignored
|
// this is emitted for consistency's sake, but it's ignored
|
||||||
|
@ -176,7 +167,7 @@ test('fetch() large torrent', function (t) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
wire1.handshake(largeParsedTorrent.infoHash, id1)
|
wire1.handshake(fixtures.sintel.parsedTorrent.infoHash, id1)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('discard invalid metadata', function (t) {
|
test('discard invalid metadata', function (t) {
|
||||||
|
@ -186,7 +177,7 @@ test('discard invalid metadata', function (t) {
|
||||||
var wire2 = new Protocol()
|
var wire2 = new Protocol()
|
||||||
wire1.pipe(wire2).pipe(wire1)
|
wire1.pipe(wire2).pipe(wire1)
|
||||||
|
|
||||||
var invalidMetadata = metadata.slice(0)
|
var invalidMetadata = fixtures.leavesMetadata.torrent.slice(0)
|
||||||
invalidMetadata[55] = 65 // mess up a byte in the info block
|
invalidMetadata[55] = 65 // mess up a byte in the info block
|
||||||
|
|
||||||
wire1.use(ut_metadata(invalidMetadata))
|
wire1.use(ut_metadata(invalidMetadata))
|
||||||
|
@ -203,8 +194,8 @@ test('discard invalid metadata', function (t) {
|
||||||
})
|
})
|
||||||
|
|
||||||
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
||||||
wire2.handshake(parsedTorrent.infoHash, id2)
|
wire2.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id2)
|
||||||
})
|
})
|
||||||
|
|
||||||
wire1.handshake(parsedTorrent.infoHash, id1)
|
wire1.handshake(fixtures.leavesMetadata.parsedTorrent.infoHash, id1)
|
||||||
})
|
})
|
||||||
|
|
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue