0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-13 22:48:31 -05:00
verdaccio/test/unit/modules/api/search.spec.ts
Juan Picado bae430fe24
feat: refactor test and use verdaccio 6 core modules (#3569)
chore: clean up comments

remove commitlint

update deps

add new tests

test

separate ci

test

test

test

test

test

test

chore: add preprelase

test

test

test

test

test

chore: update deps

Update release-snapshot.yml

Update .npmignore

test

chore: remove @verdaccio/commons-api dep

chore: cleanup

remove normalizeContributors

remove validateMetadata

fix test

clean up getLocalRegistryTarballUri

Update store.spec.ts

clean up convertDistRemoteToLocalTarballUrls

chore: update libraries

reuse getPublic url

clean up

Update jest.config.js

Update jest.config.js

update nvmrc

add tests
2023-01-28 14:39:37 +01:00

140 lines
4.1 KiB
TypeScript

import supertest from 'supertest';
import { HEADERS, HEADER_TYPE, HTTP_STATUS } from '@verdaccio/core';
import { createUser, initializeServer, publishVersionWithToken } from './_helper';
describe('search', () => {
let app;
beforeEach(async () => {
app = await initializeServer('search.yaml');
});
describe('search authenticated', () => {
test.each([['foo']])('should return a foo private package', async (pkg) => {
const res = await createUser(app, 'test', 'test');
await publishVersionWithToken(app, pkg, '1.0.0', res.body.token);
// this should not be displayed as part of the search
await publishVersionWithToken(app, 'private-auth', '1.0.0', res.body.token);
const response = await supertest(app)
.get(
`/-/v1/search?text=${encodeURIComponent(
pkg
)}&size=2000&from=0&quality=1&popularity=0.1&maintenance=0.1`
)
.set(HEADERS.ACCEPT, HEADERS.JSON)
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
.expect(HEADERS.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(HTTP_STATUS.OK);
expect(response.body.objects[0].package).toEqual(
expect.objectContaining({
name: 'foo',
description: 'package generated',
'dist-tags': {
latest: '1.0.0',
},
maintainers: [
{
name: 'User NPM',
email: 'user@domain.com',
},
],
author: {
name: 'User NPM',
email: 'user@domain.com',
},
keywords: [],
versions: {
'1.0.0': 'latest',
},
})
);
expect(response.body.objects[0].score).toEqual(
expect.objectContaining({
detail: {
maintenance: 0,
popularity: 1,
quality: 1,
},
final: 1,
})
);
expect(response.body.objects[0]).toEqual(
expect.objectContaining({
local: true,
})
);
expect(response.body).toEqual(
expect.objectContaining({
total: 1,
})
);
});
test.each([['@scope/foo']])('should return a scoped foo private package', async (pkg) => {
const res = await createUser(app, 'test', 'test');
await publishVersionWithToken(app, pkg, '1.0.0', res.body.token);
// this should not be displayed as part of the search
await publishVersionWithToken(app, '@private/auth', '1.0.0', res.body.token);
const response = await supertest(app)
.get(
`/-/v1/search?text=${encodeURIComponent(
pkg
)}&size=2000&from=0&quality=1&popularity=0.1&maintenance=0.1`
)
.set(HEADERS.ACCEPT, HEADERS.JSON)
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
.expect(HEADERS.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(HTTP_STATUS.OK);
expect(response.body.objects[0].package).toEqual(
expect.objectContaining({
name: '@scope/foo',
description: 'package generated',
'dist-tags': {
latest: '1.0.0',
},
license: 'ISC',
readmeFilename: 'README.md',
maintainers: [
{
name: 'User NPM',
email: 'user@domain.com',
},
],
author: {
name: 'User NPM',
email: 'user@domain.com',
},
keywords: [],
versions: {
'1.0.0': 'latest',
},
})
);
expect(response.body.objects[0].score).toEqual(
expect.objectContaining({
detail: {
maintenance: 0,
popularity: 1,
quality: 1,
},
final: 1,
})
);
expect(response.body.objects[0]).toEqual(
expect.objectContaining({
local: true,
})
);
expect(response.body).toEqual(
expect.objectContaining({
total: 1,
})
);
});
});
describe('error handling', () => {
test.todo('should able to abort the request');
});
});