mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-20 22:52:46 -05:00
58e0d950df
* fix(middleware): error 404 when getting scoped tarballs * Create mbt.yml * Update mbt.yml * Change to relative URL, constants, proxy url * Split into make-url-relative.ts * add debug
110 lines
3.6 KiB
TypeScript
110 lines
3.6 KiB
TypeScript
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
|
|
/* global AbortController */
|
|
import getStream from 'get-stream';
|
|
import nock from 'nock';
|
|
import path from 'path';
|
|
import { describe, expect, test, vi } from 'vitest';
|
|
|
|
import { Config, parseConfigFile } from '@verdaccio/config';
|
|
import { streamUtils } from '@verdaccio/core';
|
|
import { Logger } from '@verdaccio/types';
|
|
|
|
import { ProxyStorage } from '../src';
|
|
|
|
const getConf = (name) => path.join(__dirname, '/conf', name);
|
|
|
|
const mockDebug = vi.fn();
|
|
const mockInfo = vi.fn();
|
|
const mockHttp = vi.fn();
|
|
const mockError = vi.fn();
|
|
const mockWarn = vi.fn();
|
|
|
|
const logger = {
|
|
debug: mockDebug,
|
|
info: mockInfo,
|
|
http: mockHttp,
|
|
error: mockError,
|
|
warn: mockWarn,
|
|
} as unknown as Logger;
|
|
|
|
const domain = 'https://registry.npmjs.org';
|
|
|
|
describe('proxy', () => {
|
|
const queryUrl = '/-/v1/search?maintenance=1&popularity=1&quality=1&size=10&text=verdaccio';
|
|
const defaultRequestOptions = {
|
|
url: domain,
|
|
};
|
|
const proxyPath = getConf('proxy1.yaml');
|
|
const conf = new Config(parseConfigFile(proxyPath));
|
|
|
|
describe('search', () => {
|
|
test('get response from endpoint', async () => {
|
|
const response = require('./partials/search-v1.json');
|
|
nock(domain)
|
|
.get('/-/v1/search?maintenance=1&popularity=1&quality=1&size=10&text=verdaccio')
|
|
.reply(200, response);
|
|
const prox1 = new ProxyStorage(defaultRequestOptions, conf, logger);
|
|
const abort = new AbortController();
|
|
const stream = await prox1.search({
|
|
abort,
|
|
url: queryUrl,
|
|
});
|
|
|
|
const searchResponse = await getStream(stream.pipe(streamUtils.transformObjectToString()));
|
|
expect(searchResponse).toEqual(searchResponse);
|
|
});
|
|
|
|
test('get response from uplink with trailing slash', async () => {
|
|
const response = require('./partials/search-v1.json');
|
|
nock(domain + '/')
|
|
.get('/-/v1/search?maintenance=1&popularity=1&quality=1&size=10&text=verdaccio')
|
|
.reply(200, response);
|
|
const prox1 = new ProxyStorage(defaultRequestOptions, conf, logger);
|
|
const abort = new AbortController();
|
|
const stream = await prox1.search({
|
|
abort,
|
|
url: queryUrl,
|
|
});
|
|
|
|
const searchResponse = await getStream(stream.pipe(streamUtils.transformObjectToString()));
|
|
expect(searchResponse).toEqual(searchResponse);
|
|
});
|
|
|
|
test('handle bad response 409', async () => {
|
|
nock(domain)
|
|
.get('/-/v1/search?maintenance=1&popularity=1&quality=1&size=10&text=verdaccio')
|
|
.reply(409);
|
|
const abort = new AbortController();
|
|
const prox1 = new ProxyStorage(defaultRequestOptions, conf, logger);
|
|
await expect(
|
|
prox1.search({
|
|
abort,
|
|
url: queryUrl,
|
|
})
|
|
).rejects.toThrow('bad status code 409 from uplink');
|
|
});
|
|
|
|
// test.todo('abort search from endpoint');
|
|
|
|
// // TODO: we should test the gzip deflate here, but is hard to test
|
|
// // fix me if you can deal with Incorrect Header Check issue
|
|
// test.todo('get file from endpoint with gzip headers');
|
|
|
|
// test('search endpoint fails', async () => {
|
|
// const mockAgent = new MockAgent({ connections: 1 });
|
|
// mockAgent.disableNetConnect();
|
|
// setGlobalDispatcher(mockAgent);
|
|
// const mockClient = mockAgent.get(domain);
|
|
// mockClient.intercept(options).reply(500, {});
|
|
// const abort = new AbortController();
|
|
// const prox1 = new ProxyStorage(defaultRequestOptions, conf);
|
|
// await expect(
|
|
// prox1.search({
|
|
// abort,
|
|
// url: queryUrl,
|
|
// })
|
|
// ).rejects.toThrow('bad status code 500 from uplink');
|
|
// });
|
|
});
|
|
});
|