dont expose gotMetadata
This commit is contained in:
parent
bda3920643
commit
289b7c3e06
7
index.js
7
index.js
|
@ -23,7 +23,7 @@ module.exports = function (metadata) {
|
||||||
this._bitfield = new BitField(0)
|
this._bitfield = new BitField(0)
|
||||||
|
|
||||||
if (metadata) {
|
if (metadata) {
|
||||||
this.gotMetadata(metadata)
|
this._gotMetadata(metadata)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,7 +89,8 @@ module.exports = function (metadata) {
|
||||||
this._fetching = false
|
this._fetching = false
|
||||||
}
|
}
|
||||||
|
|
||||||
ut_metadata.prototype.gotMetadata = function (_metadata) {
|
ut_metadata.prototype._gotMetadata = function (_metadata) {
|
||||||
|
this.cancel()
|
||||||
this.metadata = _metadata
|
this.metadata = _metadata
|
||||||
this._metadataComplete = true
|
this._metadataComplete = true
|
||||||
this._metadataSize = this.metadata.length
|
this._metadataSize = this.metadata.length
|
||||||
|
@ -173,7 +174,7 @@ module.exports = function (metadata) {
|
||||||
|
|
||||||
// TODO: verify
|
// TODO: verify
|
||||||
|
|
||||||
this.gotMetadata(this.metadata)
|
this._gotMetadata(this.metadata)
|
||||||
}
|
}
|
||||||
|
|
||||||
return ut_metadata
|
return ut_metadata
|
||||||
|
|
|
@ -47,47 +47,6 @@ test('fetch()', function (t) {
|
||||||
wire1.handshake(parsedTorrent.infoHash, id1)
|
wire1.handshake(parsedTorrent.infoHash, id1)
|
||||||
})
|
})
|
||||||
|
|
||||||
test('fetch() then gotMetadata()', function (t) {
|
|
||||||
t.plan(3)
|
|
||||||
|
|
||||||
var wire1 = new Protocol()
|
|
||||||
var wire2 = new Protocol()
|
|
||||||
wire1.pipe(wire2).pipe(wire1)
|
|
||||||
|
|
||||||
wire1.use(ut_metadata(metadata)) // wire1 already has metadata
|
|
||||||
wire2.use(ut_metadata()) // wire2 does not
|
|
||||||
|
|
||||||
wire2.ext('ut_metadata').fetch()
|
|
||||||
|
|
||||||
// simulate that we just got metadata from another peer, so we set it immediately.
|
|
||||||
// 'metadata' event should still get emitted later
|
|
||||||
wire2.ext('ut_metadata').gotMetadata(metadata)
|
|
||||||
|
|
||||||
wire2.ext('ut_metadata').on('metadata', function (_metadata) {
|
|
||||||
// got metadata!
|
|
||||||
t.deepEqual(_metadata, metadata)
|
|
||||||
})
|
|
||||||
|
|
||||||
wire2.on('handshake', function (infoHash, peerId, extensions) {
|
|
||||||
wire2.handshake(parsedTorrent.infoHash, id2)
|
|
||||||
})
|
|
||||||
|
|
||||||
wire2.on('extended', function (ext) {
|
|
||||||
if (ext === 'handshake') {
|
|
||||||
t.pass('got extended handshake')
|
|
||||||
} else if (ext === 'ut_metadata') {
|
|
||||||
t.pass('got extended ut_metadata message')
|
|
||||||
// this is emitted for consistency's sake, but it's ignored
|
|
||||||
// by the user since the ut_metadata package handles the
|
|
||||||
// complexities internally
|
|
||||||
} else {
|
|
||||||
t.fail('unexpected handshake type')
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
wire1.handshake(parsedTorrent.infoHash, id1)
|
|
||||||
})
|
|
||||||
|
|
||||||
test('fetch() from peer without metadata', function (t) {
|
test('fetch() from peer without metadata', function (t) {
|
||||||
t.plan(1)
|
t.plan(1)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue