Skip to content
This repository has been archived by the owner on Jul 3, 2019. It is now read-only.

Commit

Permalink
feat(aliases): add support for registry alias specs
Browse files Browse the repository at this point in the history
  • Loading branch information
zkat committed Aug 15, 2018
1 parent 3c637e8 commit a108451
Show file tree
Hide file tree
Showing 4 changed files with 62 additions and 0 deletions.
3 changes: 3 additions & 0 deletions lib/fetch.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,9 @@ function getFetcher (type) {
// This is spelled out both to prevent sketchy stuff and to make life
// easier for bundlers/preprocessors.
switch (type) {
case 'alias':
fetchers[type] = require('./fetchers/alias')
break
case 'directory':
fetchers[type] = require('./fetchers/directory')
break
Expand Down
20 changes: 20 additions & 0 deletions lib/fetchers/alias.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
'use strict'

const Fetcher = require('../fetch')
const fetchRegistry = require('./registry')

const fetchRemote = module.exports = Object.create(null)

Fetcher.impl(fetchRemote, {
manifest (spec, opts) {
return fetchRegistry.manifest(spec.subSpec, opts)
},

tarball (spec, opts) {
return fetchRegistry.tarball(spec.subSpec, opts)
},

fromManifest (manifest, spec, opts) {
return fetchRegistry.fromManifest(manifest, spec.subSpec, opts)
}
})
19 changes: 19 additions & 0 deletions test/registry.manifest.js
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,16 @@ test('fetches manifest from registry by range', t => {
})
})

test('fetches manifest from registry by alias', t => {
const srv = tnock(t, OPTS.registry)

srv.get('/foo').reply(200, META)
return manifest('bar@npm:foo@^1.2.0', OPTS).then(pkg => {
// Not 1.2.4 because 1.2.3 is `latest`
t.deepEqual(pkg, new Manifest(META.versions['1.2.3']), 'picked right manifest')
})
})

test('fetches manifest from scoped registry by range', t => {
const srv = tnock(t, OPTS.registry)

Expand All @@ -151,6 +161,15 @@ test('fetches manifest from scoped registry by range', t => {
})
})

test('fetches scoped manifest from registry by alias', t => {
const srv = tnock(t, OPTS.registry)

srv.get('/@usr%2ffoo').reply(200, META)
return manifest('bar@npm:@usr/foo@^1.2.0', OPTS).then(pkg => {
t.deepEqual(pkg, new Manifest(META.versions['1.2.3']), 'got scoped manifest from version')
})
})

test('supports opts.includeDeprecated', t => {
const srv = tnock(t, OPTS.registry)

Expand Down
20 changes: 20 additions & 0 deletions test/registry.tarball.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,26 @@ test('basic tarball streaming', function (t) {
})
})

test('aliased tarball streaming', t => {
const pkg = {
'package.json': JSON.stringify({
name: 'foo',
version: '1.2.3'
}),
'index.js': 'console.log("hello world!")'
}
return mockTar(pkg).then(tarData => {
const srv = tnock(t, OPTS.registry)
srv.get('/foo').reply(200, META(tarData))
srv.get('/foo/-/foo-1.2.3.tgz').reply(200, tarData)
return getBuff(
fetch.tarball(npa('bar@npm:foo@^1.2.3'), OPTS)
).then(data => {
t.deepEqual(data, tarData, 'fetched tarball data matches')
})
})
})

test('errors if manifest fails', t => {
const pkg = {
'package.json': JSON.stringify({
Expand Down

0 comments on commit a108451

Please sign in to comment.