mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-20 22:52:46 -05:00
Merge pull request #132 from coldrye-collaboration/gh-131
Adds cache option to uplinks
This commit is contained in:
commit
0cabd62dea
16 changed files with 266 additions and 19 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -5,6 +5,7 @@ verdaccio-*.tgz
|
|||
###
|
||||
!bin/verdaccio
|
||||
test-storage*
|
||||
.verdaccio_test_env
|
||||
node_modules
|
||||
|
||||
|
||||
|
|
|
@ -59,6 +59,10 @@ uplinks:
|
|||
#headers:
|
||||
# authorization: "Basic YourBase64EncodedCredentials=="
|
||||
|
||||
# set this to false to prevent tarballs from this upstream
|
||||
# to be stored in the local storage (defaults to true)
|
||||
#cache: false
|
||||
|
||||
packages:
|
||||
# uncomment this for packages with "local-" prefix to be available
|
||||
# for admin only, it's a recommended way of handling private packages
|
||||
|
|
|
@ -140,6 +140,9 @@ class Config {
|
|||
}
|
||||
// sanity check for uplinks
|
||||
for (let i in self.uplinks) {
|
||||
if (self.uplinks[i].cache == null) {
|
||||
self.uplinks[i].cache = true;
|
||||
}
|
||||
if (Object.prototype.hasOwnProperty.call(self.uplinks, i)) {
|
||||
check_user_or_uplink(i);
|
||||
}
|
||||
|
|
|
@ -279,10 +279,14 @@ class Storage {
|
|||
if (uplink == null) {
|
||||
uplink = new Proxy({
|
||||
url: file.url,
|
||||
cache: true,
|
||||
_autogenerated: true,
|
||||
}, self.config);
|
||||
}
|
||||
let savestream = self.local.add_tarball(name, filename);
|
||||
let savestream = null;
|
||||
if (uplink.config.cache) {
|
||||
savestream = self.local.add_tarball(name, filename);
|
||||
}
|
||||
let on_open = function() {
|
||||
// prevent it from being called twice
|
||||
on_open = function() {};
|
||||
|
@ -312,19 +316,23 @@ class Storage {
|
|||
}
|
||||
};
|
||||
|
||||
savestream.on('open', function() {
|
||||
on_open();
|
||||
});
|
||||
if (savestream) {
|
||||
savestream.on('open', function() {
|
||||
on_open();
|
||||
});
|
||||
|
||||
savestream.on('error', function(err) {
|
||||
self.logger.warn( {err: err}
|
||||
, 'error saving file: @{err.message}\n@{err.stack}' );
|
||||
if (savestream) {
|
||||
savestream.abort();
|
||||
}
|
||||
savestream = null;
|
||||
savestream.on('error', function(err) {
|
||||
self.logger.warn( {err: err}
|
||||
, 'error saving file: @{err.message}\n@{err.stack}' );
|
||||
if (savestream) {
|
||||
savestream.abort();
|
||||
}
|
||||
savestream = null;
|
||||
on_open();
|
||||
});
|
||||
} else {
|
||||
on_open();
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -16,6 +16,8 @@ uplinks:
|
|||
timeout: 100ms
|
||||
server2:
|
||||
url: http://localhost:55552/
|
||||
server3:
|
||||
url: http://localhost:55553/
|
||||
baduplink:
|
||||
url: http://localhost:55666/
|
||||
|
||||
|
|
36
test/functional/config-3.yaml
Normal file
36
test/functional/config-3.yaml
Normal file
|
@ -0,0 +1,36 @@
|
|||
storage: ./test-storage3
|
||||
|
||||
users:
|
||||
test:
|
||||
password: a94a8fe5ccb19ba61c4c0873d391e987982fbbd3
|
||||
|
||||
web:
|
||||
enable: true
|
||||
|
||||
uplinks:
|
||||
server1:
|
||||
url: http://localhost:55551/
|
||||
# cache: true
|
||||
server2:
|
||||
url: http://localhost:55552/
|
||||
cache: false
|
||||
|
||||
logs:
|
||||
- {type: stdout, format: pretty, level: trace}
|
||||
|
||||
packages:
|
||||
'pkg-gh131':
|
||||
access: $all
|
||||
proxy: server1
|
||||
|
||||
'pkg-gh1312':
|
||||
access: $all
|
||||
proxy: server2
|
||||
|
||||
'*':
|
||||
access: $all
|
||||
|
||||
listen: 55553
|
||||
|
||||
# expose internal methods
|
||||
_debug: true
|
90
test/functional/gh131.js
Normal file
90
test/functional/gh131.js
Normal file
|
@ -0,0 +1,90 @@
|
|||
'use strict';
|
||||
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
const assert = require('assert');
|
||||
const crypto = require('crypto');
|
||||
|
||||
const STORAGE = 'test-storage3';
|
||||
const TARBALL = 'blahblah';
|
||||
const PKG_GH131 = 'pkg-gh131';
|
||||
const PKG_GH1312 = 'pkg-gh1312';
|
||||
|
||||
function isCached(pkgname, tarballname) {
|
||||
return fs.existsSync(path.join(__dirname, STORAGE, pkgname, tarballname));
|
||||
}
|
||||
|
||||
function readfile(x) {
|
||||
return fs.readFileSync(path.join(__dirname, x));
|
||||
}
|
||||
|
||||
module.exports = function() {
|
||||
const server = process.server;
|
||||
const server2 = process.server2;
|
||||
const server3 = process.server3;
|
||||
|
||||
before(function() {
|
||||
return server.add_package(PKG_GH131);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server.put_tarball(PKG_GH131, TARBALL, readfile('fixtures/binary'))
|
||||
.status(201)
|
||||
.body_ok(/.*/);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
const pkg = require('./lib/package')(PKG_GH131);
|
||||
pkg.dist.shasum = crypto.createHash('sha1').update(readfile('fixtures/binary')).digest('hex');
|
||||
return server.put_version(PKG_GH131, '0.0.1', pkg)
|
||||
.status(201)
|
||||
.body_ok(/published/);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server3.get_package(PKG_GH131)
|
||||
.status(200);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server3.get_tarball(PKG_GH131, TARBALL)
|
||||
.status(200);
|
||||
});
|
||||
|
||||
it('should be caching packages from uplink server1', function () {
|
||||
assert.equal(isCached(PKG_GH131, TARBALL), true);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server2.add_package(PKG_GH1312);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server2.put_tarball(PKG_GH1312, TARBALL, readfile('fixtures/binary'))
|
||||
.status(201)
|
||||
.body_ok(/.*/);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
const pkg = require('./lib/package')(PKG_GH1312);
|
||||
pkg.dist.shasum = crypto.createHash('sha1').update(readfile('fixtures/binary')).digest('hex');
|
||||
return server2.put_version(PKG_GH1312, '0.0.1', pkg)
|
||||
.status(201)
|
||||
.body_ok(/published/);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server3.get_package(PKG_GH1312)
|
||||
.status(200);
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return server3.get_tarball(PKG_GH1312, TARBALL)
|
||||
.status(200);
|
||||
});
|
||||
|
||||
it('must not be caching packages from uplink server2', function () {
|
||||
assert.equal(isCached(PKG_GH1312, TARBALL), false);
|
||||
});
|
||||
};
|
||||
|
|
@ -8,18 +8,20 @@ const exec = require('child_process').exec;
|
|||
describe('Func', function() {
|
||||
const server = process.server;
|
||||
const server2 = process.server2;
|
||||
const server3 = process.server3;
|
||||
|
||||
before(function(done) {
|
||||
Promise.all([
|
||||
require('./lib/startup').start('./test-storage', './config-1.yaml'),
|
||||
require('./lib/startup').start('./test-storage2', './config-2.yaml'),
|
||||
require('./lib/startup').start('./test-storage3', './config-3.yaml'),
|
||||
]).then(() => {
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
before(function() {
|
||||
return Promise.all([server, server2].map(function(server) {
|
||||
return Promise.all([server, server2, server3].map(function(server) {
|
||||
return server.debug().status(200).then(function(body) {
|
||||
server.pid = body.pid;
|
||||
return new Promise(function(resolve, reject) {
|
||||
|
@ -34,7 +36,7 @@ describe('Func', function() {
|
|||
});
|
||||
|
||||
before(function auth() {
|
||||
return Promise.all([server, server2].map(function(server, cb) {
|
||||
return Promise.all([server, server2, server3].map(function(server, cb) {
|
||||
return server.auth('test', 'test').status(201).body_ok(/'test'/);
|
||||
}));
|
||||
});
|
||||
|
@ -58,6 +60,8 @@ describe('Func', function() {
|
|||
require('./logout')();
|
||||
require('./addtag')();
|
||||
require('./plugins')();
|
||||
// requires packages published to server1/server2
|
||||
require('./gh131')();
|
||||
|
||||
after(function(done) {
|
||||
const check = (server) => {
|
||||
|
@ -78,7 +82,7 @@ describe('Func', function() {
|
|||
});
|
||||
});
|
||||
};
|
||||
Promise.all([check(server), check(server2)]).then(function() {
|
||||
Promise.all([check(server), check(server2), check(server3)]).then(function() {
|
||||
done();
|
||||
}, (reason) => {
|
||||
assert.equal(reason, null);
|
||||
|
|
|
@ -8,6 +8,7 @@ const Server = require('./server');
|
|||
const forks = process.forks = [];
|
||||
process.server = Server('http://localhost:55551/');
|
||||
process.server2 = Server('http://localhost:55552/');
|
||||
process.server3 = Server('http://localhost:55553/');
|
||||
process.express = express();
|
||||
process.express.listen(55550);
|
||||
|
||||
|
@ -39,6 +40,13 @@ module.exports.start = function(dir, conf) {
|
|||
};
|
||||
|
||||
process.on('exit', function() {
|
||||
if (forks[0]) forks[0].kill();
|
||||
if (forks[1]) forks[1].kill();
|
||||
if (forks[0]) {
|
||||
forks[0].kill();
|
||||
}
|
||||
if (forks[1]) {
|
||||
forks[1].kill();
|
||||
}
|
||||
if (forks[2]) {
|
||||
forks[2].kill();
|
||||
}
|
||||
});
|
||||
|
|
25
test/integration/config_nocache.yaml
Normal file
25
test/integration/config_nocache.yaml
Normal file
|
@ -0,0 +1,25 @@
|
|||
storage: ./.verdaccio_test_env/test-storage
|
||||
|
||||
users:
|
||||
test:
|
||||
password: a94a8fe5ccb19ba61c4c0873d391e987982fbbd3
|
||||
|
||||
uplinks:
|
||||
npmjs:
|
||||
url: https://registry.npmjs.org/
|
||||
cache: false
|
||||
|
||||
logs:
|
||||
- {type: stdout, format: pretty, level: trace}
|
||||
|
||||
packages:
|
||||
jju:
|
||||
allow_access: all
|
||||
allow_publish: all
|
||||
proxy_access: npmjs
|
||||
|
||||
'*':
|
||||
allow_access: all
|
||||
allow_publish: all
|
||||
|
||||
listen: 55501
|
Binary file not shown.
|
@ -38,7 +38,7 @@ system('npm install jju') and quit('fail');
|
|||
(`node -e 'console.log(require("jju").parse("{qwerty:123}").qwerty+456)'` =~ /579/) or quit('fail');
|
||||
|
||||
system('npm publish ../verdaccio-test-1.2.3.tgz') and quit('fail');
|
||||
system('npm tag verdaccio-test@1.2.3 meow') and quit('fail');
|
||||
system('npm dist-tag add verdaccio-test@1.2.3 meow') and quit('fail');
|
||||
system('npm install verdaccio-test@meow') and quit('fail');
|
||||
|
||||
(`node -e 'require("verdaccio-test")'` =~ /w==w/) or quit('fail');
|
||||
|
|
44
test/integration/test_nocache.pl
Executable file
44
test/integration/test_nocache.pl
Executable file
|
@ -0,0 +1,44 @@
|
|||
#!/usr/bin/perl
|
||||
|
||||
# note to readers: in perl it's useful, in javascript it isn't
|
||||
use strict;
|
||||
|
||||
# setting up working environment && chdir there
|
||||
use Cwd 'abs_path';
|
||||
use File::Basename;
|
||||
$ENV{HOME} = dirname(abs_path( __FILE__ )) . '/.verdaccio_test_env';
|
||||
system('rm -rf .verdaccio_test_env ; mkdir .verdaccio_test_env') and quit('fail');
|
||||
chdir $ENV{HOME};
|
||||
|
||||
use Data::Dumper;
|
||||
my $pid;
|
||||
|
||||
sub quit {
|
||||
print $_[0]."\n";
|
||||
exec("kill $pid ; exit 1");
|
||||
}
|
||||
|
||||
# run verdaccio in a child process
|
||||
if (($pid = fork()) == 0) {
|
||||
exec "../../../bin/verdaccio ../config_nocache.yaml";
|
||||
die "exec failed";
|
||||
}
|
||||
|
||||
system('mkdir node_modules') and quit('fail');
|
||||
system('npm set verdaccio_test_config 12345') and quit('fail');
|
||||
|
||||
if (`cat .npmrc` !~ /verdaccio_test_config/) {
|
||||
quit "npm is using wrong config";
|
||||
}
|
||||
|
||||
system('npm set registry http://localhost:55501') and quit('fail');
|
||||
system(q{/bin/echo -e 'test\ntest\ns@s.s\n' | npm adduser}) and quit('fail');
|
||||
|
||||
system('npm install jju') and quit('fail');
|
||||
system('test ! -f ./test-storage/jju/jju-*.tgz') and quit('fail');
|
||||
|
||||
|
||||
quit("
|
||||
==================================================================
|
||||
All tests seem to be executed successfully, nothing is broken yet.
|
||||
==================================================================");
|
BIN
test/integration/verdaccio-test-1.2.3.tgz
Normal file
BIN
test/integration/verdaccio-test-1.2.3.tgz
Normal file
Binary file not shown.
17
test/unit/config.js
Normal file
17
test/unit/config.js
Normal file
|
@ -0,0 +1,17 @@
|
|||
'use strict';
|
||||
|
||||
const assert = require('assert');
|
||||
const config_hash = require('./partials/config');
|
||||
const Config = require('../../lib/config');
|
||||
|
||||
|
||||
describe('Config', function() {
|
||||
before(function() {
|
||||
this.config = new Config(config_hash);
|
||||
});
|
||||
|
||||
it('npmjs uplink should have a default cache option that is true', function() {
|
||||
assert.equal(this.config.uplinks['npmjs'].cache, true);
|
||||
});
|
||||
});
|
||||
|
|
@ -1,7 +1,12 @@
|
|||
'use strict';
|
||||
|
||||
let config = {
|
||||
const config = {
|
||||
storage: __dirname + '/test-storage',
|
||||
uplinks: {
|
||||
'npmjs': {
|
||||
'url': 'https://registry.npmjs.org/'
|
||||
}
|
||||
},
|
||||
packages: {
|
||||
'*': {
|
||||
allow_access: '$all',
|
||||
|
|
Loading…
Add table
Reference in a new issue