You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
1.5 KiB
38 lines
1.5 KiB
4 years ago
|
const normalize = require('../')
|
||
|
const t = require('tap')
|
||
|
|
||
|
t.test('benign string', async t => {
|
||
|
const pkg = { name: 'hello', version: 'world', bin: 'hello.js' }
|
||
|
const expect = { name: 'hello', version: 'world', bin: { hello: 'hello.js' } }
|
||
|
t.strictSame(normalize(pkg), expect)
|
||
|
t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok')
|
||
|
})
|
||
|
|
||
|
t.test('slashy string', async t => {
|
||
|
const pkg = { name: 'hello', version: 'world', bin: '/etc/passwd' }
|
||
|
const expect = { name: 'hello', version: 'world', bin: { hello: 'etc/passwd' } }
|
||
|
t.strictSame(normalize(pkg), expect)
|
||
|
t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok')
|
||
|
})
|
||
|
|
||
|
t.test('dotty string', async t => {
|
||
|
const pkg = { name: 'hello', version: 'world', bin: '../../../../etc/passwd' }
|
||
|
const expect = { name: 'hello', version: 'world', bin: { hello: 'etc/passwd' } }
|
||
|
t.strictSame(normalize(pkg), expect)
|
||
|
t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok')
|
||
|
})
|
||
|
|
||
|
t.test('double path', async t => {
|
||
|
const pkg = { name: 'hello', version: 'world', bin: '/etc/passwd:/bin/usr/exec' }
|
||
|
const expect = { name: 'hello', version: 'world', bin: { hello: 'etc/passwd:/bin/usr/exec' } }
|
||
|
t.strictSame(normalize(pkg), expect)
|
||
|
t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok')
|
||
|
})
|
||
|
|
||
|
t.test('string with no name', async t => {
|
||
|
const pkg = { bin: 'foobar.js' }
|
||
|
const expect = {}
|
||
|
t.strictSame(normalize(pkg), expect)
|
||
|
t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok')
|
||
|
})
|