2022-07-29 13:51:45 -05:00
|
|
|
import { Application } from 'express';
|
|
|
|
import _ from 'lodash';
|
2021-10-29 10:33:05 -05:00
|
|
|
import path from 'path';
|
2020-06-30 14:55:14 -05:00
|
|
|
import supertest from 'supertest';
|
|
|
|
|
2022-07-29 13:51:45 -05:00
|
|
|
import { parseConfigFile } from '@verdaccio/config';
|
|
|
|
import { HEADERS, HEADER_TYPE, HTTP_STATUS, TOKEN_BEARER } from '@verdaccio/core';
|
|
|
|
import { setup } from '@verdaccio/logger';
|
2021-10-29 10:33:05 -05:00
|
|
|
import { Storage } from '@verdaccio/store';
|
2022-07-29 13:51:45 -05:00
|
|
|
import {
|
|
|
|
generatePackageMetadata,
|
|
|
|
initializeServer as initializeServerHelper,
|
|
|
|
} from '@verdaccio/test-helper';
|
|
|
|
import { GenericBody } from '@verdaccio/types';
|
|
|
|
import { buildToken, generateRandomHexString } from '@verdaccio/utils';
|
2021-10-29 10:33:05 -05:00
|
|
|
|
2022-07-29 13:51:45 -05:00
|
|
|
import apiMiddleware from '../../src';
|
2020-06-30 14:55:14 -05:00
|
|
|
|
2022-07-29 13:51:45 -05:00
|
|
|
setup();
|
2020-06-30 14:55:14 -05:00
|
|
|
|
2022-07-29 13:51:45 -05:00
|
|
|
export const getConf = (conf) => {
|
|
|
|
const configPath = path.join(__dirname, 'config', conf);
|
|
|
|
const config = parseConfigFile(configPath);
|
|
|
|
// custom config to avoid conflict with other tests
|
|
|
|
config.auth.htpasswd.file = `${config.auth.htpasswd.file}-${generateRandomHexString()}`;
|
|
|
|
return config;
|
2020-06-30 14:55:14 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
export async function initializeServer(configName): Promise<Application> {
|
2022-07-29 13:51:45 -05:00
|
|
|
return initializeServerHelper(getConf(configName), [apiMiddleware], Storage);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function createUser(app, name: string, password: string): supertest.Test {
|
|
|
|
return supertest(app)
|
|
|
|
.put(`/-/user/org.couchdb.user:${name}`)
|
|
|
|
.send({
|
|
|
|
name: name,
|
|
|
|
password: password,
|
|
|
|
})
|
|
|
|
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
|
|
|
|
.expect(HTTP_STATUS.CREATED);
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function getNewToken(app: any, credentials: any): Promise<string> {
|
|
|
|
const response = await createUser(app, credentials.name, credentials.password);
|
|
|
|
const { token, ok } = response.body;
|
|
|
|
expect(ok).toBeDefined();
|
|
|
|
expect(token).toBeDefined();
|
|
|
|
expect(typeof token).toBe('string');
|
|
|
|
return token;
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function generateTokenCLI(app, token, payload): Promise<any> {
|
|
|
|
return supertest(app)
|
|
|
|
.post('/-/npm/v1/tokens')
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.send(JSON.stringify(payload))
|
|
|
|
.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token))
|
|
|
|
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET);
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function deleteTokenCLI(app, token, tokenToDelete): Promise<any> {
|
|
|
|
return supertest(app)
|
|
|
|
.delete(`/-/npm/v1/tokens/token/${tokenToDelete}`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token))
|
|
|
|
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
|
|
|
|
.expect(HTTP_STATUS.OK);
|
2020-06-30 14:55:14 -05:00
|
|
|
}
|
|
|
|
|
2022-07-29 13:51:45 -05:00
|
|
|
export function publishVersionWithToken(
|
|
|
|
app,
|
|
|
|
pkgName: string,
|
|
|
|
version: string,
|
|
|
|
token: string,
|
|
|
|
distTags?: GenericBody
|
|
|
|
): supertest.Test {
|
|
|
|
const pkgMetadata = generatePackageMetadata(pkgName, version, distTags);
|
2020-06-30 14:55:14 -05:00
|
|
|
|
2020-08-13 16:27:00 -05:00
|
|
|
return supertest(app)
|
|
|
|
.put(`/${encodeURIComponent(pkgName)}`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
2022-07-29 13:51:45 -05:00
|
|
|
.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token))
|
2020-08-13 16:27:00 -05:00
|
|
|
.send(JSON.stringify(pkgMetadata))
|
|
|
|
.set('accept', HEADERS.GZIP)
|
2022-07-29 13:51:45 -05:00
|
|
|
.set(HEADER_TYPE.ACCEPT_ENCODING, HEADERS.JSON);
|
2020-06-30 14:55:14 -05:00
|
|
|
}
|
|
|
|
|
2022-07-29 13:51:45 -05:00
|
|
|
export function publishVersion(
|
2020-09-16 23:48:16 -05:00
|
|
|
app,
|
|
|
|
pkgName: string,
|
|
|
|
version: string,
|
2022-07-29 13:51:45 -05:00
|
|
|
distTags?: GenericBody
|
|
|
|
): supertest.Test {
|
|
|
|
const pkgMetadata = generatePackageMetadata(pkgName, version, distTags);
|
2020-06-30 14:55:14 -05:00
|
|
|
|
2020-08-13 16:27:00 -05:00
|
|
|
return supertest(app)
|
2022-07-29 13:51:45 -05:00
|
|
|
.put(`/${encodeURIComponent(pkgName)}`)
|
2020-08-13 16:27:00 -05:00
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.send(JSON.stringify(pkgMetadata))
|
|
|
|
.set('accept', HEADERS.GZIP)
|
2022-07-29 13:51:45 -05:00
|
|
|
.set(HEADER_TYPE.ACCEPT_ENCODING, HEADERS.JSON);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getDisTags(app, pkgName) {
|
|
|
|
return supertest(app)
|
|
|
|
.get(`/-/package/${encodeURIComponent(pkgName)}/dist-tags`)
|
|
|
|
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
|
|
|
|
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
|
|
|
|
.expect(HTTP_STATUS.OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getPackage(
|
|
|
|
app: any,
|
|
|
|
token: string,
|
|
|
|
pkgName: string,
|
|
|
|
statusCode: number = HTTP_STATUS.OK
|
|
|
|
): supertest.Test {
|
|
|
|
const test = supertest(app).get(`/${pkgName}`);
|
|
|
|
|
|
|
|
if (_.isNil(token) === false || _.isEmpty(token) === false) {
|
|
|
|
test.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token));
|
|
|
|
}
|
|
|
|
|
|
|
|
return test.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET).expect(statusCode);
|
2020-06-30 14:55:14 -05:00
|
|
|
}
|