0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-12-30 22:34:10 -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:
Juan Picado 2022-08-02 22:45:16 +02:00 committed by GitHub
parent a123775f20
commit 1755840cd3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
60 changed files with 602 additions and 749 deletions

View file

@ -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'

View file

@ -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",

View 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);
}

View 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';

View file

@ -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');

View file

@ -1,3 +1,3 @@
#!/usr/bin/env node #!/usr/bin/env node
require('@verdaccio/cli'); require('../build/start');

View file

@ -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);

View file

@ -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'}

View file

@ -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

View file

@ -0,0 +1,3 @@
{
"extends": "../../../.babelrc"
}

View 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"
}
}

View 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';

View 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);
}

View 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 };
}

View 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];
}

View 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();
}

View file

@ -0,0 +1,9 @@
{
"extends": "../../../tsconfig.base.json",
"compilerOptions": {
"rootDir": "./src",
"outDir": "./build"
},
"include": ["src/**/*"],
"exclude": ["src/**/*.test.ts"]
}

View 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"
}
]
}

View file

@ -0,0 +1,3 @@
{
"extends": "../../../.babelrc"
}

View file

@ -0,0 +1,7 @@
{
"rules": {
"no-console": 0,
"@typescript-eslint/no-var-requires": 0,
"@typescript-eslint/explicit-member-accessibility": 0
}
}

View 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();
});
});

View 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',
});

View 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"
}
}

View file

@ -3,5 +3,10 @@
"compilerOptions": { "compilerOptions": {
"rootDir": "./src", "rootDir": "./src",
"outDir": "./build" "outDir": "./build"
} },
"references": [
{
"path": "../cli-commons"
}
]
} }

View 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);
}

View file

@ -1,3 +0,0 @@
{
"extends": "../../.babelrc"
}

View file

@ -1,4 +0,0 @@
require('@babel/register')({
extensions: ['.ts', '.js'],
});
module.exports = require('./setup/test_environment');

View file

@ -1,4 +0,0 @@
require('@babel/register')({
extensions: ['.ts', '.js'],
});
module.exports = require('./setup/setup');

View file

@ -1,4 +0,0 @@
require('@babel/register')({
extensions: ['.ts', '.js'],
});
module.exports = require('./setup/teardown');

View file

@ -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',
});

View file

@ -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"
}
}

View file

@ -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}`
);
};

View file

@ -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();
};

View file

@ -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;

View file

@ -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];
};

View file

@ -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);
}

View file

@ -1,7 +0,0 @@
import { addNpmPrefix } from './registry';
describe('registry utils', function () {
test('prefix', () => {
expect([...addNpmPrefix('foo')]).toEqual('');
});
});

View file

@ -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}`);
};

View file

@ -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`;

View file

@ -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);
}
});
});
}