2020-03-03 23:59:19 +01:00
|
|
|
import { Config } from '@verdaccio/config';
|
2021-10-29 17:33:05 +02:00
|
|
|
import { searchUtils } from '@verdaccio/core';
|
2020-03-03 23:59:19 +01:00
|
|
|
import { setup } from '@verdaccio/logger';
|
2021-10-29 17:33:05 +02:00
|
|
|
import { configExample } from '@verdaccio/mock';
|
2020-03-03 23:59:19 +01:00
|
|
|
|
2021-09-12 16:21:19 +02:00
|
|
|
import { Storage, removeDuplicates } from '../src';
|
2020-03-03 23:59:19 +01:00
|
|
|
import { SearchInstance } from '../src/search';
|
|
|
|
|
|
|
|
setup([]);
|
|
|
|
|
2021-09-12 16:21:19 +02:00
|
|
|
describe('search', () => {
|
|
|
|
describe('search manager utils', () => {
|
|
|
|
test('remove duplicates', () => {
|
|
|
|
const item: searchUtils.SearchPackageItem = {
|
|
|
|
// @ts-expect-error
|
|
|
|
package: {
|
|
|
|
name: 'foo',
|
|
|
|
},
|
2021-12-12 18:00:19 +01:00
|
|
|
['dist-tags']: {
|
|
|
|
latest: '1.0.0',
|
|
|
|
},
|
2021-09-12 16:21:19 +02:00
|
|
|
// @ts-expect-error
|
|
|
|
score: {},
|
|
|
|
searchScore: 0.4,
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(removeDuplicates([item, item])).toEqual([item]);
|
2020-03-03 23:59:19 +01:00
|
|
|
});
|
|
|
|
|
2021-09-12 16:21:19 +02:00
|
|
|
test('search items', async () => {
|
|
|
|
const { MockAgent } = require('undici');
|
|
|
|
// FIXME: fetch is already part of undici
|
|
|
|
const { setGlobalDispatcher } = require('undici-fetch');
|
|
|
|
const domain = 'http://localhost:4873';
|
|
|
|
const url = '/-/v1/search?maintenance=1&popularity=1&quality=1&size=10&text=verdaccio';
|
|
|
|
const response = require('./fixtures/search.json');
|
|
|
|
const options = {
|
|
|
|
path: url,
|
|
|
|
method: 'GET',
|
|
|
|
};
|
|
|
|
const mockAgent = new MockAgent({ connections: 1 });
|
|
|
|
mockAgent.disableNetConnect();
|
|
|
|
setGlobalDispatcher(mockAgent);
|
|
|
|
const mockClient = mockAgent.get(domain);
|
|
|
|
mockClient.intercept(options).reply(200, JSON.stringify(response));
|
|
|
|
const config = new Config(configExample());
|
|
|
|
const storage = new Storage(config);
|
|
|
|
await storage.init(config);
|
|
|
|
|
|
|
|
// @ts-expect-error
|
|
|
|
const results = await storage.searchManager.search({ url, query: { text: 'foo' } });
|
|
|
|
expect(results).toHaveLength(4);
|
|
|
|
});
|
2020-03-03 23:59:19 +01:00
|
|
|
});
|
|
|
|
|
2021-09-12 16:21:19 +02:00
|
|
|
describe('search index', () => {
|
|
|
|
const packages = [
|
|
|
|
{
|
|
|
|
name: 'test1',
|
|
|
|
description: 'description',
|
|
|
|
_npmUser: {
|
|
|
|
name: 'test_user',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'test2',
|
|
|
|
description: 'description',
|
|
|
|
_npmUser: {
|
|
|
|
name: 'test_user',
|
|
|
|
},
|
2020-03-03 23:59:19 +01:00
|
|
|
},
|
2021-09-12 16:21:19 +02:00
|
|
|
{
|
|
|
|
name: 'test3',
|
|
|
|
description: 'description',
|
|
|
|
_npmUser: {
|
|
|
|
name: 'test_user',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
test('search query item', async () => {
|
|
|
|
const config = new Config(configExample());
|
|
|
|
const storage = new Storage(config);
|
|
|
|
await storage.init(config);
|
|
|
|
SearchInstance.configureStorage(storage);
|
|
|
|
packages.map(function (item) {
|
|
|
|
// @ts-ignore
|
|
|
|
SearchInstance.add(item);
|
|
|
|
});
|
|
|
|
const result = SearchInstance.query('t');
|
|
|
|
expect(result).toHaveLength(3);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('search remove item', async () => {
|
|
|
|
const config = new Config(configExample());
|
|
|
|
const storage = new Storage(config);
|
|
|
|
await storage.init(config);
|
|
|
|
SearchInstance.configureStorage(storage);
|
|
|
|
packages.map(function (item) {
|
|
|
|
// @ts-ignore
|
|
|
|
SearchInstance.add(item);
|
|
|
|
});
|
|
|
|
const item = {
|
|
|
|
name: 'test6',
|
|
|
|
description: 'description',
|
|
|
|
_npmUser: {
|
|
|
|
name: 'test_user',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// @ts-ignore
|
|
|
|
SearchInstance.add(item);
|
|
|
|
let result = SearchInstance.query('test6');
|
|
|
|
expect(result).toHaveLength(1);
|
|
|
|
SearchInstance.remove(item.name);
|
|
|
|
result = SearchInstance.query('test6');
|
|
|
|
expect(result).toHaveLength(0);
|
|
|
|
});
|
2020-03-03 23:59:19 +01:00
|
|
|
});
|
|
|
|
});
|