0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-12-23 22:27:34 -05:00
verdaccio/test/functional/security.js

73 lines
2.2 KiB
JavaScript
Raw Normal View History

2017-04-19 14:15:28 -05:00
'use strict';
const assert = require('assert');
2013-12-19 10:11:54 -05:00
module.exports = function() {
2017-04-19 14:15:28 -05:00
let server = process.server;
2013-12-29 01:40:47 -05:00
describe('Security', function() {
before(function() {
return server.addPackage('testpkg-sec');
2017-04-19 14:15:28 -05:00
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('bad pkg #1', function() {
return server.getPackage('package.json')
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid package/);
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('bad pkg #2', function() {
return server.getPackage('__proto__')
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid package/);
});
2017-04-19 14:15:28 -05:00
it('__proto__, connect stuff', function() {
return server.request({uri: '/testpkg-sec?__proto__=1'})
.then(function(body) {
// test for NOT outputting stack trace
2017-04-19 14:15:28 -05:00
assert(!body || typeof(body) === 'object' || body.indexOf('node_modules') === -1);
2013-12-19 10:11:54 -05:00
// test for NOT crashing
2017-04-19 14:15:28 -05:00
return server.request({uri: '/testpkg-sec'}).status(200);
});
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('do not return package.json as an attachment', function() {
return server.request({uri: '/testpkg-sec/-/package.json'})
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid filename/);
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('silly things - reading #1', function() {
return server.request({uri: '/testpkg-sec/-/../../../../../../../../etc/passwd'})
.status(404);
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('silly things - reading #2', function() {
return server.request({uri: '/testpkg-sec/-/%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2fetc%2fpasswd'})
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid filename/);
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('silly things - writing #1', function() {
return server.putTarball('testpkg-sec', 'package.json', '{}')
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid filename/);
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('silly things - writing #3', function() {
return server.putTarball('testpkg-sec', 'node_modules', '{}')
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid filename/);
});
2013-12-19 10:11:54 -05:00
2017-04-19 14:15:28 -05:00
it('silly things - writing #4', function() {
return server.putTarball('testpkg-sec', '../testpkg.tgz', '{}')
.status(403)
2017-04-19 14:15:28 -05:00
.body_error(/invalid filename/);
});
});
};
2013-12-19 10:11:54 -05:00