Compare commits
12 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ec51fcf70c | ||
|
|
565a7d3cfe | ||
|
|
4ac857fba2 | ||
|
|
af7c952d2f | ||
|
|
6705172d4b | ||
|
|
c0295ecc77 | ||
|
|
aaf7f04d08 | ||
|
|
beceac10dc | ||
|
|
fad58273b6 | ||
|
|
e0361dc1f2 | ||
|
|
d8c337acc5 | ||
|
|
9d7683bd61 |
22
History.md
22
History.md
@@ -1,4 +1,26 @@
|
||||
|
||||
0.8.4 / 2014-07-22
|
||||
==================
|
||||
|
||||
* adapt default scpoe in /@:scope/:name/:version
|
||||
|
||||
0.8.3 / 2014-07-22
|
||||
==================
|
||||
|
||||
* hot fix download
|
||||
|
||||
0.8.2 / 2014-07-22
|
||||
==================
|
||||
|
||||
* fix default scope detect
|
||||
|
||||
0.8.1 / 2014-07-21
|
||||
==================
|
||||
|
||||
* add more test cases
|
||||
* support default @org. close #376
|
||||
* hotfix redis init error
|
||||
|
||||
0.8.0 / 2014-07-21
|
||||
==================
|
||||
|
||||
|
||||
@@ -22,8 +22,7 @@ if (config.redis && config.redis.host && config.redis.port) {
|
||||
var redis = require('redis');
|
||||
var wrapper = require('co-redis');
|
||||
var logger = require('./logger');
|
||||
|
||||
var _client = redis.createClient(config.redis);
|
||||
var _client = redis.createClient(config.redis.port, config.redis.host);
|
||||
|
||||
_client.on('error', function (err) {
|
||||
logger.error(err);
|
||||
|
||||
@@ -116,6 +116,7 @@ var config = {
|
||||
message: 'request frequency limited, any question, please contact fengmk2@gmail.com',
|
||||
},
|
||||
enableCompress: false, // enable gzip response or not
|
||||
defaultScope: '', // default scope name
|
||||
};
|
||||
|
||||
// load config/config.js, everything in config.js will cover the same key in index.js
|
||||
|
||||
@@ -46,14 +46,29 @@ var downloadAsReadStream = require('../utils').downloadAsReadStream;
|
||||
* GET /:name
|
||||
*/
|
||||
exports.show = function* (next) {
|
||||
var name = this.params.name || this.params[0];
|
||||
var orginalName = this.params.name || this.params[0];
|
||||
var name = orginalName;
|
||||
var rs = yield [
|
||||
Module.getLastModified(name),
|
||||
Module.listTags(name)
|
||||
];
|
||||
var modifiedTime = rs[0];
|
||||
var tags = rs[1];
|
||||
debug('show %s, last modified: %s, tags: %j', name, modifiedTime, tags);
|
||||
var adaptDefaultScope = false;
|
||||
|
||||
if (tags.length === 0 && config.defaultScope && name.indexOf(config.defaultScope + '/') === 0) {
|
||||
// remove default scope name and retry
|
||||
name = name.split('/')[1];
|
||||
rs = yield [
|
||||
Module.getLastModified(name),
|
||||
Module.listTags(name)
|
||||
];
|
||||
modifiedTime = rs[0];
|
||||
tags = rs[1];
|
||||
adaptDefaultScope = true;
|
||||
}
|
||||
|
||||
debug('show %s(%s), last modified: %s, tags: %j', name, orginalName, modifiedTime, tags);
|
||||
if (modifiedTime) {
|
||||
// find out the latest modfied time
|
||||
// because update tags only modfied tag, wont change module gmt_modified
|
||||
@@ -101,8 +116,8 @@ exports.show = function* (next) {
|
||||
if (unpublishedInfo) {
|
||||
this.status = 404;
|
||||
this.body = {
|
||||
_id: name,
|
||||
name: name,
|
||||
_id: orginalName,
|
||||
name: orginalName,
|
||||
time: {
|
||||
modified: unpublishedInfo.package.time,
|
||||
unpublished: unpublishedInfo.package,
|
||||
@@ -116,7 +131,7 @@ exports.show = function* (next) {
|
||||
// if module not exist in this registry,
|
||||
// sync the module backend and return package info from official registry
|
||||
if (rows.length === 0) {
|
||||
if (!this.allowSync) {
|
||||
if (!this.allowSync || adaptDefaultScope) {
|
||||
this.status = 404;
|
||||
this.body = {
|
||||
error: 'not_found',
|
||||
@@ -169,6 +184,12 @@ exports.show = function* (next) {
|
||||
if (!createdTime || t < createdTime) {
|
||||
createdTime = t;
|
||||
}
|
||||
|
||||
if (adaptDefaultScope) {
|
||||
// change to orginal name for default scope was removed above
|
||||
pkg.name = orginalName;
|
||||
pkg._id = orginalName + '@' + pkg.version;
|
||||
}
|
||||
}
|
||||
|
||||
if (modifiedTime && createdTime) {
|
||||
@@ -204,9 +225,9 @@ exports.show = function* (next) {
|
||||
}
|
||||
|
||||
var info = {
|
||||
_id: name,
|
||||
_id: orginalName,
|
||||
_rev: rev,
|
||||
name: name,
|
||||
name: orginalName,
|
||||
description: pkg.description,
|
||||
"dist-tags": distTags,
|
||||
maintainers: pkg.maintainers,
|
||||
@@ -224,7 +245,7 @@ exports.show = function* (next) {
|
||||
info.bugs = pkg.bugs;
|
||||
info.license = pkg.license;
|
||||
|
||||
debug('show module %s: %s, latest: %s', name, rev, latestMod.version);
|
||||
debug('show module %s: %s, latest: %s', orginalName, rev, latestMod.version);
|
||||
this.body = info;
|
||||
};
|
||||
|
||||
@@ -240,25 +261,33 @@ exports.get = function* (next) {
|
||||
var version = semver.valid(tag);
|
||||
var method = version ? 'get' : 'getByTag';
|
||||
var queryLabel = version ? version : tag;
|
||||
var orginalName = name;
|
||||
var adaptDefaultScope = false;
|
||||
debug('%s %s with %j', method, name, this.params);
|
||||
|
||||
var rs = yield [
|
||||
Module[method](name, queryLabel),
|
||||
packageService.listMaintainers(name),
|
||||
];
|
||||
var mod = rs[0];
|
||||
var mod = yield Module[method](name, queryLabel);
|
||||
if (!mod && config.defaultScope && name.indexOf(config.defaultScope + '/') === 0) {
|
||||
name = name.split('/')[1];
|
||||
mod = yield Module[method](name, queryLabel);
|
||||
adaptDefaultScope = true;
|
||||
}
|
||||
|
||||
if (mod) {
|
||||
common.setDownloadURL(mod.package, this);
|
||||
mod.package._cnpm_publish_time = mod.publish_time;
|
||||
var maintainers = rs[1];
|
||||
var maintainers = yield* packageService.listMaintainers(name);
|
||||
if (maintainers.length > 0) {
|
||||
mod.package.maintainers = maintainers;
|
||||
}
|
||||
if (adaptDefaultScope) {
|
||||
mod.package.name = orginalName;
|
||||
mod.package._id = orginalName + '@' + mod.package.version;
|
||||
}
|
||||
this.body = mod.package;
|
||||
return;
|
||||
}
|
||||
// if not fond, sync from source registry
|
||||
if (!this.allowSync) {
|
||||
if (!this.allowSync || adaptDefaultScope) {
|
||||
this.status = 404;
|
||||
this.body = {
|
||||
error: 'not exist',
|
||||
@@ -283,8 +312,8 @@ exports.get = function* (next) {
|
||||
var _downloads = {};
|
||||
|
||||
exports.download = function *(next) {
|
||||
var name = this.params.name;
|
||||
var filename = this.params.filename;
|
||||
var name = this.params.name || this.params[0];
|
||||
var filename = this.params.filename || this.params[1];
|
||||
var version = filename.slice(name.length + 1, -4);
|
||||
var row = yield Module.get(name, version);
|
||||
// can not get dist
|
||||
@@ -294,6 +323,8 @@ exports.download = function *(next) {
|
||||
url = nfs.url(common.getCDNKey(name, filename));
|
||||
}
|
||||
|
||||
debug('download %s %s %s %s', name, filename, version, url);
|
||||
|
||||
if (!row || !row.package || !row.package.dist) {
|
||||
if (!url) {
|
||||
return yield* next;
|
||||
@@ -547,7 +578,7 @@ exports.updateOrRemove = function* (next) {
|
||||
};
|
||||
|
||||
exports.updateMaintainers = function* (next) {
|
||||
var name = this.params.name;
|
||||
var name = this.params.name || this.params[0];
|
||||
var body = this.request.body;
|
||||
debug('updateMaintainers module %s, %j', name, body);
|
||||
|
||||
@@ -588,7 +619,7 @@ exports.updateMaintainers = function* (next) {
|
||||
|
||||
exports.removeWithVersions = function* (next) {
|
||||
var username = this.user.name;
|
||||
var name = this.params.name;
|
||||
var name = this.params.name || this.params[0];
|
||||
// left versions
|
||||
var versions = this.request.body.versions || {};
|
||||
|
||||
@@ -675,12 +706,12 @@ exports.removeWithVersions = function* (next) {
|
||||
};
|
||||
|
||||
exports.removeTar = function* (next) {
|
||||
debug('remove tarball with filename: %s, id: %s', this.params.filename, this.params.rev);
|
||||
var id = Number(this.params.rev);
|
||||
var filename = this.params.filename;
|
||||
var name = this.params.name;
|
||||
var username = this.user.name;
|
||||
var name = this.params.name || this.params[0];
|
||||
var filename = this.params.filename || this.params[1];
|
||||
var id = Number(this.params.rev || this.params[2]);
|
||||
debug('remove tarball with filename: %s, id: %s', filename, id);
|
||||
|
||||
var username = this.user.name;
|
||||
if (isNaN(id)) {
|
||||
return yield* next;
|
||||
}
|
||||
@@ -707,9 +738,10 @@ exports.removeTar = function* (next) {
|
||||
};
|
||||
|
||||
exports.removeAll = function* (next) {
|
||||
debug('remove all the module with name: %s, id: %s', this.params.name, this.params.rev);
|
||||
var name = this.params.name;
|
||||
var name = this.params.name || this.params[0];
|
||||
var username = this.user.name;
|
||||
var rev = this.params.rev || this.params[1];
|
||||
debug('remove all the module with name: %s, id: %s', name, rev);
|
||||
|
||||
var mods = yield Module.listByName(name);
|
||||
debug('removeAll module %s: %d', name, mods.length);
|
||||
@@ -818,8 +850,8 @@ exports.listAllModuleNames = function *() {
|
||||
// PUT /:name/:tag
|
||||
exports.updateTag = function* () {
|
||||
var version = this.request.body;
|
||||
var tag = this.params.tag;
|
||||
var name = this.params.name;
|
||||
var name = this.params.name || this.params[0];
|
||||
var tag = this.params.tag || this.params[1];
|
||||
debug('updateTag: %s %s to %s', name, version, tag);
|
||||
|
||||
if (!version) {
|
||||
|
||||
@@ -37,7 +37,8 @@ exports.display = function* (next) {
|
||||
var params = this.params;
|
||||
// normal: {name: $name, version: $version}
|
||||
// scope: [$name, $version]
|
||||
var name = params.name || params[0];
|
||||
var orginalName = params.name || params[0];
|
||||
var name = orginalName;
|
||||
var tag = params.version || params[1];
|
||||
debug('display %s with %j', name, params);
|
||||
|
||||
@@ -51,24 +52,29 @@ exports.display = function* (next) {
|
||||
getPackageMethod = 'getByTag';
|
||||
getPackageArgs = [name, tag || 'latest'];
|
||||
}
|
||||
|
||||
var pkg = yield Module[getPackageMethod].apply(Module, getPackageArgs);
|
||||
if (!pkg && config.defaultScope && name.indexOf(config.defaultScope + '/') === 0) {
|
||||
name = name.split('/')[1];
|
||||
pkg = yield Module[getPackageMethod].apply(Module, [name, getPackageArgs[1]]);
|
||||
}
|
||||
|
||||
if (!pkg || !pkg.package) {
|
||||
return yield* next;
|
||||
}
|
||||
|
||||
var r = yield [
|
||||
Module[getPackageMethod].apply(Module, getPackageArgs),
|
||||
down.total(name),
|
||||
ModuleDeps.list(name),
|
||||
ModuleStar.listUsers(name),
|
||||
packageService.listMaintainers(name)
|
||||
];
|
||||
var pkg = r[0];
|
||||
var download = r[1];
|
||||
var dependents = (r[2] || []).map(function (item) {
|
||||
var download = r[0];
|
||||
var dependents = (r[1] || []).map(function (item) {
|
||||
return item.deps;
|
||||
});
|
||||
var users = r[3];
|
||||
var maintainers = r[4];
|
||||
|
||||
if (!pkg || !pkg.package) {
|
||||
return yield* next;
|
||||
}
|
||||
var users = r[2];
|
||||
var maintainers = r[3];
|
||||
|
||||
pkg.package.fromNow = moment(pkg.publish_time).fromNow();
|
||||
pkg = pkg.package;
|
||||
@@ -124,6 +130,10 @@ exports.display = function* (next) {
|
||||
pkg.dist.size = bytes(pkg.dist.size || 0);
|
||||
}
|
||||
|
||||
if (pkg.name !== orginalName) {
|
||||
pkg.name = orginalName;
|
||||
}
|
||||
|
||||
yield this.render('package', {
|
||||
title: 'Package - ' + pkg.name,
|
||||
package: pkg,
|
||||
|
||||
@@ -26,7 +26,11 @@ module.exports = function *notFound(next) {
|
||||
return;
|
||||
}
|
||||
|
||||
var m = /^\/([\w\-\_\.]+)\/?$/.exec(this.url);
|
||||
var m = /^\/([\w\-\.]+)\/?$/.exec(this.path);
|
||||
if (!m) {
|
||||
// scoped packages
|
||||
m = /^\/(@[\w\-\.]+\/[\w\-\.]+)$/.exec(this.path);
|
||||
}
|
||||
debug('%s match %j', this.url, m);
|
||||
if (m) {
|
||||
return this.redirect('/package/' + m[1]);
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "cnpmjs.org",
|
||||
"version": "0.8.0",
|
||||
"version": "0.8.4",
|
||||
"description": "Private npm registry and web for Enterprise, base on MySQL and Simple Store Service",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
|
||||
@@ -44,28 +44,35 @@ function routes(app) {
|
||||
|
||||
// module
|
||||
// scope package: params: [$name]
|
||||
app.get(/\/(@[\w\-\.]+\/[\w\-\.]+)$/, syncByInstall, mod.show);
|
||||
app.get(/^\/(@[\w\-\.]+\/[\w\-\.]+)$/, syncByInstall, mod.show);
|
||||
// scope package: params: [$name, $version]
|
||||
app.get(/\/(@[\w\-\.]+\/[\w\-\.]+)\/([\w\.\-]+)$/, syncByInstall, mod.get);
|
||||
app.get(/^\/(@[\w\-\.]+\/[\w\-\.]+)\/([\w\.\-]+)$/, syncByInstall, mod.get);
|
||||
|
||||
app.get('/:name', syncByInstall, mod.show);
|
||||
app.get('/:name/:version', syncByInstall, mod.get);
|
||||
// try to add module
|
||||
// app.put(/^\/(@[\w\-\.]+\/[\w\-\.]+)$/, login, publishable, mod.addPackageAndDist);
|
||||
app.put('/:name', login, publishable, mod.addPackageAndDist);
|
||||
|
||||
// sync from source npm
|
||||
app.put('/:name/sync', sync.sync);
|
||||
app.get('/:name/sync/log/:id', sync.getSyncLog);
|
||||
|
||||
app.put(/^\/(@[\w\-\.]+\/[\w\-\.]+)\/([\w\-\.]+)/, login, mod.updateTag);
|
||||
app.put('/:name/:tag', login, mod.updateTag);
|
||||
|
||||
// need limit by ip
|
||||
app.get(/^\/(@[\w\-\.]+\/[\w\-\.]+)\/download\/(@[\w\-\.]+\/[\w\-\.]+)/, limit, mod.download);
|
||||
app.get('/:name/download/:filename', limit, mod.download);
|
||||
|
||||
// delete tarball
|
||||
app.delete(/^\/(@[\w\-\.]+\/[\w\-\.]+)\/download\/(@[\w\-\.]+\/[\w\-\.]+)\/\-rev\/([\w\-\.]+)/,
|
||||
login, publishable, mod.removeTar);
|
||||
app.delete('/:name/download/:filename/-rev/:rev', login, publishable, mod.removeTar);
|
||||
|
||||
// update module, unpublish will PUT this
|
||||
app.put(/^\/(@[\w\-\.]+\/[\w\-\.]+)\/\-rev\/([\w\-\.]+)/, login, publishable, mod.updateOrRemove);
|
||||
app.delete(/^\/(@[\w\-\.]+\/[\w\-\.]+)\/\-rev\/([\w\-\.]+)/, login, publishable, mod.removeAll);
|
||||
app.put('/:name/-rev/:rev', login, publishable, mod.updateOrRemove);
|
||||
app.delete('/:name/-rev/:rev', login, publishable, mod.removeAll);
|
||||
|
||||
|
||||
@@ -35,7 +35,7 @@ var fixtures = path.join(path.dirname(path.dirname(__dirname)), 'fixtures');
|
||||
|
||||
describe('controllers/registry/module.test.js', function () {
|
||||
before(function (done) {
|
||||
app.listen(0, function () {
|
||||
app = app.listen(0, function () {
|
||||
done = pedding(2, done);
|
||||
// name: mk2testmodule
|
||||
var pkg = utils.getPackage('mk2testmodule', '0.0.1', utils.admin);
|
||||
|
||||
@@ -16,6 +16,8 @@
|
||||
|
||||
var should = require('should');
|
||||
var request = require('supertest');
|
||||
var mm = require('mm');
|
||||
var config = require('../../../../config');
|
||||
var app = require('../../../../servers/registry');
|
||||
var utils = require('../../../utils');
|
||||
|
||||
@@ -23,27 +25,31 @@ describe('controllers/registry/module/scope_package.test.js', function () {
|
||||
var pkgname = '@cnpm/test-scope-package';
|
||||
var pkgURL = '/@' + encodeURIComponent(pkgname.substring(1));
|
||||
before(function (done) {
|
||||
// add scope package
|
||||
var pkg = utils.getPackage(pkgname, '0.0.1', utils.admin);
|
||||
app = app.listen(0, function () {
|
||||
// add scope package
|
||||
var pkg = utils.getPackage(pkgname, '0.0.1', utils.admin);
|
||||
|
||||
request(app.listen())
|
||||
.put(pkgURL)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, function (err) {
|
||||
should.not.exist(err);
|
||||
pkg = utils.getPackage(pkgname, '0.0.2', utils.admin);
|
||||
// publish 0.0.2
|
||||
request(app.listen())
|
||||
request(app)
|
||||
.put(pkgURL)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, done);
|
||||
.expect(201, function (err) {
|
||||
should.not.exist(err);
|
||||
pkg = utils.getPackage(pkgname, '0.0.2', utils.admin);
|
||||
// publish 0.0.2
|
||||
request(app.listen())
|
||||
.put(pkgURL)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, done);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
afterEach(mm.restore);
|
||||
|
||||
it('should get scope package info: /@scope%2Fname', function (done) {
|
||||
request(app.listen())
|
||||
request(app)
|
||||
.get(pkgURL)
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -75,7 +81,7 @@ describe('controllers/registry/module/scope_package.test.js', function () {
|
||||
});
|
||||
|
||||
it('should get scope package info: /%40scope%2Fname', function (done) {
|
||||
request(app.listen())
|
||||
request(app)
|
||||
.get('/' + encodeURIComponent(pkgname))
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -91,7 +97,7 @@ describe('controllers/registry/module/scope_package.test.js', function () {
|
||||
});
|
||||
|
||||
it('should get scope package with version', function (done) {
|
||||
request(app.listen())
|
||||
request(app)
|
||||
.get('/' + pkgname + '/0.0.1')
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -105,7 +111,7 @@ describe('controllers/registry/module/scope_package.test.js', function () {
|
||||
});
|
||||
|
||||
it('should get scope package with tag', function (done) {
|
||||
request(app.listen())
|
||||
request(app)
|
||||
.get('/' + pkgname + '/latest')
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -117,4 +123,122 @@ describe('controllers/registry/module/scope_package.test.js', function () {
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should download work', function (done) {
|
||||
request(app)
|
||||
.get('/@cnpm/test-scope-package/download/@cnpm/test-scope-package-0.0.2.tgz')
|
||||
.expect('Location', /\.tgz$/)
|
||||
.expect(302, done);
|
||||
});
|
||||
|
||||
describe('support defaultScope', function () {
|
||||
before(function (done) {
|
||||
var pkg = utils.getPackage('test-default-scope-package', '0.0.1', utils.admin);
|
||||
request(app)
|
||||
.put('/' + pkg.name)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, done);
|
||||
});
|
||||
describe('/@:scope/:name', function () {
|
||||
it('should adapt /@cnpm/test-default-scope-package => /test-default-scope-package', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package')
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
var pkg = res.body;
|
||||
pkg._id.should.equal('@cnpm/test-default-scope-package');
|
||||
pkg.name.should.equal('@cnpm/test-default-scope-package');
|
||||
pkg.versions.should.have.keys('0.0.1');
|
||||
pkg['dist-tags'].latest.should.equal('0.0.1');
|
||||
pkg.versions['0.0.1'].name.should.equal('@cnpm/test-default-scope-package');
|
||||
pkg.versions['0.0.1']._id.should.equal('@cnpm/test-default-scope-package@0.0.1');
|
||||
pkg.versions['0.0.1'].dist.tarball
|
||||
.should.containEql('/test-default-scope-package/download/test-default-scope-package-0.0.1.tgz');
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should not adapt /@cnpm123/test-default-scope-package', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm123/test-default-scope-package')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should not adapt when defaultScope is empty', function (done) {
|
||||
mm(config, 'defaultScope', '');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when pkg not exists', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package-not-exists')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when scope not match', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm123');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package')
|
||||
.expect(404, done);
|
||||
});
|
||||
});
|
||||
|
||||
describe('/@:scope/:name/:tag', function () {
|
||||
it('should adapt /@cnpm/test-default-scope-package/latest => /test-default-scope-package/latest', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package/latest')
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
var pkg = res.body;
|
||||
pkg.version.should.have.equal('0.0.1');
|
||||
pkg.name.should.equal('@cnpm/test-default-scope-package');
|
||||
pkg._id.should.equal('@cnpm/test-default-scope-package@0.0.1');
|
||||
pkg.dist.tarball.should.containEql('/test-default-scope-package/download/test-default-scope-package-0.0.1.tgz');
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should not adapt /@cnpm123/test-default-scope-package/latest', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm123/test-default-scope-package/latest')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should not adapt when defaultScope is empty', function (done) {
|
||||
mm(config, 'defaultScope', '');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package/latest')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when pkg not exists', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package-not-exists/latest')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when pkg version not exists', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package-not-exists/1.0.0')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when scope not match', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm123');
|
||||
request(app)
|
||||
.get('/@cnpm/test-default-scope-package/latest')
|
||||
.expect(404, done);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
@@ -23,11 +23,7 @@ var mysql = require('../../../common/mysql');
|
||||
|
||||
describe('controllers/registry/user.test.js', function () {
|
||||
before(function (done) {
|
||||
app.listen(0, done);
|
||||
});
|
||||
|
||||
after(function (done) {
|
||||
app.close(done);
|
||||
app = app.listen(0, done);
|
||||
});
|
||||
|
||||
afterEach(mm.restore);
|
||||
|
||||
@@ -27,11 +27,6 @@ describe('controllers/total.test.js', function () {
|
||||
registryApp.listen(0, done);
|
||||
webApp.listen(0, done);
|
||||
});
|
||||
after(function (done) {
|
||||
done = pedding(2, done);
|
||||
registryApp.close(done);
|
||||
webApp.close(done);
|
||||
});
|
||||
|
||||
describe('GET / in registry', function () {
|
||||
it('should return total info', function (done) {
|
||||
|
||||
@@ -23,11 +23,7 @@ var Dist = require('../../../proxy/dist');
|
||||
|
||||
describe('controllers/web/dist.test.js', function () {
|
||||
before(function (done) {
|
||||
app.listen(0, done);
|
||||
});
|
||||
|
||||
after(function (done) {
|
||||
app.close(done);
|
||||
app = app.listen(0, done);
|
||||
});
|
||||
|
||||
afterEach(mm.restore);
|
||||
|
||||
@@ -18,31 +18,29 @@ var should = require('should');
|
||||
var request = require('supertest');
|
||||
var mm = require('mm');
|
||||
var path = require('path');
|
||||
var pedding = require('pedding');
|
||||
var mysql = require('../../../common/mysql');
|
||||
var app = require('../../../servers/web');
|
||||
var registry = require('../../../servers/registry');
|
||||
var pkg = require('../../../controllers/web/package');
|
||||
var utils = require('../../utils');
|
||||
|
||||
var fixtures = path.join(path.dirname(path.dirname(__dirname)), 'fixtures');
|
||||
|
||||
describe('controllers/web/package.test.js', function () {
|
||||
var baseauth = 'Basic ' + new Buffer('cnpmjstest10:cnpmjstest10').toString('base64');
|
||||
|
||||
before(function (done) {
|
||||
registry.listen(0, function () {
|
||||
var pkg = require(path.join(fixtures, 'package_and_tgz.json'));
|
||||
done = pedding(2, done);
|
||||
registry = registry.listen(0, function () {
|
||||
// name: mk2testmodule
|
||||
var pkg = utils.getPackage('mk2testmodule', '0.0.1', utils.admin);
|
||||
request(registry)
|
||||
.put('/' + pkg.name)
|
||||
.set('authorization', baseauth)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, function () {
|
||||
app.listen(0, done);
|
||||
});
|
||||
.end(done);
|
||||
});
|
||||
});
|
||||
|
||||
after(function (done) {
|
||||
app.close(done);
|
||||
app = app.listen(0, done);
|
||||
});
|
||||
|
||||
afterEach(mm.restore);
|
||||
|
||||
@@ -16,6 +16,9 @@
|
||||
|
||||
var should = require('should');
|
||||
var request = require('supertest');
|
||||
var pedding = require('pedding');
|
||||
var mm = require('mm');
|
||||
var config = require('../../../../config');
|
||||
var registry = require('../../../../servers/registry');
|
||||
var web = require('../../../../servers/web');
|
||||
var utils = require('../../../utils');
|
||||
@@ -24,27 +27,32 @@ describe('controllers/web/package/scope_package.test.js', function () {
|
||||
var pkgname = '@cnpm/test-web-scope-package';
|
||||
var pkgURL = '/@' + encodeURIComponent(pkgname.substring(1));
|
||||
before(function (done) {
|
||||
// add scope package
|
||||
var pkg = utils.getPackage(pkgname, '0.0.1', utils.admin);
|
||||
|
||||
request(registry.listen())
|
||||
.put(pkgURL)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, function (err) {
|
||||
should.not.exist(err);
|
||||
pkg = utils.getPackage(pkgname, '0.0.2', utils.admin);
|
||||
// publish 0.0.2
|
||||
request(registry.listen())
|
||||
done = pedding(2, done);
|
||||
registry = registry.listen(0, function () {
|
||||
// add scope package
|
||||
var pkg = utils.getPackage(pkgname, '0.0.1', utils.admin);
|
||||
request(registry)
|
||||
.put(pkgURL)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, done);
|
||||
.expect(201, function (err) {
|
||||
should.not.exist(err);
|
||||
pkg = utils.getPackage(pkgname, '0.0.2', utils.admin);
|
||||
// publish 0.0.2
|
||||
request(registry)
|
||||
.put(pkgURL)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, done);
|
||||
});
|
||||
});
|
||||
web = web.listen(0, done);
|
||||
});
|
||||
|
||||
afterEach(mm.restore);
|
||||
|
||||
it('should show scope package info page: /@scope%2Fname', function (done) {
|
||||
request(web.listen())
|
||||
request(web)
|
||||
.get('/package' + pkgURL)
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -56,7 +64,7 @@ describe('controllers/web/package/scope_package.test.js', function () {
|
||||
});
|
||||
|
||||
it('should show scope package info page: encodeURIComponent("/@scope/name")', function (done) {
|
||||
request(web.listen())
|
||||
request(web)
|
||||
.get('/package/' + encodeURIComponent(pkgname))
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -68,7 +76,7 @@ describe('controllers/web/package/scope_package.test.js', function () {
|
||||
});
|
||||
|
||||
it('should show scope package info page: /@scope/name', function (done) {
|
||||
request(web.listen())
|
||||
request(web)
|
||||
.get('/package/' + pkgname)
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -79,14 +87,14 @@ describe('controllers/web/package/scope_package.test.js', function () {
|
||||
});
|
||||
});
|
||||
|
||||
it('should /@scope/name/ 404', function (done) {
|
||||
request(web.listen())
|
||||
it('should /package/@scope/name/ 404', function (done) {
|
||||
request(web)
|
||||
.get('/package/' + pkgname + '/')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should show scope package with version: /@scope/name/0.0.2', function (done) {
|
||||
request(web.listen())
|
||||
request(web)
|
||||
.get('/package/' + pkgname + '/0.0.2')
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
@@ -96,4 +104,63 @@ describe('controllers/web/package/scope_package.test.js', function () {
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should /@scope/name redirect to /package/@scope/name', function (done) {
|
||||
request(web)
|
||||
.get('/' + pkgname)
|
||||
.expect('Location', '/package/' + pkgname)
|
||||
.expect(302, done);
|
||||
});
|
||||
|
||||
describe('support default scope', function () {
|
||||
before(function (done) {
|
||||
var pkg = utils.getPackage('test-default-web-scope-package', '0.0.1', utils.admin);
|
||||
request(registry)
|
||||
.put('/' + pkg.name)
|
||||
.set('authorization', utils.adminAuth)
|
||||
.send(pkg)
|
||||
.expect(201, done);
|
||||
});
|
||||
|
||||
it('should adapt /@cnpm/test-default-web-scope-package => /test-default-web-scope-package', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(web)
|
||||
.get('/package/@cnpm/test-default-web-scope-package')
|
||||
.expect(200, function (err, res) {
|
||||
should.not.exist(err);
|
||||
var body = res.text;
|
||||
body.should.containEql('@cnpm/test-default-web-scope-package');
|
||||
body.should.containEql('/test-default-web-scope-package/download/test-default-web-scope-package-0.0.1.tgz');
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
it('should not adapt /@cnpm123/test-default-web-scope-package', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(web)
|
||||
.get('/package/@cnpm123/test-default-web-scope-package')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should not adapt', function (done) {
|
||||
mm(config, 'defaultScope', '');
|
||||
request(web)
|
||||
.get('/package/@cnpm/test-default-web-scope-package')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when scope not match', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm123');
|
||||
request(web)
|
||||
.get('/package/@cnpm/test-default-web-scope-package')
|
||||
.expect(404, done);
|
||||
});
|
||||
|
||||
it('should 404 when pkg not exists', function (done) {
|
||||
mm(config, 'defaultScope', '@cnpm');
|
||||
request(web)
|
||||
.get('/package/@cnpm/test-default-web-scope-package-not-exists')
|
||||
.expect(404, done);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
@@ -20,10 +20,7 @@ var app = require('../../../servers/web');
|
||||
|
||||
describe('controllers/web/user.test.js', function () {
|
||||
before(function (done) {
|
||||
app.listen(0, done);
|
||||
});
|
||||
after(function (done) {
|
||||
app.close(done);
|
||||
app = app.listen(0, done);
|
||||
});
|
||||
|
||||
describe('GET /~:name', function (done) {
|
||||
|
||||
Reference in New Issue
Block a user