mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-13 22:48:31 -05:00
e2e cli npm 6 (#3282)
* chore: add config utility * improve verdaccio bin location * add new npm cli e2e tests * add tests * rename files
This commit is contained in:
parent
a123775f20
commit
1755840cd3
60 changed files with 602 additions and 749 deletions
48
.github/workflows/ci.yml
vendored
48
.github/workflows/ci.yml
vendored
|
@ -139,34 +139,32 @@ jobs:
|
||||||
# env:
|
# env:
|
||||||
# DEBUG: verdaccio:e2e*
|
# DEBUG: verdaccio:e2e*
|
||||||
# FIXME verify why fails on Node 16 (locally works fine)
|
# FIXME verify why fails on Node 16 (locally works fine)
|
||||||
# ci-e2e-cli:
|
ci-e2e-cli:
|
||||||
# needs: [format, lint]
|
needs: [format, lint]
|
||||||
# runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
# # TODO: fails on migrate to node 16, we need to check why
|
name: CLI Test E2E Node 16
|
||||||
# name: CLI Test E2E Node 16
|
steps:
|
||||||
# steps:
|
- uses: actions/checkout@v3
|
||||||
# - uses: actions/checkout@v3
|
- uses: actions/setup-node@v3
|
||||||
# - uses: actions/setup-node@v3
|
with:
|
||||||
# with:
|
node-version: 16
|
||||||
# node-version: 16
|
- name: Install pnpm
|
||||||
# - name: Install pnpm
|
run: npm i pnpm@6.32.15 -g
|
||||||
# run: npm i pnpm@latest -g
|
- uses: actions/cache@v3
|
||||||
# - uses: actions/cache@v3
|
with:
|
||||||
# with:
|
path: ~/.pnpm-store
|
||||||
# path: ~/.pnpm-store
|
key: pnpm-${{ hashFiles('pnpm-lock.yaml') }}
|
||||||
# key: pnpm-${{ hashFiles('pnpm-lock.yaml') }}
|
- name: Install
|
||||||
# - name: Install
|
## we need scripts, pupetter downloads aditional content
|
||||||
# ## we need scripts, pupetter downloads aditional content
|
run: pnpm recursive install --frozen-lockfile
|
||||||
# run: pnpm recursive install --frozen-lockfile
|
- name: build
|
||||||
# - name: build
|
run: pnpm build
|
||||||
# run: pnpm build
|
- name: Test CLI
|
||||||
# - name: Test CLI
|
run: pnpm test:e2e:cli
|
||||||
# run: pnpm test:e2e:cli
|
|
||||||
# env:
|
# env:
|
||||||
# DEBUG: verdaccio*
|
# DEBUG: verdaccio*
|
||||||
sync-translations:
|
sync-translations:
|
||||||
# needs: [ci-e2e-cli, ci-e2e-ui]
|
needs: [ci-e2e-cli, ci-e2e-ui]
|
||||||
needs: [ci-e2e-ui]
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
name: synchronize translations
|
name: synchronize translations
|
||||||
if: (github.event_name == 'push' && github.ref == 'refs/heads/master') || github.event_name == 'workflow_dispatch'
|
if: (github.event_name == 'push' && github.ref == 'refs/heads/master') || github.event_name == 'workflow_dispatch'
|
||||||
|
|
|
@ -110,6 +110,7 @@
|
||||||
"verdaccio-memory": "workspace:*"
|
"verdaccio-memory": "workspace:*"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
"prepare": "husky install",
|
||||||
"husky:pre-commit": "lint-staged",
|
"husky:pre-commit": "lint-staged",
|
||||||
"clean": "pnpm recursive run clean",
|
"clean": "pnpm recursive run clean",
|
||||||
"build": "pnpm recursive run build --filter=!@verdaccio/website",
|
"build": "pnpm recursive run build --filter=!@verdaccio/website",
|
||||||
|
@ -118,7 +119,7 @@
|
||||||
"format:check": "prettier --check \"**/*.{js,jsx,ts,tsx,json,yml,yaml,md}\"",
|
"format:check": "prettier --check \"**/*.{js,jsx,ts,tsx,json,yml,yaml,md}\"",
|
||||||
"lint": "eslint --max-warnings 100 \"**/*.{js,jsx,ts,tsx}\"",
|
"lint": "eslint --max-warnings 100 \"**/*.{js,jsx,ts,tsx}\"",
|
||||||
"test": "pnpm recursive test --filter ./packages",
|
"test": "pnpm recursive test --filter ./packages",
|
||||||
"test:e2e:cli": "pnpm test --filter ...@verdaccio/e2e-cli",
|
"test:e2e:cli": "pnpm test --filter ...@verdaccio/e2e-*",
|
||||||
"test:e2e:ui": "pnpm test --filter ...@verdaccio/e2e-ui",
|
"test:e2e:ui": "pnpm test --filter ...@verdaccio/e2e-ui",
|
||||||
"start": "concurrently --kill-others \"pnpm _start:server\" \"pnpm _start:web\"",
|
"start": "concurrently --kill-others \"pnpm _start:server\" \"pnpm _start:web\"",
|
||||||
"benchmark:hyper": "verdaccio-benchmark hyper -r ./hyper-results.json",
|
"benchmark:hyper": "verdaccio-benchmark hyper -r ./hyper-results.json",
|
||||||
|
|
8
packages/config/src/conf/index.ts
Normal file
8
packages/config/src/conf/index.ts
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import { join } from 'path';
|
||||||
|
|
||||||
|
import { parseConfigFile } from '../parse';
|
||||||
|
|
||||||
|
export function getDefaultConfig(fileName = 'default.yaml') {
|
||||||
|
const file = join(__dirname, `./${fileName}`);
|
||||||
|
return parseConfigFile(file);
|
||||||
|
}
|
|
@ -7,3 +7,4 @@ export * from './uplinks';
|
||||||
export * from './security';
|
export * from './security';
|
||||||
export * from './user';
|
export * from './user';
|
||||||
export { default as ConfigBuilder } from './builder';
|
export { default as ConfigBuilder } from './builder';
|
||||||
|
export { getDefaultConfig } from './conf';
|
||||||
|
|
|
@ -8,6 +8,7 @@ import {
|
||||||
ROLES,
|
ROLES,
|
||||||
WEB_TITLE,
|
WEB_TITLE,
|
||||||
defaultSecurity,
|
defaultSecurity,
|
||||||
|
getDefaultConfig,
|
||||||
parseConfigFile,
|
parseConfigFile,
|
||||||
} from '../src';
|
} from '../src';
|
||||||
import { parseConfigurationFile } from './utils';
|
import { parseConfigurationFile } from './utils';
|
||||||
|
@ -74,7 +75,7 @@ describe('check basic content parsed file', () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
test('parse default.yaml', () => {
|
test('parse default.yaml', () => {
|
||||||
const config = new Config(parseConfigFile(resolveConf('default')));
|
const config = new Config(getDefaultConfig());
|
||||||
checkDefaultUplink(config);
|
checkDefaultUplink(config);
|
||||||
expect(config.storage).toBe('./storage');
|
expect(config.storage).toBe('./storage');
|
||||||
expect(config.auth.htpasswd.file).toBe('./htpasswd');
|
expect(config.auth.htpasswd.file).toBe('./htpasswd');
|
||||||
|
@ -82,7 +83,7 @@ describe('check basic content parsed file', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
test('parse docker.yaml', () => {
|
test('parse docker.yaml', () => {
|
||||||
const config = new Config(parseConfigFile(resolveConf('docker')));
|
const config = new Config(getDefaultConfig('docker.yaml'));
|
||||||
checkDefaultUplink(config);
|
checkDefaultUplink(config);
|
||||||
expect(config.storage).toBe('/verdaccio/storage/data');
|
expect(config.storage).toBe('/verdaccio/storage/data');
|
||||||
expect(config.auth.htpasswd.file).toBe('/verdaccio/storage/htpasswd');
|
expect(config.auth.htpasswd.file).toBe('/verdaccio/storage/htpasswd');
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
#!/usr/bin/env node
|
#!/usr/bin/env node
|
||||||
|
|
||||||
require('@verdaccio/cli');
|
require('../build/start');
|
||||||
|
|
|
@ -96,15 +96,22 @@ export class Registry {
|
||||||
silent: false,
|
silent: false,
|
||||||
};
|
};
|
||||||
|
|
||||||
// @ts-ignore
|
if (this.debug) {
|
||||||
const debugPort = parseInt(port, 10) + 5;
|
const debugPort = port + 5;
|
||||||
|
debug('debug port %o', debugPort);
|
||||||
childOptions = Object.assign({}, childOptions, {
|
childOptions = Object.assign({}, childOptions, {
|
||||||
execArgv: [`--inspect=${debugPort}`],
|
execArgv: [`--inspect=${debugPort}`],
|
||||||
env: {
|
env: {
|
||||||
DEBUG: process.env.DEBUG,
|
DEBUG: process.env.DEBUG,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
childOptions = Object.assign({}, childOptions, {
|
||||||
|
env: {
|
||||||
|
DEBUG: process.env.DEBUG,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
const { configPath } = this;
|
const { configPath } = this;
|
||||||
debug('configPath %s', configPath);
|
debug('configPath %s', configPath);
|
||||||
|
|
478
pnpm-lock.yaml
generated
478
pnpm-lock.yaml
generated
|
@ -1245,50 +1245,39 @@ importers:
|
||||||
verdaccio-auth-memory: link:../plugins/auth-memory
|
verdaccio-auth-memory: link:../plugins/auth-memory
|
||||||
verdaccio-memory: link:../plugins/memory
|
verdaccio-memory: link:../plugins/memory
|
||||||
|
|
||||||
test/e2e-cli:
|
test/cli/cli-commons:
|
||||||
specifiers:
|
|
||||||
debug: 4.3.3
|
|
||||||
fs-extra: 10.0.0
|
|
||||||
get-port: 5.1.1
|
|
||||||
npm: 7.24.2
|
|
||||||
pnpm: 6.27.1
|
|
||||||
request: 2.88.0
|
|
||||||
semver: 7.3.5
|
|
||||||
wait-on: ^6.0.0
|
|
||||||
yarn: 1.22.17
|
|
||||||
dependencies:
|
|
||||||
debug: 4.3.3
|
|
||||||
npm: 7.24.2
|
|
||||||
pnpm: 6.27.1
|
|
||||||
request: 2.88.0
|
|
||||||
yarn: 1.22.17
|
|
||||||
devDependencies:
|
|
||||||
fs-extra: 10.0.0
|
|
||||||
get-port: 5.1.1
|
|
||||||
semver: 7.3.5
|
|
||||||
wait-on: 6.0.0
|
|
||||||
|
|
||||||
test/e2e-ui:
|
|
||||||
specifiers:
|
specifiers:
|
||||||
'@verdaccio/config': workspace:6.0.0-6-next.14
|
'@verdaccio/config': workspace:6.0.0-6-next.14
|
||||||
'@verdaccio/core': workspace:6.0.0-6-next.5
|
'@verdaccio/core': workspace:6.0.0-6-next.5
|
||||||
'@verdaccio/test-helper': workspace:1.1.0-6-next.1
|
'@verdaccio/test-helper': workspace:1.1.0-6-next.1
|
||||||
debug: 4.3.4
|
debug: 4.3.3
|
||||||
kleur: ^3.0.3
|
fs-extra: 10.0.0
|
||||||
lodash: ^4.17.21
|
get-port: 5.1.1
|
||||||
puppeteer: 10.4.0
|
got: 11.8.3
|
||||||
rimraf: 3.0.2
|
npm: 6.14.5
|
||||||
|
semver: 7.3.5
|
||||||
verdaccio: workspace:6.0.0-6-next.41
|
verdaccio: workspace:6.0.0-6-next.41
|
||||||
devDependencies:
|
wait-on: ^6.0.0
|
||||||
'@verdaccio/config': link:../../packages/config
|
dependencies:
|
||||||
'@verdaccio/core': link:../../packages/core/core
|
'@verdaccio/config': link:../../../packages/config
|
||||||
'@verdaccio/test-helper': link:../../packages/tools/helpers
|
'@verdaccio/core': link:../../../packages/core/core
|
||||||
debug: 4.3.4
|
'@verdaccio/test-helper': link:../../../packages/tools/helpers
|
||||||
kleur: 3.0.3
|
debug: 4.3.3
|
||||||
lodash: 4.17.21
|
fs-extra: 10.0.0
|
||||||
puppeteer: 10.4.0
|
get-port: 5.1.1
|
||||||
rimraf: 3.0.2
|
got: 11.8.3
|
||||||
verdaccio: link:../../packages/verdaccio
|
npm: 6.14.5
|
||||||
|
semver: 7.3.5
|
||||||
|
verdaccio: link:../../../packages/verdaccio
|
||||||
|
wait-on: 6.0.1_debug@4.3.3
|
||||||
|
|
||||||
|
test/cli/e2e-npm6:
|
||||||
|
specifiers:
|
||||||
|
'@verdaccio/test-cli-commons': workspace:1.0.0
|
||||||
|
npm: latest-6
|
||||||
|
dependencies:
|
||||||
|
'@verdaccio/test-cli-commons': link:../cli-commons
|
||||||
|
npm: 6.14.17
|
||||||
|
|
||||||
website:
|
website:
|
||||||
specifiers:
|
specifiers:
|
||||||
|
@ -9486,11 +9475,6 @@ packages:
|
||||||
resolution: {integrity: sha512-e6ZowgGJmTuXa3GyaPbTGxX17tnThl2aSSizrFthQ7m9uLGZBXiGhgE55cjRZTF5kjZvYn9EOPOMljdjwbflxw==}
|
resolution: {integrity: sha512-e6ZowgGJmTuXa3GyaPbTGxX17tnThl2aSSizrFthQ7m9uLGZBXiGhgE55cjRZTF5kjZvYn9EOPOMljdjwbflxw==}
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/@types/node/16.11.17:
|
|
||||||
resolution: {integrity: sha512-C1vTZME8cFo8uxY2ui41xcynEotVkczIVI5AjLmy5pkpBv/FtG+jhtOlfcPysI8VRVwoOMv6NJm44LGnoMSWkw==}
|
|
||||||
dev: true
|
|
||||||
optional: true
|
|
||||||
|
|
||||||
/@types/node/16.11.19:
|
/@types/node/16.11.19:
|
||||||
resolution: {integrity: sha512-BPAcfDPoHlRQNKktbsbnpACGdypPFBuX4xQlsWDE7B8XXcfII+SpOLay3/qZmCLb39kV5S1RTYwXdkx2lwLYng==}
|
resolution: {integrity: sha512-BPAcfDPoHlRQNKktbsbnpACGdypPFBuX4xQlsWDE7B8XXcfII+SpOLay3/qZmCLb39kV5S1RTYwXdkx2lwLYng==}
|
||||||
|
|
||||||
|
@ -9780,14 +9764,6 @@ packages:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/yargs-parser': 20.2.0
|
'@types/yargs-parser': 20.2.0
|
||||||
|
|
||||||
/@types/yauzl/2.9.1:
|
|
||||||
resolution: {integrity: sha512-A1b8SU4D10uoPjwb0lnHmmu8wZhR9d+9o2PKBQT2jU5YPTKsxac6M2qGAdY7VcL+dHHhARVUDmeg0rOrcd9EjA==}
|
|
||||||
requiresBuild: true
|
|
||||||
dependencies:
|
|
||||||
'@types/node': 16.11.17
|
|
||||||
dev: true
|
|
||||||
optional: true
|
|
||||||
|
|
||||||
/@types/yup/0.29.13:
|
/@types/yup/0.29.13:
|
||||||
resolution: {integrity: sha512-qRyuv+P/1t1JK1rA+elmK1MmCL1BapEzKKfbEhDBV/LMMse4lmhZ/XbgETI39JveDJRpLjmToOI6uFtMW/WR2g==}
|
resolution: {integrity: sha512-qRyuv+P/1t1JK1rA+elmK1MmCL1BapEzKKfbEhDBV/LMMse4lmhZ/XbgETI39JveDJRpLjmToOI6uFtMW/WR2g==}
|
||||||
dev: true
|
dev: true
|
||||||
|
@ -10960,6 +10936,14 @@ packages:
|
||||||
dependencies:
|
dependencies:
|
||||||
follow-redirects: 1.13.0
|
follow-redirects: 1.13.0
|
||||||
|
|
||||||
|
/axios/0.25.0_debug@4.3.3:
|
||||||
|
resolution: {integrity: sha512-cD8FOb0tRH3uuEe6+evtAbgJtfxr7ly3fQjYcMcuPlgkwVS9xboaVIpcDV+cYQe+yGykgwZCs1pzjntcGa6l5g==}
|
||||||
|
dependencies:
|
||||||
|
follow-redirects: 1.14.9_debug@4.3.3
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- debug
|
||||||
|
dev: false
|
||||||
|
|
||||||
/axios/0.25.0_debug@4.3.4:
|
/axios/0.25.0_debug@4.3.4:
|
||||||
resolution: {integrity: sha512-cD8FOb0tRH3uuEe6+evtAbgJtfxr7ly3fQjYcMcuPlgkwVS9xboaVIpcDV+cYQe+yGykgwZCs1pzjntcGa6l5g==}
|
resolution: {integrity: sha512-cD8FOb0tRH3uuEe6+evtAbgJtfxr7ly3fQjYcMcuPlgkwVS9xboaVIpcDV+cYQe+yGykgwZCs1pzjntcGa6l5g==}
|
||||||
dependencies:
|
dependencies:
|
||||||
|
@ -11685,10 +11669,6 @@ packages:
|
||||||
resolution: {integrity: sha1-M3dm2hWAEhD92VbCLpxokaudAzc=}
|
resolution: {integrity: sha1-M3dm2hWAEhD92VbCLpxokaudAzc=}
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/buffer-crc32/0.2.13:
|
|
||||||
resolution: {integrity: sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=}
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/buffer-equal-constant-time/1.0.1:
|
/buffer-equal-constant-time/1.0.1:
|
||||||
resolution: {integrity: sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=}
|
resolution: {integrity: sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=}
|
||||||
|
|
||||||
|
@ -13755,10 +13735,6 @@ packages:
|
||||||
- supports-color
|
- supports-color
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/devtools-protocol/0.0.901419:
|
|
||||||
resolution: {integrity: sha512-4INMPwNm9XRpBukhNbF7OB6fNTTCaI8pzy/fXg0xQzAy5h3zL1P8xT3QazgKqBrb/hAYwIBizqDBZ7GtJE74QQ==}
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/dezalgo/1.0.3:
|
/dezalgo/1.0.3:
|
||||||
resolution: {integrity: sha1-f3Qt4Gb8dIvI24IFad3c5Jvw1FY=}
|
resolution: {integrity: sha1-f3Qt4Gb8dIvI24IFad3c5Jvw1FY=}
|
||||||
dependencies:
|
dependencies:
|
||||||
|
@ -15425,20 +15401,6 @@ packages:
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
/extract-zip/2.0.1:
|
|
||||||
resolution: {integrity: sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==}
|
|
||||||
engines: {node: '>= 10.17.0'}
|
|
||||||
hasBin: true
|
|
||||||
dependencies:
|
|
||||||
debug: 4.3.4
|
|
||||||
get-stream: 5.2.0
|
|
||||||
yauzl: 2.10.0
|
|
||||||
optionalDependencies:
|
|
||||||
'@types/yauzl': 2.9.1
|
|
||||||
transitivePeerDependencies:
|
|
||||||
- supports-color
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/extsprintf/1.3.0:
|
/extsprintf/1.3.0:
|
||||||
resolution: {integrity: sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=}
|
resolution: {integrity: sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=}
|
||||||
engines: {'0': node >=0.6.0}
|
engines: {'0': node >=0.6.0}
|
||||||
|
@ -15630,12 +15592,6 @@ packages:
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- encoding
|
- encoding
|
||||||
|
|
||||||
/fd-slicer/1.1.0:
|
|
||||||
resolution: {integrity: sha1-JcfInLH5B3+IkbvmHY85Dq4lbx4=}
|
|
||||||
dependencies:
|
|
||||||
pend: 1.2.0
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/feed/4.2.2:
|
/feed/4.2.2:
|
||||||
resolution: {integrity: sha512-u5/sxGfiMfZNtJ3OvQpXcvotFpYkL0n9u9mM2vkui2nGo8b4wvDkJ8gAkYqbA8QpGyFCv3RK0Z+Iv+9veCS9bQ==}
|
resolution: {integrity: sha512-u5/sxGfiMfZNtJ3OvQpXcvotFpYkL0n9u9mM2vkui2nGo8b4wvDkJ8gAkYqbA8QpGyFCv3RK0Z+Iv+9veCS9bQ==}
|
||||||
engines: {node: '>=0.4.0'}
|
engines: {node: '>=0.4.0'}
|
||||||
|
@ -15855,6 +15811,18 @@ packages:
|
||||||
resolution: {integrity: sha512-aq6gF1BEKje4a9i9+5jimNFIpq4Q1WiwBToeRK5NvZBd/TRsmW8BsJfOEGkr76TbOyPVD3OVDN910EcUNtRYEA==}
|
resolution: {integrity: sha512-aq6gF1BEKje4a9i9+5jimNFIpq4Q1WiwBToeRK5NvZBd/TRsmW8BsJfOEGkr76TbOyPVD3OVDN910EcUNtRYEA==}
|
||||||
engines: {node: '>=4.0'}
|
engines: {node: '>=4.0'}
|
||||||
|
|
||||||
|
/follow-redirects/1.14.9_debug@4.3.3:
|
||||||
|
resolution: {integrity: sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==}
|
||||||
|
engines: {node: '>=4.0'}
|
||||||
|
peerDependencies:
|
||||||
|
debug: '*'
|
||||||
|
peerDependenciesMeta:
|
||||||
|
debug:
|
||||||
|
optional: true
|
||||||
|
dependencies:
|
||||||
|
debug: 4.3.3
|
||||||
|
dev: false
|
||||||
|
|
||||||
/follow-redirects/1.14.9_debug@4.3.4:
|
/follow-redirects/1.14.9_debug@4.3.4:
|
||||||
resolution: {integrity: sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==}
|
resolution: {integrity: sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==}
|
||||||
engines: {node: '>=4.0'}
|
engines: {node: '>=4.0'}
|
||||||
|
@ -16015,7 +15983,7 @@ packages:
|
||||||
resolution: {integrity: sha512-C5owb14u9eJwizKGdchcDUQeFtlSHHthBk8pbX9Vc1PFZrLombudjDnNns88aYslCyF6IY5SUw3Roz6xShcEIQ==}
|
resolution: {integrity: sha512-C5owb14u9eJwizKGdchcDUQeFtlSHHthBk8pbX9Vc1PFZrLombudjDnNns88aYslCyF6IY5SUw3Roz6xShcEIQ==}
|
||||||
engines: {node: '>=12'}
|
engines: {node: '>=12'}
|
||||||
dependencies:
|
dependencies:
|
||||||
graceful-fs: 4.2.6
|
graceful-fs: 4.2.9
|
||||||
jsonfile: 6.1.0
|
jsonfile: 6.1.0
|
||||||
universalify: 2.0.0
|
universalify: 2.0.0
|
||||||
|
|
||||||
|
@ -18276,16 +18244,6 @@ packages:
|
||||||
- ts-node
|
- ts-node
|
||||||
- utf-8-validate
|
- utf-8-validate
|
||||||
|
|
||||||
/joi/17.4.1:
|
|
||||||
resolution: {integrity: sha512-gDPOwQ5sr+BUxXuPDGrC1pSNcVR/yGGcTI0aCnjYxZEa3za60K/iCQ+OFIkEHWZGVCUcUlXlFKvMmrlmxrG6UQ==}
|
|
||||||
dependencies:
|
|
||||||
'@hapi/hoek': 9.1.0
|
|
||||||
'@hapi/topo': 5.0.0
|
|
||||||
'@sideway/address': 4.1.0
|
|
||||||
'@sideway/formula': 3.0.0
|
|
||||||
'@sideway/pinpoint': 2.0.0
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/joi/17.4.2:
|
/joi/17.4.2:
|
||||||
resolution: {integrity: sha512-Lm56PP+n0+Z2A2rfRvsfWVDXGEWjXxatPopkQ8qQ5mxCEhwHG+Ettgg5o98FFaxilOxozoa14cFhrE/hOzh/Nw==}
|
resolution: {integrity: sha512-Lm56PP+n0+Z2A2rfRvsfWVDXGEWjXxatPopkQ8qQ5mxCEhwHG+Ettgg5o98FFaxilOxozoa14cFhrE/hOzh/Nw==}
|
||||||
dependencies:
|
dependencies:
|
||||||
|
@ -20279,11 +20237,6 @@ packages:
|
||||||
semver: 5.7.1
|
semver: 5.7.1
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/node-fetch/2.6.1:
|
|
||||||
resolution: {integrity: sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==}
|
|
||||||
engines: {node: 4.x || >=6.0.0}
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/node-fetch/2.6.7:
|
/node-fetch/2.6.7:
|
||||||
resolution: {integrity: sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==}
|
resolution: {integrity: sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==}
|
||||||
engines: {node: 4.x || >=6.0.0}
|
engines: {node: 4.x || >=6.0.0}
|
||||||
|
@ -20454,81 +20407,264 @@ packages:
|
||||||
engines: {node: '>=6.0.0'}
|
engines: {node: '>=6.0.0'}
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/npm/7.24.2:
|
/npm/6.14.17:
|
||||||
resolution: {integrity: sha512-120p116CE8VMMZ+hk8IAb1inCPk4Dj3VZw29/n2g6UI77urJKVYb7FZUDW8hY+EBnfsjI/2yrobBgFyzo7YpVQ==}
|
resolution: {integrity: sha512-CxEDn1ydVRPDl4tHrlnq+WevYAhv4GF2AEHzJKQ4prZDZ96IS3Uo6t0Sy6O9kB6XzqkI+J00WfYCqqk0p6IJ1Q==}
|
||||||
engines: {node: '>=10'}
|
engines: {node: 6 >=6.2.0 || 8 || >=9.3.0}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
dev: false
|
dev: false
|
||||||
bundledDependencies:
|
bundledDependencies:
|
||||||
- '@isaacs/string-locale-compare'
|
|
||||||
- '@npmcli/arborist'
|
|
||||||
- '@npmcli/ci-detect'
|
|
||||||
- '@npmcli/config'
|
|
||||||
- '@npmcli/map-workspaces'
|
|
||||||
- '@npmcli/package-json'
|
|
||||||
- '@npmcli/run-script'
|
|
||||||
- abbrev
|
- abbrev
|
||||||
- ansicolors
|
- ansicolors
|
||||||
- ansistyles
|
- ansistyles
|
||||||
|
- aproba
|
||||||
- archy
|
- archy
|
||||||
|
- bin-links
|
||||||
|
- bluebird
|
||||||
|
- byte-size
|
||||||
- cacache
|
- cacache
|
||||||
- chalk
|
- call-limit
|
||||||
- chownr
|
- chownr
|
||||||
|
- ci-info
|
||||||
- cli-columns
|
- cli-columns
|
||||||
- cli-table3
|
- cli-table3
|
||||||
|
- cmd-shim
|
||||||
- columnify
|
- columnify
|
||||||
- fastest-levenshtein
|
- config-chain
|
||||||
|
- debuglog
|
||||||
|
- detect-indent
|
||||||
|
- detect-newline
|
||||||
|
- dezalgo
|
||||||
|
- editor
|
||||||
|
- figgy-pudding
|
||||||
|
- find-npm-prefix
|
||||||
|
- fs-vacuum
|
||||||
|
- fs-write-stream-atomic
|
||||||
|
- gentle-fs
|
||||||
- glob
|
- glob
|
||||||
- graceful-fs
|
- graceful-fs
|
||||||
|
- has-unicode
|
||||||
- hosted-git-info
|
- hosted-git-info
|
||||||
|
- iferr
|
||||||
|
- imurmurhash
|
||||||
|
- infer-owner
|
||||||
|
- inflight
|
||||||
|
- inherits
|
||||||
- ini
|
- ini
|
||||||
- init-package-json
|
- init-package-json
|
||||||
- is-cidr
|
- is-cidr
|
||||||
- json-parse-even-better-errors
|
- json-parse-better-errors
|
||||||
|
- JSONStream
|
||||||
|
- lazy-property
|
||||||
|
- libcipm
|
||||||
|
- libnpm
|
||||||
- libnpmaccess
|
- libnpmaccess
|
||||||
- libnpmdiff
|
|
||||||
- libnpmexec
|
|
||||||
- libnpmfund
|
|
||||||
- libnpmhook
|
- libnpmhook
|
||||||
- libnpmorg
|
- libnpmorg
|
||||||
- libnpmpack
|
|
||||||
- libnpmpublish
|
|
||||||
- libnpmsearch
|
- libnpmsearch
|
||||||
- libnpmteam
|
- libnpmteam
|
||||||
- libnpmversion
|
- libnpx
|
||||||
- make-fetch-happen
|
- lock-verify
|
||||||
- minipass
|
- lockfile
|
||||||
- minipass-pipeline
|
- lodash._baseindexof
|
||||||
|
- lodash._baseuniq
|
||||||
|
- lodash._bindcallback
|
||||||
|
- lodash._cacheindexof
|
||||||
|
- lodash._createcache
|
||||||
|
- lodash._getnative
|
||||||
|
- lodash.clonedeep
|
||||||
|
- lodash.restparam
|
||||||
|
- lodash.union
|
||||||
|
- lodash.uniq
|
||||||
|
- lodash.without
|
||||||
|
- lru-cache
|
||||||
|
- meant
|
||||||
|
- mississippi
|
||||||
- mkdirp
|
- mkdirp
|
||||||
- mkdirp-infer-owner
|
- move-concurrently
|
||||||
- ms
|
|
||||||
- node-gyp
|
- node-gyp
|
||||||
- nopt
|
- nopt
|
||||||
|
- normalize-package-data
|
||||||
- npm-audit-report
|
- npm-audit-report
|
||||||
|
- npm-cache-filename
|
||||||
- npm-install-checks
|
- npm-install-checks
|
||||||
|
- npm-lifecycle
|
||||||
- npm-package-arg
|
- npm-package-arg
|
||||||
|
- npm-packlist
|
||||||
- npm-pick-manifest
|
- npm-pick-manifest
|
||||||
- npm-profile
|
- npm-profile
|
||||||
- npm-registry-fetch
|
- npm-registry-fetch
|
||||||
- npm-user-validate
|
- npm-user-validate
|
||||||
- npmlog
|
- npmlog
|
||||||
|
- once
|
||||||
- opener
|
- opener
|
||||||
|
- osenv
|
||||||
- pacote
|
- pacote
|
||||||
- parse-conflict-json
|
- path-is-inside
|
||||||
|
- promise-inflight
|
||||||
- qrcode-terminal
|
- qrcode-terminal
|
||||||
- read
|
- query-string
|
||||||
|
- qw
|
||||||
|
- read-cmd-shim
|
||||||
|
- read-installed
|
||||||
- read-package-json
|
- read-package-json
|
||||||
- read-package-json-fast
|
- read-package-tree
|
||||||
|
- read
|
||||||
|
- readable-stream
|
||||||
- readdir-scoped-modules
|
- readdir-scoped-modules
|
||||||
|
- request
|
||||||
|
- retry
|
||||||
- rimraf
|
- rimraf
|
||||||
|
- safe-buffer
|
||||||
- semver
|
- semver
|
||||||
|
- sha
|
||||||
|
- slide
|
||||||
|
- sorted-object
|
||||||
|
- sorted-union-stream
|
||||||
- ssri
|
- ssri
|
||||||
|
- stringify-package
|
||||||
- tar
|
- tar
|
||||||
- text-table
|
- text-table
|
||||||
- tiny-relative-date
|
- tiny-relative-date
|
||||||
- treeverse
|
- uid-number
|
||||||
|
- umask
|
||||||
|
- unique-filename
|
||||||
|
- unpipe
|
||||||
|
- update-notifier
|
||||||
|
- uuid
|
||||||
|
- validate-npm-package-license
|
||||||
- validate-npm-package-name
|
- validate-npm-package-name
|
||||||
- which
|
- which
|
||||||
|
- worker-farm
|
||||||
|
- write-file-atomic
|
||||||
|
|
||||||
|
/npm/6.14.5:
|
||||||
|
resolution: {integrity: sha512-CDwa3FJd0XJpKDbWCST484H+mCNjF26dPrU+xnREW+upR0UODjMEfXPl3bxWuAwZIX6c2ASg1plLO7jP8ehWeA==}
|
||||||
|
engines: {node: 6 >=6.2.0 || 8 || >=9.3.0}
|
||||||
|
hasBin: true
|
||||||
|
dev: false
|
||||||
|
bundledDependencies:
|
||||||
|
- abbrev
|
||||||
|
- ansicolors
|
||||||
|
- ansistyles
|
||||||
|
- aproba
|
||||||
|
- archy
|
||||||
|
- bin-links
|
||||||
|
- bluebird
|
||||||
|
- byte-size
|
||||||
|
- cacache
|
||||||
|
- call-limit
|
||||||
|
- chownr
|
||||||
|
- ci-info
|
||||||
|
- cli-columns
|
||||||
|
- cli-table3
|
||||||
|
- cmd-shim
|
||||||
|
- columnify
|
||||||
|
- config-chain
|
||||||
|
- debuglog
|
||||||
|
- detect-indent
|
||||||
|
- detect-newline
|
||||||
|
- dezalgo
|
||||||
|
- editor
|
||||||
|
- figgy-pudding
|
||||||
|
- find-npm-prefix
|
||||||
|
- fs-vacuum
|
||||||
|
- fs-write-stream-atomic
|
||||||
|
- gentle-fs
|
||||||
|
- glob
|
||||||
|
- graceful-fs
|
||||||
|
- has-unicode
|
||||||
|
- hosted-git-info
|
||||||
|
- iferr
|
||||||
|
- imurmurhash
|
||||||
|
- infer-owner
|
||||||
|
- inflight
|
||||||
|
- inherits
|
||||||
|
- ini
|
||||||
|
- init-package-json
|
||||||
|
- is-cidr
|
||||||
|
- json-parse-better-errors
|
||||||
|
- JSONStream
|
||||||
|
- lazy-property
|
||||||
|
- libcipm
|
||||||
|
- libnpm
|
||||||
|
- libnpmaccess
|
||||||
|
- libnpmhook
|
||||||
|
- libnpmorg
|
||||||
|
- libnpmsearch
|
||||||
|
- libnpmteam
|
||||||
|
- libnpx
|
||||||
|
- lock-verify
|
||||||
|
- lockfile
|
||||||
|
- lodash._baseindexof
|
||||||
|
- lodash._baseuniq
|
||||||
|
- lodash._bindcallback
|
||||||
|
- lodash._cacheindexof
|
||||||
|
- lodash._createcache
|
||||||
|
- lodash._getnative
|
||||||
|
- lodash.clonedeep
|
||||||
|
- lodash.restparam
|
||||||
|
- lodash.union
|
||||||
|
- lodash.uniq
|
||||||
|
- lodash.without
|
||||||
|
- lru-cache
|
||||||
|
- meant
|
||||||
|
- mississippi
|
||||||
|
- mkdirp
|
||||||
|
- move-concurrently
|
||||||
|
- node-gyp
|
||||||
|
- nopt
|
||||||
|
- normalize-package-data
|
||||||
|
- npm-audit-report
|
||||||
|
- npm-cache-filename
|
||||||
|
- npm-install-checks
|
||||||
|
- npm-lifecycle
|
||||||
|
- npm-package-arg
|
||||||
|
- npm-packlist
|
||||||
|
- npm-pick-manifest
|
||||||
|
- npm-profile
|
||||||
|
- npm-registry-fetch
|
||||||
|
- npm-user-validate
|
||||||
|
- npmlog
|
||||||
|
- once
|
||||||
|
- opener
|
||||||
|
- osenv
|
||||||
|
- pacote
|
||||||
|
- path-is-inside
|
||||||
|
- promise-inflight
|
||||||
|
- qrcode-terminal
|
||||||
|
- query-string
|
||||||
|
- qw
|
||||||
|
- read-cmd-shim
|
||||||
|
- read-installed
|
||||||
|
- read-package-json
|
||||||
|
- read-package-tree
|
||||||
|
- read
|
||||||
|
- readable-stream
|
||||||
|
- readdir-scoped-modules
|
||||||
|
- request
|
||||||
|
- retry
|
||||||
|
- rimraf
|
||||||
|
- safe-buffer
|
||||||
|
- semver
|
||||||
|
- sha
|
||||||
|
- slide
|
||||||
|
- sorted-object
|
||||||
|
- sorted-union-stream
|
||||||
|
- ssri
|
||||||
|
- stringify-package
|
||||||
|
- tar
|
||||||
|
- text-table
|
||||||
|
- tiny-relative-date
|
||||||
|
- uid-number
|
||||||
|
- umask
|
||||||
|
- unique-filename
|
||||||
|
- unpipe
|
||||||
|
- update-notifier
|
||||||
|
- uuid
|
||||||
|
- validate-npm-package-license
|
||||||
|
- validate-npm-package-name
|
||||||
|
- which
|
||||||
|
- worker-farm
|
||||||
- write-file-atomic
|
- write-file-atomic
|
||||||
|
|
||||||
/npmlog/4.1.2:
|
/npmlog/4.1.2:
|
||||||
|
@ -21071,10 +21207,6 @@ packages:
|
||||||
resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==}
|
resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==}
|
||||||
engines: {node: '>=8'}
|
engines: {node: '>=8'}
|
||||||
|
|
||||||
/pend/1.2.0:
|
|
||||||
resolution: {integrity: sha1-elfrVQpng/kRUzH89GY9XI4AelA=}
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/performance-now/2.1.0:
|
/performance-now/2.1.0:
|
||||||
resolution: {integrity: sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=}
|
resolution: {integrity: sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=}
|
||||||
dev: false
|
dev: false
|
||||||
|
@ -21267,12 +21399,6 @@ packages:
|
||||||
resolution: {integrity: sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA==}
|
resolution: {integrity: sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA==}
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/pnpm/6.27.1:
|
|
||||||
resolution: {integrity: sha512-aW+oDXiMk9mzInmIaRv9v9+FSNkXBs60rVUO6QBpalPja0eO3J5ePSyBxAbLsuhGGbEOpwRq0aNywFq8yIi9HQ==}
|
|
||||||
engines: {node: '>=12.17'}
|
|
||||||
hasBin: true
|
|
||||||
dev: false
|
|
||||||
|
|
||||||
/popper.js/1.16.1-lts:
|
/popper.js/1.16.1-lts:
|
||||||
resolution: {integrity: sha512-Kjw8nKRl1m+VrSFCoVGPph93W/qrSO7ZkqPpTf7F4bk/sqcfWK019dWBUpE/fBOsOQY1dks/Bmcbfn1heM/IsA==}
|
resolution: {integrity: sha512-Kjw8nKRl1m+VrSFCoVGPph93W/qrSO7ZkqPpTf7F4bk/sqcfWK019dWBUpE/fBOsOQY1dks/Bmcbfn1heM/IsA==}
|
||||||
dev: false
|
dev: false
|
||||||
|
@ -22300,11 +22426,6 @@ packages:
|
||||||
engines: {node: '>= 0.6.0'}
|
engines: {node: '>= 0.6.0'}
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/progress/2.0.1:
|
|
||||||
resolution: {integrity: sha512-OE+a6vzqazc+K6LxJrX5UPyKFvGnL5CYmq2jFGNIBWHpc4QyE49/YOumcrpQFJpfejmvRtbJzgO1zPmMCqlbBg==}
|
|
||||||
engines: {node: '>=0.4.0'}
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/progress/2.0.3:
|
/progress/2.0.3:
|
||||||
resolution: {integrity: sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==}
|
resolution: {integrity: sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==}
|
||||||
engines: {node: '>=0.4.0'}
|
engines: {node: '>=0.4.0'}
|
||||||
|
@ -22376,10 +22497,6 @@ packages:
|
||||||
forwarded: 0.2.0
|
forwarded: 0.2.0
|
||||||
ipaddr.js: 1.9.1
|
ipaddr.js: 1.9.1
|
||||||
|
|
||||||
/proxy-from-env/1.1.0:
|
|
||||||
resolution: {integrity: sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==}
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/prr/1.0.1:
|
/prr/1.0.1:
|
||||||
resolution: {integrity: sha1-0/wRS6BplaRexok/SEzrHXj19HY=}
|
resolution: {integrity: sha1-0/wRS6BplaRexok/SEzrHXj19HY=}
|
||||||
|
|
||||||
|
@ -22416,29 +22533,6 @@ packages:
|
||||||
dependencies:
|
dependencies:
|
||||||
escape-goat: 2.1.1
|
escape-goat: 2.1.1
|
||||||
|
|
||||||
/puppeteer/10.4.0:
|
|
||||||
resolution: {integrity: sha512-2cP8mBoqnu5gzAVpbZ0fRaobBWZM8GEUF4I1F6WbgHrKV/rz7SX8PG2wMymZgD0wo0UBlg2FBPNxlF/xlqW6+w==}
|
|
||||||
engines: {node: '>=10.18.1'}
|
|
||||||
requiresBuild: true
|
|
||||||
dependencies:
|
|
||||||
debug: 4.3.1
|
|
||||||
devtools-protocol: 0.0.901419
|
|
||||||
extract-zip: 2.0.1
|
|
||||||
https-proxy-agent: 5.0.0
|
|
||||||
node-fetch: 2.6.1
|
|
||||||
pkg-dir: 4.2.0
|
|
||||||
progress: 2.0.1
|
|
||||||
proxy-from-env: 1.1.0
|
|
||||||
rimraf: 3.0.2
|
|
||||||
tar-fs: 2.0.0
|
|
||||||
unbzip2-stream: 1.3.3
|
|
||||||
ws: 7.4.6
|
|
||||||
transitivePeerDependencies:
|
|
||||||
- bufferutil
|
|
||||||
- supports-color
|
|
||||||
- utf-8-validate
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/pure-color/1.3.0:
|
/pure-color/1.3.0:
|
||||||
resolution: {integrity: sha1-H+Bk+wrIUfDeYTIKi/eWg2Qi8z4=}
|
resolution: {integrity: sha1-H+Bk+wrIUfDeYTIKi/eWg2Qi8z4=}
|
||||||
|
|
||||||
|
@ -23640,12 +23734,6 @@ packages:
|
||||||
dependencies:
|
dependencies:
|
||||||
tslib: 1.14.1
|
tslib: 1.14.1
|
||||||
|
|
||||||
/rxjs/7.3.0:
|
|
||||||
resolution: {integrity: sha512-p2yuGIg9S1epc3vrjKf6iVb3RCaAYjYskkO+jHIaV0IjOPlJop4UnodOoFb2xeNwlguqLYvGw1b1McillYb5Gw==}
|
|
||||||
dependencies:
|
|
||||||
tslib: 2.1.0
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/rxjs/7.4.0:
|
/rxjs/7.4.0:
|
||||||
resolution: {integrity: sha512-7SQDi7xeTMCJpqViXh8gL/lebcwlp3d831F05+9B44A4B0WfsEwUQHR64gsH1kvJ+Ep/J9K2+n1hVl1CsGN23w==}
|
resolution: {integrity: sha512-7SQDi7xeTMCJpqViXh8gL/lebcwlp3d831F05+9B44A4B0WfsEwUQHR64gsH1kvJ+Ep/J9K2+n1hVl1CsGN23w==}
|
||||||
dependencies:
|
dependencies:
|
||||||
|
@ -25121,15 +25209,6 @@ packages:
|
||||||
resolution: {integrity: sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==}
|
resolution: {integrity: sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==}
|
||||||
engines: {node: '>=6'}
|
engines: {node: '>=6'}
|
||||||
|
|
||||||
/tar-fs/2.0.0:
|
|
||||||
resolution: {integrity: sha512-vaY0obB6Om/fso8a8vakQBzwholQ7v5+uy+tF3Ozvxv1KNezmVQAiWtcNmMHFSFPqL3dJA8ha6gdtFbfX9mcxA==}
|
|
||||||
dependencies:
|
|
||||||
chownr: 1.1.4
|
|
||||||
mkdirp: 0.5.5
|
|
||||||
pump: 3.0.0
|
|
||||||
tar-stream: 2.1.4
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/tar-fs/2.1.0:
|
/tar-fs/2.1.0:
|
||||||
resolution: {integrity: sha512-9uW5iDvrIMCVpvasdFHW0wJPez0K4JnMZtsuIeDI7HyMGJNxmDZDOCQROr7lXyS+iL/QMpj07qcjGYTSdRFXUg==}
|
resolution: {integrity: sha512-9uW5iDvrIMCVpvasdFHW0wJPez0K4JnMZtsuIeDI7HyMGJNxmDZDOCQROr7lXyS+iL/QMpj07qcjGYTSdRFXUg==}
|
||||||
dependencies:
|
dependencies:
|
||||||
|
@ -25776,13 +25855,6 @@ packages:
|
||||||
which-boxed-primitive: 1.0.2
|
which-boxed-primitive: 1.0.2
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/unbzip2-stream/1.3.3:
|
|
||||||
resolution: {integrity: sha512-fUlAF7U9Ah1Q6EieQ4x4zLNejrRvDWUYmxXUpN3uziFYCHapjWFaCAnreY9bGgxzaMCFAPPpYNng57CypwJVhg==}
|
|
||||||
dependencies:
|
|
||||||
buffer: 5.7.1
|
|
||||||
through: 2.3.8
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/undefsafe/2.0.5:
|
/undefsafe/2.0.5:
|
||||||
resolution: {integrity: sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==}
|
resolution: {integrity: sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==}
|
||||||
dev: true
|
dev: true
|
||||||
|
@ -26538,17 +26610,19 @@ packages:
|
||||||
rxjs: 6.6.7
|
rxjs: 6.6.7
|
||||||
dev: false
|
dev: false
|
||||||
|
|
||||||
/wait-on/6.0.0:
|
/wait-on/6.0.1_debug@4.3.3:
|
||||||
resolution: {integrity: sha512-tnUJr9p5r+bEYXPUdRseolmz5XqJTTj98JgOsfBn7Oz2dxfE2g3zw1jE+Mo8lopM3j3et/Mq1yW7kKX6qw7RVw==}
|
resolution: {integrity: sha512-zht+KASY3usTY5u2LgaNqn/Cd8MukxLGjdcZxT2ns5QzDmTFc4XoWBgC+C/na+sMRZTuVygQoMYwdcVjHnYIVw==}
|
||||||
engines: {node: '>=10.0.0'}
|
engines: {node: '>=10.0.0'}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
dependencies:
|
dependencies:
|
||||||
axios: 0.21.1
|
axios: 0.25.0_debug@4.3.3
|
||||||
joi: 17.4.1
|
joi: 17.6.0
|
||||||
lodash: 4.17.21
|
lodash: 4.17.21
|
||||||
minimist: 1.2.5
|
minimist: 1.2.6
|
||||||
rxjs: 7.3.0
|
rxjs: 7.5.4
|
||||||
dev: true
|
transitivePeerDependencies:
|
||||||
|
- debug
|
||||||
|
dev: false
|
||||||
|
|
||||||
/wait-on/6.0.1_debug@4.3.4:
|
/wait-on/6.0.1_debug@4.3.4:
|
||||||
resolution: {integrity: sha512-zht+KASY3usTY5u2LgaNqn/Cd8MukxLGjdcZxT2ns5QzDmTFc4XoWBgC+C/na+sMRZTuVygQoMYwdcVjHnYIVw==}
|
resolution: {integrity: sha512-zht+KASY3usTY5u2LgaNqn/Cd8MukxLGjdcZxT2ns5QzDmTFc4XoWBgC+C/na+sMRZTuVygQoMYwdcVjHnYIVw==}
|
||||||
|
@ -27666,20 +27740,6 @@ packages:
|
||||||
yargs-parser: 21.0.0
|
yargs-parser: 21.0.0
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
/yarn/1.22.17:
|
|
||||||
resolution: {integrity: sha512-H0p241BXaH0UN9IeH//RT82tl5PfNraVpSpEoW+ET7lmopNC61eZ+A+IDvU8FM6Go5vx162SncDL8J1ZjRBriQ==}
|
|
||||||
engines: {node: '>=4.0.0'}
|
|
||||||
hasBin: true
|
|
||||||
requiresBuild: true
|
|
||||||
dev: false
|
|
||||||
|
|
||||||
/yauzl/2.10.0:
|
|
||||||
resolution: {integrity: sha1-x+sXyT4RLLEIb6bY5R+wZnt5pfk=}
|
|
||||||
dependencies:
|
|
||||||
buffer-crc32: 0.2.13
|
|
||||||
fd-slicer: 1.1.0
|
|
||||||
dev: true
|
|
||||||
|
|
||||||
/yn/3.1.1:
|
/yn/3.1.1:
|
||||||
resolution: {integrity: sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==}
|
resolution: {integrity: sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==}
|
||||||
engines: {node: '>=6'}
|
engines: {node: '>=6'}
|
||||||
|
|
|
@ -10,5 +10,5 @@ packages:
|
||||||
- packages/plugins/memory
|
- packages/plugins/memory
|
||||||
- packages/plugins/local-storage
|
- packages/plugins/local-storage
|
||||||
- website
|
- website
|
||||||
- test/e2e-*
|
- test/cli/*
|
||||||
- test/helpers
|
- test/helpers
|
||||||
|
|
3
test/cli/cli-commons/.babelrc
Normal file
3
test/cli/cli-commons/.babelrc
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"extends": "../../../.babelrc"
|
||||||
|
}
|
27
test/cli/cli-commons/package.json
Normal file
27
test/cli/cli-commons/package.json
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
{
|
||||||
|
"private": true,
|
||||||
|
"name": "@verdaccio/test-cli-commons",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"main": "./build/index.js",
|
||||||
|
"types": "./build/index.d.ts",
|
||||||
|
"dependencies": {
|
||||||
|
"debug": "4.3.3",
|
||||||
|
"npm": "6.14.5",
|
||||||
|
"get-port": "5.1.1",
|
||||||
|
"wait-on": "^6.0.0",
|
||||||
|
"fs-extra": "10.0.0",
|
||||||
|
"semver": "7.3.5",
|
||||||
|
"got": "11.8.3",
|
||||||
|
"verdaccio": "workspace:6.0.0-6-next.41",
|
||||||
|
"@verdaccio/core": "workspace:6.0.0-6-next.5",
|
||||||
|
"@verdaccio/config": "workspace:6.0.0-6-next.14",
|
||||||
|
"@verdaccio/test-helper": "workspace:1.1.0-6-next.1"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"test": "jest",
|
||||||
|
"type-check": "tsc --noEmit -p tsconfig.build.json",
|
||||||
|
"build:types": "tsc --emitDeclarationOnly -p tsconfig.build.json",
|
||||||
|
"build:js": "babel src/ --out-dir build/ --copy-files --extensions \".ts,.tsx\" --source-maps",
|
||||||
|
"build": "pnpm run build:js && pnpm run build:types"
|
||||||
|
}
|
||||||
|
}
|
4
test/cli/cli-commons/src/index.ts
Normal file
4
test/cli/cli-commons/src/index.ts
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
export { getDefaultConfig } from '@verdaccio/config';
|
||||||
|
export { initialSetup } from './registry';
|
||||||
|
export { addNpmPrefix, addYarnPrefix, addRegistry } from './utils';
|
||||||
|
export { exec, ExecOutput } from './process';
|
58
test/cli/cli-commons/src/process.ts
Normal file
58
test/cli/cli-commons/src/process.ts
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
import { spawn } from 'child_process';
|
||||||
|
import { SpawnOptions } from 'child_process';
|
||||||
|
import buildDebug from 'debug';
|
||||||
|
import { createInterface } from 'readline';
|
||||||
|
|
||||||
|
const debug = buildDebug('verdaccio:e2e:process');
|
||||||
|
|
||||||
|
export type ExecOutput = {
|
||||||
|
stdout: string;
|
||||||
|
stderr: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
export async function exec(options: SpawnOptions, cmd, args): Promise<ExecOutput> {
|
||||||
|
debug('start _exec %o %o %o', options, cmd, args);
|
||||||
|
let stdout = '';
|
||||||
|
let stderr;
|
||||||
|
const env = options.env;
|
||||||
|
debug(`Running \`${cmd} ${args.join(' ')}`);
|
||||||
|
debug(`CWD: %o`, options.cwd);
|
||||||
|
debug(`ENV: ${JSON.stringify(env)}`);
|
||||||
|
const spawnOptions = {
|
||||||
|
cwd: options.cwd,
|
||||||
|
stdio: options.stdio || 'pipe',
|
||||||
|
...(env ? { env } : {}),
|
||||||
|
};
|
||||||
|
|
||||||
|
if (process.platform.startsWith('win')) {
|
||||||
|
args.unshift('/c', cmd);
|
||||||
|
cmd = 'cmd.exe';
|
||||||
|
spawnOptions['stdio'] = 'pipe';
|
||||||
|
}
|
||||||
|
|
||||||
|
const childProcess = spawn(cmd, args, spawnOptions);
|
||||||
|
// @ts-ignore
|
||||||
|
const rl = createInterface({ input: childProcess.stdout });
|
||||||
|
|
||||||
|
rl.on('line', function (line) {
|
||||||
|
stdout += line;
|
||||||
|
});
|
||||||
|
|
||||||
|
const err = new Error(`Running "${cmd} ${args.join(' ')}" returned error code `);
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
childProcess.on('exit', (error) => {
|
||||||
|
if (!error) {
|
||||||
|
resolve({ stdout, stderr });
|
||||||
|
} else {
|
||||||
|
err.message += `${error}...\n\nSTDOUT:\n${stdout}\n\nSTDERR:\n${stderr}\n`;
|
||||||
|
return reject({ stdout, stderr: err });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export function silentNpm(...args): Promise<ExecOutput> {
|
||||||
|
debug('run silent npm %o', args);
|
||||||
|
// @ts-ignore
|
||||||
|
return exec({ silent: true }, 'npm', args);
|
||||||
|
}
|
20
test/cli/cli-commons/src/registry.ts
Normal file
20
test/cli/cli-commons/src/registry.ts
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
/* eslint-disable prefer-promise-reject-errors */
|
||||||
|
import buildDebug from 'debug';
|
||||||
|
import { Registry } from 'verdaccio';
|
||||||
|
|
||||||
|
import { getDefaultConfig } from '@verdaccio/config';
|
||||||
|
|
||||||
|
const debug = buildDebug('verdaccio:e2e:registry-utils');
|
||||||
|
|
||||||
|
export type Setup = {
|
||||||
|
registry: Registry;
|
||||||
|
tempFolder: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
export async function initialSetup(): Promise<Setup> {
|
||||||
|
const { configPath, tempFolder } = await Registry.fromConfigToPath(getDefaultConfig());
|
||||||
|
debug(`configPath %o`, configPath);
|
||||||
|
debug(`tempFolder %o`, tempFolder);
|
||||||
|
const registry = new Registry(configPath);
|
||||||
|
return { registry, tempFolder };
|
||||||
|
}
|
45
test/cli/cli-commons/src/utils.ts
Normal file
45
test/cli/cli-commons/src/utils.ts
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
import fs from 'fs-extra';
|
||||||
|
import { join } from 'path';
|
||||||
|
|
||||||
|
import { fileUtils } from '@verdaccio/core';
|
||||||
|
|
||||||
|
export function createProject(projectName: string) {
|
||||||
|
// @ts-ignore
|
||||||
|
const tempRootFolder = global.__namespace.getItem('dir-suite-root');
|
||||||
|
const verdaccioInstall = join(tempRootFolder, projectName);
|
||||||
|
fs.mkdirSync(verdaccioInstall);
|
||||||
|
|
||||||
|
return verdaccioInstall;
|
||||||
|
}
|
||||||
|
export function copyConfigFile(rootFolder, configTemplate): string {
|
||||||
|
const configPath = join(rootFolder, 'config.yaml');
|
||||||
|
copyTo(join(__dirname, configTemplate), configPath);
|
||||||
|
|
||||||
|
return configPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function createTempFolder(prefix: string) {
|
||||||
|
return fileUtils.createTempFolder(prefix);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function copyTo(from, to) {
|
||||||
|
fs.copyFileSync(from, to);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function cleanUpTemp(tmpFolder) {
|
||||||
|
fs.rmdirSync(tmpFolder, { recursive: true });
|
||||||
|
}
|
||||||
|
|
||||||
|
export function addRegistry(registryUrl) {
|
||||||
|
return ['--registry', registryUrl];
|
||||||
|
}
|
||||||
|
|
||||||
|
export function addNpmPrefix(installFolder) {
|
||||||
|
return ['--prefix', installFolder];
|
||||||
|
}
|
||||||
|
|
||||||
|
export function addYarnPrefix(installFolder) {
|
||||||
|
// info regarding cwd flag
|
||||||
|
// https://github.com/yarnpkg/yarn/pull/4174
|
||||||
|
return ['--cwd', installFolder];
|
||||||
|
}
|
5
test/cli/cli-commons/src/web.ts
Normal file
5
test/cli/cli-commons/src/web.ts
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
import got from 'got';
|
||||||
|
|
||||||
|
export function callRegistry(url: string): Promise<string> {
|
||||||
|
return got.get(url, { headers: { Accept: 'application/json' } }).json();
|
||||||
|
}
|
9
test/cli/cli-commons/tsconfig.build.json
Normal file
9
test/cli/cli-commons/tsconfig.build.json
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
{
|
||||||
|
"extends": "../../../tsconfig.base.json",
|
||||||
|
"compilerOptions": {
|
||||||
|
"rootDir": "./src",
|
||||||
|
"outDir": "./build"
|
||||||
|
},
|
||||||
|
"include": ["src/**/*"],
|
||||||
|
"exclude": ["src/**/*.test.ts"]
|
||||||
|
}
|
21
test/cli/cli-commons/tsconfig.json
Normal file
21
test/cli/cli-commons/tsconfig.json
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
{
|
||||||
|
"extends": "../../../tsconfig.reference.json",
|
||||||
|
"compilerOptions": {
|
||||||
|
"rootDir": "./src",
|
||||||
|
"outDir": "./build"
|
||||||
|
},
|
||||||
|
"references": [
|
||||||
|
{
|
||||||
|
"path": "../../../packages/core/core"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "../../../packages/verdaccio"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "../../../packages/config"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "../../../packages/tools/helpers"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
3
test/cli/e2e-npm6/.babelrc
Normal file
3
test/cli/e2e-npm6/.babelrc
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"extends": "../../../.babelrc"
|
||||||
|
}
|
7
test/cli/e2e-npm6/.eslintrc
Normal file
7
test/cli/e2e-npm6/.eslintrc
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{
|
||||||
|
"rules": {
|
||||||
|
"no-console": 0,
|
||||||
|
"@typescript-eslint/no-var-requires": 0,
|
||||||
|
"@typescript-eslint/explicit-member-accessibility": 0
|
||||||
|
}
|
||||||
|
}
|
30
test/cli/e2e-npm6/info.spec.ts
Normal file
30
test/cli/e2e-npm6/info.spec.ts
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
import { addRegistry, initialSetup } from '@verdaccio/test-cli-commons';
|
||||||
|
|
||||||
|
import { npm } from './utils';
|
||||||
|
|
||||||
|
describe('install a package', () => {
|
||||||
|
jest.setTimeout(10000);
|
||||||
|
let registry;
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
const setup = await initialSetup();
|
||||||
|
registry = setup.registry;
|
||||||
|
await registry.init();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should run npm info json body', async () => {
|
||||||
|
const resp = await npm(
|
||||||
|
'info',
|
||||||
|
'verdaccio',
|
||||||
|
'--json',
|
||||||
|
...addRegistry(registry.getRegistryUrl())
|
||||||
|
);
|
||||||
|
const parsedBody = JSON.parse(resp.stdout as string);
|
||||||
|
expect(parsedBody.name).toEqual('verdaccio');
|
||||||
|
expect(parsedBody.dependencies).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
registry.stop();
|
||||||
|
});
|
||||||
|
});
|
14
test/cli/e2e-npm6/jest.config.js
Normal file
14
test/cli/e2e-npm6/jest.config.js
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
const { defaults } = require('jest-config');
|
||||||
|
const config = require('../../../jest/config');
|
||||||
|
|
||||||
|
module.exports = Object.assign({}, config, {
|
||||||
|
name: 'verdaccio-e2e-cli-jest',
|
||||||
|
// verbose: true,
|
||||||
|
// collectCoverage: false,
|
||||||
|
moduleFileExtensions: [...defaults.moduleFileExtensions, 'ts'],
|
||||||
|
// testEnvironment: './env_babel.js',
|
||||||
|
// globalSetup: './env_setup.js',
|
||||||
|
// globalTeardown: './env_teardown.js',
|
||||||
|
// testRegex: '(/test/e2e.*\\.spec)\\.ts',
|
||||||
|
testRegex: '(/test/*.*.spec)\\.ts',
|
||||||
|
});
|
12
test/cli/e2e-npm6/package.json
Normal file
12
test/cli/e2e-npm6/package.json
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
"private": true,
|
||||||
|
"name": "@verdaccio/e2e-cli-npm6",
|
||||||
|
"version": "2.0.0-6-next.1",
|
||||||
|
"dependencies": {
|
||||||
|
"@verdaccio/test-cli-commons": "workspace:1.0.0",
|
||||||
|
"npm": "latest-6"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"test": "jest"
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,5 +3,10 @@
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"rootDir": "./src",
|
"rootDir": "./src",
|
||||||
"outDir": "./build"
|
"outDir": "./build"
|
||||||
|
},
|
||||||
|
"references": [
|
||||||
|
{
|
||||||
|
"path": "../cli-commons"
|
||||||
}
|
}
|
||||||
|
]
|
||||||
}
|
}
|
12
test/cli/e2e-npm6/utils.ts
Normal file
12
test/cli/e2e-npm6/utils.ts
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
import { join } from 'path';
|
||||||
|
|
||||||
|
import { exec } from '@verdaccio/test-cli-commons';
|
||||||
|
|
||||||
|
export function getCommand() {
|
||||||
|
return join(__dirname, './node_modules/.bin/npm');
|
||||||
|
}
|
||||||
|
|
||||||
|
export function npm(...args: string[]) {
|
||||||
|
console.log('-getCommand()', getCommand());
|
||||||
|
return exec({}, getCommand(), args);
|
||||||
|
}
|
|
@ -1,3 +0,0 @@
|
||||||
{
|
|
||||||
"extends": "../../.babelrc"
|
|
||||||
}
|
|
|
@ -1,4 +0,0 @@
|
||||||
require('@babel/register')({
|
|
||||||
extensions: ['.ts', '.js'],
|
|
||||||
});
|
|
||||||
module.exports = require('./setup/test_environment');
|
|
|
@ -1,4 +0,0 @@
|
||||||
require('@babel/register')({
|
|
||||||
extensions: ['.ts', '.js'],
|
|
||||||
});
|
|
||||||
module.exports = require('./setup/setup');
|
|
|
@ -1,4 +0,0 @@
|
||||||
require('@babel/register')({
|
|
||||||
extensions: ['.ts', '.js'],
|
|
||||||
});
|
|
||||||
module.exports = require('./setup/teardown');
|
|
|
@ -1,14 +0,0 @@
|
||||||
const { defaults } = require('jest-config');
|
|
||||||
const config = require('../../jest/config');
|
|
||||||
|
|
||||||
module.exports = Object.assign({}, config, {
|
|
||||||
name: 'verdaccio-e2e-cli-jest',
|
|
||||||
verbose: true,
|
|
||||||
collectCoverage: false,
|
|
||||||
moduleFileExtensions: [...defaults.moduleFileExtensions, 'ts'],
|
|
||||||
testEnvironment: './env_babel.js',
|
|
||||||
globalSetup: './env_setup.js',
|
|
||||||
globalTeardown: './env_teardown.js',
|
|
||||||
// testRegex: '(/test/e2e.*\\.spec)\\.ts',
|
|
||||||
testRegex: '(/test_bk/*.*.spec)\\.ts',
|
|
||||||
});
|
|
|
@ -1,21 +0,0 @@
|
||||||
{
|
|
||||||
"private": true,
|
|
||||||
"name": "@verdaccio/e2e-cli",
|
|
||||||
"version": "2.0.0-6-next.1",
|
|
||||||
"dependencies": {
|
|
||||||
"debug": "4.3.3",
|
|
||||||
"npm": "7.24.2",
|
|
||||||
"pnpm": "6.27.1",
|
|
||||||
"request": "2.88.0",
|
|
||||||
"yarn": "1.22.17"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"get-port": "5.1.1",
|
|
||||||
"wait-on": "^6.0.0",
|
|
||||||
"fs-extra": "10.0.0",
|
|
||||||
"semver": "7.3.5"
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"test": "jest --config jest.config.e2e.cli.js"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,68 +0,0 @@
|
||||||
import { spawn } from 'child_process';
|
|
||||||
import buildDebug from 'debug';
|
|
||||||
import fs from 'fs';
|
|
||||||
import { yellow } from 'kleur';
|
|
||||||
import os from 'os';
|
|
||||||
import path from 'path';
|
|
||||||
|
|
||||||
import * as __global from '../utils/global.js';
|
|
||||||
import { pnpmGlobal } from '../utils/process';
|
|
||||||
import { SETUP_VERDACCIO_PORT } from '../utils/utils';
|
|
||||||
|
|
||||||
// import { waitOnRegistry } from '../utils/registry';
|
|
||||||
|
|
||||||
const debug = buildDebug('verdaccio:e2e:setup');
|
|
||||||
|
|
||||||
module.exports = async () => {
|
|
||||||
const tempRoot = fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'verdaccio-cli-e2e-'));
|
|
||||||
debug('dirname folder %o', __dirname);
|
|
||||||
debug('temporary folder %o', tempRoot);
|
|
||||||
// @ts-ignore
|
|
||||||
__global.addItem('dir-root', tempRoot);
|
|
||||||
debug(yellow(`Add temp root folder: ${tempRoot}`));
|
|
||||||
const destinationConfigFile = path.join(tempRoot, 'verdaccio.yaml');
|
|
||||||
debug('destination config file %o', destinationConfigFile);
|
|
||||||
fs.copyFileSync(
|
|
||||||
path.join(__dirname, '../config/_bootstrap_verdaccio.yaml'),
|
|
||||||
destinationConfigFile
|
|
||||||
);
|
|
||||||
// @ts-ignore
|
|
||||||
global.__namespace = __global;
|
|
||||||
debug(`current directory %o`, process.cwd());
|
|
||||||
const verdaccioPath = path.normalize(
|
|
||||||
path.join(process.cwd(), '../../packages/verdaccio/debug/bootstrap.js')
|
|
||||||
);
|
|
||||||
debug(process.env.DEBUG);
|
|
||||||
debug('verdaccio path %o', verdaccioPath);
|
|
||||||
const childProcess = spawn(
|
|
||||||
'node',
|
|
||||||
[verdaccioPath, '-c', './verdaccio.yaml', '-l', SETUP_VERDACCIO_PORT],
|
|
||||||
// @ts-ignore
|
|
||||||
{
|
|
||||||
cwd: tempRoot,
|
|
||||||
env: {
|
|
||||||
...process.env,
|
|
||||||
},
|
|
||||||
stdio: 'ignore',
|
|
||||||
}
|
|
||||||
);
|
|
||||||
// @ts-ignore
|
|
||||||
global.registryProcess = childProcess;
|
|
||||||
// await waitOnRegistry(SETUP_VERDACCIO_PORT);
|
|
||||||
// publish current build version on local registry
|
|
||||||
const rootFolder = path.normalize(path.join(process.cwd(), '../../'));
|
|
||||||
// install the local changes to verdaccio
|
|
||||||
// the published package will be installed from every suite
|
|
||||||
await pnpmGlobal(
|
|
||||||
rootFolder,
|
|
||||||
'publish',
|
|
||||||
'--filter',
|
|
||||||
' ./packages',
|
|
||||||
'--access',
|
|
||||||
'public',
|
|
||||||
'--git-checks',
|
|
||||||
'false',
|
|
||||||
'--registry',
|
|
||||||
`http://localhost:${SETUP_VERDACCIO_PORT}`
|
|
||||||
);
|
|
||||||
};
|
|
|
@ -1,9 +0,0 @@
|
||||||
import buildDebug from 'debug';
|
|
||||||
|
|
||||||
const debug = buildDebug('verdaccio:e2e:teardown');
|
|
||||||
|
|
||||||
module.exports = async function () {
|
|
||||||
debug('e2e teardown kill server');
|
|
||||||
// @ts-ignore
|
|
||||||
global.registryProcess.kill();
|
|
||||||
};
|
|
|
@ -1,38 +0,0 @@
|
||||||
import buildDebug from 'debug';
|
|
||||||
import NodeEnvironment from 'jest-environment-node';
|
|
||||||
import os from 'os';
|
|
||||||
import path from 'path';
|
|
||||||
|
|
||||||
const fs = require('fs');
|
|
||||||
|
|
||||||
const __global = require('../utils/global');
|
|
||||||
|
|
||||||
const debug = buildDebug('verdaccio:e2e:env');
|
|
||||||
|
|
||||||
class E2ECliTestEnvironment extends NodeEnvironment {
|
|
||||||
constructor(config) {
|
|
||||||
super(config);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async setup() {
|
|
||||||
// create an unique suite location peer test to avoid conflicts
|
|
||||||
const tempRoot = fs.mkdtempSync(
|
|
||||||
path.join(fs.realpathSync(os.tmpdir()), 'verdaccio-suite-test-')
|
|
||||||
);
|
|
||||||
debug('suite temporary folder %o', tempRoot);
|
|
||||||
__global.addItem('dir-suite-root', tempRoot);
|
|
||||||
// @ts-ignore
|
|
||||||
this.global.__namespace = __global;
|
|
||||||
debug(`current directory: ${process.cwd()}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
async teardown() {
|
|
||||||
// TODO: clean folder
|
|
||||||
}
|
|
||||||
|
|
||||||
public runScript(script): any {
|
|
||||||
return super.runScript(script);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default E2ECliTestEnvironment;
|
|
|
@ -1,18 +0,0 @@
|
||||||
import buildDebug from 'debug';
|
|
||||||
|
|
||||||
const namespace = Object.create(null);
|
|
||||||
|
|
||||||
const debug = buildDebug('verdaccio:e2e:global');
|
|
||||||
|
|
||||||
exports.addItem = function (name, value) {
|
|
||||||
namespace[name] = value;
|
|
||||||
};
|
|
||||||
|
|
||||||
exports.getItem = function (name) {
|
|
||||||
debug('get-item %o:%o', name, namespace);
|
|
||||||
if (!(name in namespace)) {
|
|
||||||
throw new Error('The item '.concat(name, ' does exist in the namespace'));
|
|
||||||
}
|
|
||||||
|
|
||||||
return namespace[name];
|
|
||||||
};
|
|
|
@ -1,102 +0,0 @@
|
||||||
import { spawn } from 'child_process';
|
|
||||||
import { SpawnOptions } from 'child_process';
|
|
||||||
import buildDebug from 'debug';
|
|
||||||
import readline from 'readline';
|
|
||||||
|
|
||||||
const debug = buildDebug('verdaccio:e2e:process');
|
|
||||||
|
|
||||||
export type ExecOutput = {
|
|
||||||
stdout: string;
|
|
||||||
stderr: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
export async function _exec(options: SpawnOptions, cmd, args): Promise<ExecOutput> {
|
|
||||||
debug('start _exec %o %o %o', options, cmd, args);
|
|
||||||
let stdout = '';
|
|
||||||
let stderr;
|
|
||||||
const env = options.env;
|
|
||||||
debug(`Running \`${cmd} ${args.join(' ')}`);
|
|
||||||
debug(`CWD: %o`, options.cwd);
|
|
||||||
debug(`ENV: ${JSON.stringify(env)}`);
|
|
||||||
const spawnOptions = {
|
|
||||||
cwd: options.cwd,
|
|
||||||
stdio: options.stdio || 'pipe',
|
|
||||||
...(env ? { env } : {}),
|
|
||||||
};
|
|
||||||
|
|
||||||
if (process.platform.startsWith('win')) {
|
|
||||||
args.unshift('/c', cmd);
|
|
||||||
cmd = 'cmd.exe';
|
|
||||||
spawnOptions['stdio'] = 'pipe';
|
|
||||||
}
|
|
||||||
|
|
||||||
const childProcess = spawn(cmd, args, spawnOptions);
|
|
||||||
const rl = readline.createInterface({ input: childProcess.stdout });
|
|
||||||
|
|
||||||
rl.on('line', function (line) {
|
|
||||||
stdout += line;
|
|
||||||
});
|
|
||||||
|
|
||||||
const err = new Error(`Running "${cmd} ${args.join(' ')}" returned error code `);
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
childProcess.on('exit', (error) => {
|
|
||||||
if (!error) {
|
|
||||||
resolve({ stdout, stderr });
|
|
||||||
} else {
|
|
||||||
err.message += `${error}...\n\nSTDOUT:\n${stdout}\n\nSTDERR:\n${stderr}\n`;
|
|
||||||
reject({ stdout, stderr: err });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// export function execAndWaitForOutputToMatch(
|
|
||||||
// cmd: string,
|
|
||||||
// args: string[],
|
|
||||||
// match: RegExp,
|
|
||||||
// spawnOptions: SpawnOptions = {}
|
|
||||||
// ): any {
|
|
||||||
// return _exec({ waitForMatch: match, ...spawnOptions, silence: true }, cmd, args);
|
|
||||||
// }
|
|
||||||
|
|
||||||
export function pnpmGlobal(rootFolder, ...args) {
|
|
||||||
const pnpmCmd = require.resolve('pnpm');
|
|
||||||
debug('pnpmCommand %o', pnpmCmd);
|
|
||||||
debug('run pnpm on %o', rootFolder);
|
|
||||||
return _exec(
|
|
||||||
{
|
|
||||||
cwd: rootFolder,
|
|
||||||
},
|
|
||||||
process.execPath,
|
|
||||||
[pnpmCmd, ...args]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function npm(...args): Promise<ExecOutput> {
|
|
||||||
return _exec({}, 'npm', args);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function yarn(...args): Promise<ExecOutput> {
|
|
||||||
return _exec({}, 'yarn', args);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function pnpm(...args): Promise<ExecOutput> {
|
|
||||||
return _exec({}, 'pnpm', args);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function pnpmWithCwd(cwd, ...args): Promise<ExecOutput> {
|
|
||||||
return _exec({ cwd }, 'pnpm', args);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function yarnWithCwd(cwd, ...args): Promise<ExecOutput> {
|
|
||||||
return _exec({ cwd }, 'yarn', args);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function nodeCwd(cwd, ...args): Promise<ExecOutput> {
|
|
||||||
return _exec({ cwd }, 'yarn', args);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function silentNpm(...args): Promise<ExecOutput> {
|
|
||||||
debug('run silent npm %o', args);
|
|
||||||
return _exec({ silent: true }, 'npm', args);
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
import { addNpmPrefix } from './registry';
|
|
||||||
|
|
||||||
describe('registry utils', function () {
|
|
||||||
test('prefix', () => {
|
|
||||||
expect([...addNpmPrefix('foo')]).toEqual('');
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,149 +0,0 @@
|
||||||
/* eslint-disable prefer-promise-reject-errors */
|
|
||||||
import { ChildProcess, fork } from 'child_process';
|
|
||||||
import buildDebug from 'debug';
|
|
||||||
import fs from 'fs';
|
|
||||||
import path from 'path';
|
|
||||||
import waitOn from 'wait-on';
|
|
||||||
|
|
||||||
import { silentNpm } from './process';
|
|
||||||
|
|
||||||
const debug = buildDebug('verdaccio:e2e:registry-utils');
|
|
||||||
|
|
||||||
export function createInstallationFolder(tempRootFolder) {
|
|
||||||
const verdaccioInstall = path.join(tempRootFolder, 'verdaccio-root-install');
|
|
||||||
fs.mkdirSync(verdaccioInstall);
|
|
||||||
return verdaccioInstall;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function addNpmPrefix(installFolder) {
|
|
||||||
return ['--prefix', installFolder];
|
|
||||||
}
|
|
||||||
|
|
||||||
export function addYarnPrefix(installFolder) {
|
|
||||||
// info regarding cwd flag
|
|
||||||
// https://github.com/yarnpkg/yarn/pull/4174
|
|
||||||
return ['--cwd', installFolder];
|
|
||||||
}
|
|
||||||
|
|
||||||
export function addRegistry(port) {
|
|
||||||
return ['--registry', `http://localhost:${port}`];
|
|
||||||
}
|
|
||||||
|
|
||||||
export function installVerdaccio(verdaccioInstall) {
|
|
||||||
debug('installing verdaccio from internal registry');
|
|
||||||
return silentNpm(
|
|
||||||
'install',
|
|
||||||
...addNpmPrefix(verdaccioInstall),
|
|
||||||
'verdaccio',
|
|
||||||
...addRegistry('6001'),
|
|
||||||
// lock file is not useful for this purpose
|
|
||||||
'--no-package-lock',
|
|
||||||
'-no-shrinkwrap',
|
|
||||||
// reduce external calls and potential test failures
|
|
||||||
'--no-audit'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
export type Setup = {
|
|
||||||
child: ChildProcess;
|
|
||||||
install: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
export async function initialSetup(port: string | number): Promise<Setup> {
|
|
||||||
// temp folder created on test_environment.ts
|
|
||||||
// @ts-ignore
|
|
||||||
const tempRootFolder = global.__namespace.getItem('dir-suite-root');
|
|
||||||
debug('initial setup on %o and port %o', tempRootFolder, port);
|
|
||||||
// create temporary installation folder
|
|
||||||
const verdaccioInstall = createInstallationFolder(tempRootFolder);
|
|
||||||
debug('install folder %o', verdaccioInstall);
|
|
||||||
// create a file path for the future the configuration file
|
|
||||||
const verdaccioConfigPathOnInstallLocation = path.join(tempRootFolder, 'verdaccio.yaml');
|
|
||||||
debug('config file location %o', verdaccioConfigPathOnInstallLocation);
|
|
||||||
// install a global verdaccio
|
|
||||||
debug('install verdaccio start');
|
|
||||||
await installVerdaccio(verdaccioInstall);
|
|
||||||
debug('install verdaccio finish');
|
|
||||||
// copy the original config verdaccio file
|
|
||||||
fs.copyFileSync(
|
|
||||||
path.join(__dirname, '../../../packages/config/src/conf/default.yaml'),
|
|
||||||
verdaccioConfigPathOnInstallLocation
|
|
||||||
);
|
|
||||||
// location of verdaccio binary installed in the previous step
|
|
||||||
const pathVerdaccioModule = require.resolve('verdaccio/bin/verdaccio', {
|
|
||||||
paths: [verdaccioInstall],
|
|
||||||
});
|
|
||||||
debug('path verdaccio module %o', pathVerdaccioModule);
|
|
||||||
// spawn the registry
|
|
||||||
const processChild = await forkRegistry(
|
|
||||||
pathVerdaccioModule,
|
|
||||||
['-c', verdaccioConfigPathOnInstallLocation, '-l', port],
|
|
||||||
{
|
|
||||||
cwd: verdaccioInstall,
|
|
||||||
silent: false,
|
|
||||||
},
|
|
||||||
port
|
|
||||||
);
|
|
||||||
|
|
||||||
return {
|
|
||||||
child: processChild,
|
|
||||||
install: verdaccioInstall,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
export function getVerdaccioPath() {
|
|
||||||
const verdaccioPath = path.normalize(
|
|
||||||
path.join(process.cwd(), '../../packages/verdaccio/debug/bootstrap.js')
|
|
||||||
);
|
|
||||||
|
|
||||||
return verdaccioPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function forkRegistry(
|
|
||||||
verdaccioPath: string,
|
|
||||||
args: string[],
|
|
||||||
childOptions,
|
|
||||||
port
|
|
||||||
): Promise<ChildProcess> {
|
|
||||||
debug('spawning registry for %o in port %o', verdaccioPath, port);
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
let _childOptions = { silent: true, ...childOptions };
|
|
||||||
debug('options %o', _childOptions);
|
|
||||||
debug('fork path %o', verdaccioPath);
|
|
||||||
debug('args %o', args);
|
|
||||||
const childFork = fork(verdaccioPath, args, _childOptions);
|
|
||||||
|
|
||||||
childFork.on('message', (msg) => {
|
|
||||||
if ('verdaccio_started' in msg) {
|
|
||||||
debug('spawning registry [started] in port %o', port);
|
|
||||||
resolve(childFork);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
childFork.on('error', (err) => {
|
|
||||||
debug('error %o', err);
|
|
||||||
reject([err]);
|
|
||||||
});
|
|
||||||
childFork.on('disconnect', (err) => {
|
|
||||||
debug('disconnect %o', err);
|
|
||||||
reject([err]);
|
|
||||||
});
|
|
||||||
childFork.on('exit', (err) => {
|
|
||||||
debug('exit %o', err);
|
|
||||||
reject([err]);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
export const waitOnRegistry = async (port, timeout = 5000) => {
|
|
||||||
debug('waiting on registry ...');
|
|
||||||
await waitOn({
|
|
||||||
timeout,
|
|
||||||
resources: [`http://localhost:${port}/-/ping`],
|
|
||||||
validateStatus: function (status) {
|
|
||||||
debug('wating status %s', status);
|
|
||||||
return status >= 200 && status < 300; // default if not provided
|
|
||||||
},
|
|
||||||
});
|
|
||||||
debug(`registry detected on por ${port}`);
|
|
||||||
};
|
|
|
@ -1,35 +0,0 @@
|
||||||
import fs from 'fs-extra';
|
|
||||||
import os from 'os';
|
|
||||||
import path from 'path';
|
|
||||||
|
|
||||||
export function createProject(projectName: string) {
|
|
||||||
// @ts-ignore
|
|
||||||
const tempRootFolder = global.__namespace.getItem('dir-suite-root');
|
|
||||||
const verdaccioInstall = path.join(tempRootFolder, projectName);
|
|
||||||
fs.mkdirSync(verdaccioInstall);
|
|
||||||
|
|
||||||
return verdaccioInstall;
|
|
||||||
}
|
|
||||||
export function copyConfigFile(rootFolder, configTemplate): string {
|
|
||||||
const configPath = path.join(rootFolder, 'verdaccio.yaml');
|
|
||||||
copyTo(path.join(__dirname, configTemplate), configPath);
|
|
||||||
|
|
||||||
return configPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated use @verdaccio/core:createTempFolder async function instead
|
|
||||||
*/
|
|
||||||
export function createTempFolder(prefix: string) {
|
|
||||||
return fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), prefix));
|
|
||||||
}
|
|
||||||
|
|
||||||
export function copyTo(from, to) {
|
|
||||||
fs.copyFileSync(from, to);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function cleanUpTemp(tmpFolder) {
|
|
||||||
fs.rmdirSync(tmpFolder, { recursive: true });
|
|
||||||
}
|
|
||||||
|
|
||||||
export const SETUP_VERDACCIO_PORT = `6001`;
|
|
|
@ -1,22 +0,0 @@
|
||||||
import { IncomingMessage } from 'http';
|
|
||||||
import request from 'request';
|
|
||||||
|
|
||||||
export function callRegistry(url: string): Promise<string> {
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
let options = {
|
|
||||||
url: url,
|
|
||||||
headers: { Accept: 'application/json' },
|
|
||||||
};
|
|
||||||
// @ts-ignore
|
|
||||||
request(options, (error: any, response: IncomingMessage, body: string) => {
|
|
||||||
if (error) {
|
|
||||||
reject(error);
|
|
||||||
// @ts-ignore
|
|
||||||
} else if (response.statusCode >= 400) {
|
|
||||||
reject(new Error(`Requesting "${url}" returned status code ${response.statusCode}.`));
|
|
||||||
} else {
|
|
||||||
resolve(body);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue