0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-06 22:40:26 -05:00

chore: replace node-fetch by undici hook package (#2292)

* chore: replace node-fetch by undici hook package

* fix types

* test something

* test 12

* add flag

* restore fail fast

* remove 12 from tests
This commit is contained in:
Juan Picado 2021-06-12 18:24:54 +02:00 committed by GitHub
parent 2197d08e42
commit d6e44a4c18
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 62 additions and 54 deletions

View file

@ -116,7 +116,7 @@ jobs:
fail-fast: true fail-fast: true
matrix: matrix:
os: [ubuntu-latest] os: [ubuntu-latest]
node_version: [12, 14] node_version: [14]
name: ${{ matrix.os }} / Node ${{ matrix.node_version }} name: ${{ matrix.os }} / Node ${{ matrix.node_version }}
runs-on: ${{ matrix.os }} runs-on: ${{ matrix.os }}
steps: steps:

View file

@ -1,3 +1,5 @@
const config = require('../../jest/config'); const config = require('../../jest/config');
module.exports = Object.assign({}, config, {}); module.exports = Object.assign({}, config, {
testEnvironment: 'node',
});

View file

@ -26,7 +26,7 @@
"verdaccio" "verdaccio"
], ],
"engines": { "engines": {
"node": ">=10", "node": ">=12",
"npm": ">=6" "npm": ">=6"
}, },
"dependencies": { "dependencies": {
@ -34,15 +34,14 @@
"@verdaccio/logger": "workspace:6.0.0-6-next.4", "@verdaccio/logger": "workspace:6.0.0-6-next.4",
"debug": "^4.2.0", "debug": "^4.2.0",
"handlebars": "4.5.3", "handlebars": "4.5.3",
"node-fetch": "^2.6.1", "undici": "^4.0.0-rc.1",
"request": "2.87.0" "undici-fetch": "^1.0.0-rc.1"
}, },
"devDependencies": { "devDependencies": {
"@verdaccio/auth": "workspace:6.0.0-6-next.9", "@verdaccio/auth": "workspace:6.0.0-6-next.9",
"@verdaccio/commons-api": "workspace:11.0.0-alpha.3", "@verdaccio/commons-api": "workspace:11.0.0-alpha.3",
"@verdaccio/config": "workspace:6.0.0-6-next.7", "@verdaccio/config": "workspace:6.0.0-6-next.7",
"@verdaccio/types": "workspace:11.0.0-6-next.7", "@verdaccio/types": "workspace:11.0.0-6-next.7"
"nock": "^13.0.4"
}, },
"scripts": { "scripts": {
"clean": "rimraf ./build", "clean": "rimraf ./build",

View file

@ -1,13 +1,18 @@
import fetch, { RequestInit } from 'node-fetch';
import buildDebug from 'debug'; import buildDebug from 'debug';
import { logger } from '@verdaccio/logger'; import { logger } from '@verdaccio/logger';
import { HTTP_STATUS } from '@verdaccio/commons-api'; import { HTTP_STATUS } from '@verdaccio/commons-api';
const debug = buildDebug('verdaccio:hooks:request'); const debug = buildDebug('verdaccio:hooks:request');
export type NotifyRequestOptions = RequestInit; const fetch = require('undici-fetch');
export async function notifyRequest(url: string, options: NotifyRequestOptions): Promise<boolean> { export type FetchOptions = {
body: string;
headers?: {};
method?: string;
};
export async function notifyRequest(url: string, options: FetchOptions): Promise<boolean> {
let response; let response;
try { try {
debug('uri %o', url); debug('uri %o', url);

View file

@ -5,7 +5,7 @@ import Handlebars from 'handlebars';
import buildDebug from 'debug'; import buildDebug from 'debug';
import { Config, Package, RemoteUser, Notification } from '@verdaccio/types'; import { Config, Package, RemoteUser, Notification } from '@verdaccio/types';
import { logger } from '@verdaccio/logger'; import { logger } from '@verdaccio/logger';
import { notifyRequest, NotifyRequestOptions } from './notify-request'; import { notifyRequest, FetchOptions } from './notify-request';
const debug = buildDebug('verdaccio:hooks'); const debug = buildDebug('verdaccio:hooks');
@ -50,7 +50,7 @@ export async function handleNotify(
content = await compileTemplate(notifyEntry.content, metadata); content = await compileTemplate(notifyEntry.content, metadata);
} }
const options: NotifyRequestOptions = { const options: FetchOptions = {
body: JSON.stringify(content), body: JSON.stringify(content),
}; };

View file

@ -1,4 +1,4 @@
import nock from 'nock'; import { setup } from '@verdaccio/logger';
import { Config } from '@verdaccio/types'; import { Config } from '@verdaccio/types';
import { parseConfigFile, createRemoteUser } from '@verdaccio/config'; import { parseConfigFile, createRemoteUser } from '@verdaccio/config';
import { notify } from '../src/notify'; import { notify } from '../src/notify';
@ -12,36 +12,33 @@ const singleHeaderNotificationConfig = parseConfigFile(
); );
const multiNotificationConfig = parseConfigFile(parseConfigurationNotifyFile('multiple.notify')); const multiNotificationConfig = parseConfigFile(parseConfigurationNotifyFile('multiple.notify'));
const mockInfo = jest.fn(); setup([]);
jest.mock('@verdaccio/logger', () => ({
setup: jest.fn(),
logger: {
child: jest.fn(),
debug: jest.fn(),
trace: jest.fn(),
warn: jest.fn(),
info: () => mockInfo(),
error: jest.fn(),
fatal: jest.fn(),
},
}));
const domain = 'http://slack-service'; const domain = 'http://slack-service';
const { MockAgent } = require('undici');
const { setGlobalDispatcher } = require('undici-fetch');
const options = {
path: '/foo?auth_token=mySecretToken',
method: 'POST',
};
describe('Notifications:: notifyRequest', () => { describe('Notifications:: notifyRequest', () => {
beforeEach(() => {
nock.cleanAll();
});
test('when sending a empty notification', async () => { test('when sending a empty notification', async () => {
nock(domain).post('/foo?auth_token=mySecretToken').reply(200, { body: 'test' }); const mockAgent = new MockAgent({ connections: 1 });
setGlobalDispatcher(mockAgent);
const mockClient = mockAgent.get(domain);
mockClient.intercept(options).reply(200, { body: 'test' });
const notificationResponse = await notify({}, {}, createRemoteUser('foo', []), 'bar'); const notificationResponse = await notify({}, {}, createRemoteUser('foo', []), 'bar');
expect(notificationResponse).toEqual([false]); expect(notificationResponse).toEqual([false]);
}); });
test('when sending a single notification', async () => { test('when sending a single notification', async () => {
nock(domain).post('/foo?auth_token=mySecretToken').reply(200, { body: 'test' }); const mockAgent = new MockAgent({ connections: 1 });
setGlobalDispatcher(mockAgent);
const mockClient = mockAgent.get(domain);
mockClient.intercept(options).reply(200, { body: 'test' });
const notificationResponse = await notify( const notificationResponse = await notify(
{}, {},
@ -50,10 +47,14 @@ describe('Notifications:: notifyRequest', () => {
'bar' 'bar'
); );
expect(notificationResponse).toEqual([true]); expect(notificationResponse).toEqual([true]);
await mockClient.close();
}); });
test('when notification endpoint is missing', async () => { test('when notification endpoint is missing', async () => {
nock(domain).post('/foo?auth_token=mySecretToken').reply(200, { body: 'test' }); const mockAgent = new MockAgent({ connections: 1 });
setGlobalDispatcher(mockAgent);
const mockClient = mockAgent.get(domain);
mockClient.intercept(options).reply(200, { body: 'test' });
const name = 'package'; const name = 'package';
const config: Partial<Config> = { const config: Partial<Config> = {
// @ts-ignore // @ts-ignore
@ -68,14 +69,16 @@ describe('Notifications:: notifyRequest', () => {
}); });
test('when multiple notifications', async () => { test('when multiple notifications', async () => {
nock(domain).post('/foo?auth_token=mySecretToken').reply(200, { body: 'test' }); const mockAgent = new MockAgent({ connections: 1 });
nock(domain).post('/foo?auth_token=mySecretToken').reply(400, {}); setGlobalDispatcher(mockAgent);
nock(domain) const mockClient = mockAgent.get(domain);
.post('/foo?auth_token=mySecretToken') mockClient.intercept(options).reply(200, { body: 'test' });
.reply(500, { message: 'Something bad happened' }); mockClient.intercept(options).reply(400, {});
mockClient.intercept(options).reply(500, { message: 'Something bad happened' });
const name = 'package'; const name = 'package';
const responses = await notify({ name }, multiNotificationConfig, { name: 'foo' }, 'bar'); const responses = await notify({ name }, multiNotificationConfig, { name: 'foo' }, 'bar');
expect(responses).toEqual([true, false, false]); expect(responses).toEqual([true, false, false]);
await mockClient.close();
}); });
}); });

View file

@ -504,21 +504,19 @@ importers:
'@verdaccio/types': workspace:11.0.0-6-next.7 '@verdaccio/types': workspace:11.0.0-6-next.7
debug: ^4.2.0 debug: ^4.2.0
handlebars: 4.5.3 handlebars: 4.5.3
nock: ^13.0.4 undici: ^4.0.0-rc.1
node-fetch: ^2.6.1 undici-fetch: ^1.0.0-rc.1
request: 2.87.0
dependencies: dependencies:
'@verdaccio/commons-api': link:../core/commons-api '@verdaccio/commons-api': link:../core/commons-api
'@verdaccio/logger': link:../logger '@verdaccio/logger': link:../logger
debug: 4.2.0 debug: 4.2.0
handlebars: 4.5.3 handlebars: 4.5.3
node-fetch: 2.6.1 undici: 4.0.0-rc.7
request: 2.87.0 undici-fetch: 1.0.0-rc.1
devDependencies: devDependencies:
'@verdaccio/auth': link:../auth '@verdaccio/auth': link:../auth
'@verdaccio/config': link:../config '@verdaccio/config': link:../config
'@verdaccio/types': link:../core/types '@verdaccio/types': link:../core/types
nock: 13.0.4
packages/loaders: packages/loaders:
specifiers: specifiers:
@ -13500,16 +13498,6 @@ packages:
- supports-color - supports-color
dev: true dev: true
/nock/13.0.4:
resolution: {integrity: sha512-alqTV8Qt7TUbc74x1pKRLSENzfjp4nywovcJgi/1aXDiUxXdt7TkruSTF5MDWPP7UoPVgea4F9ghVdmX0xxnSA==}
engines: {node: '>= 10.13'}
dependencies:
debug: 4.1.1
json-stringify-safe: 5.0.1
lodash.set: 4.3.2
propagate: 2.0.1
dev: true
/node-abi/2.19.1: /node-abi/2.19.1:
resolution: {integrity: sha512-HbtmIuByq44yhAzK7b9j/FelKlHYISKQn0mtvcBrU5QBkhoCMp5bu8Hv5AI34DcKfOAcJBcOEMwLlwO62FFu9A==} resolution: {integrity: sha512-HbtmIuByq44yhAzK7b9j/FelKlHYISKQn0mtvcBrU5QBkhoCMp5bu8Hv5AI34DcKfOAcJBcOEMwLlwO62FFu9A==}
dependencies: dependencies:
@ -18095,6 +18083,17 @@ packages:
debug: 2.6.9 debug: 2.6.9
dev: true dev: true
/undici-fetch/1.0.0-rc.1:
resolution: {integrity: sha512-VPMBog6ke/hSABltjVrcq+xc0RSnqfgmufn+5hfKBoIEJJq5nkKWQcWzW/uGlesSC2eKFQ6sPCQesFc7LfqGAg==}
dependencies:
undici: 4.0.0-rc.7
dev: false
/undici/4.0.0-rc.7:
resolution: {integrity: sha512-8vhF9REAH/O+eGh1K942bTznr47JOZHlHMTh9/5XiJvcBk3GqV2qzeRPxwDfAeHNWjm1BZ4EsSgAotHV2EOxeA==}
engines: {node: '>=12.18'}
dev: false
/unicode-canonical-property-names-ecmascript/1.0.4: /unicode-canonical-property-names-ecmascript/1.0.4:
resolution: {integrity: sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==} resolution: {integrity: sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==}
engines: {node: '>=4'} engines: {node: '>=4'}