mirror of
https://github.com/webtorrent/bittorrent-tracker.git
synced 2025-01-22 06:01:35 +00:00
2959c2cea6
Use the new Buffer APIs from Node v6 for added security. For example, `Buffer.from()` will throw if passed a number, unlike `Buffer()` which allocated UNINITIALIZED memory in that case. Use the `safe-buffer` package for compatibility with previous versions of Node.js, including v4.x, v0.12, and v0.10. https://github.com/feross/safe-buffer
18 lines
606 B
JavaScript
18 lines
606 B
JavaScript
var Buffer = require('safe-buffer').Buffer
|
|
var common = require('../lib/common')
|
|
var test = require('tape')
|
|
|
|
// https://github.com/feross/webtorrent/issues/196
|
|
test('encode special chars +* in http tracker urls', function (t) {
|
|
var q = {
|
|
info_hash: Buffer.from('a2a15537542b22925ad10486bf7a8b2a9c42f0d1', 'hex').toString('binary')
|
|
}
|
|
var encoded = 'info_hash=%A2%A1U7T%2B%22%92Z%D1%04%86%BFz%8B%2A%9CB%F0%D1'
|
|
t.equal(common.querystringStringify(q), encoded)
|
|
|
|
// sanity check that encode-decode matches up
|
|
t.deepEqual(common.querystringParse(common.querystringStringify(q)), q)
|
|
|
|
t.end()
|
|
})
|