0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-12-30 22:34:10 -05:00
verdaccio/test/unit/__helper/api.ts
Juan Picado 69d7df20d8
build: enable pnp yarn2 (#2253)
* chore: enable pnp yarn

* chore: ignore pnp

* fix type issues on run eslint

* add missing dependency and fix some errors

* fix most of the errors

some were just disabled, already fixed in master

* add missing jest-config

* update jest@26 align with other deps

* add missing @babel/register

* clean up

* use yarn node

* use yarn node on release

* chore: add husky 6

* chore: add husky 6

* chore: lint-stage

* chore: test

* chore: add hook git

* chore: test

* chore: test

* update deps

* chore: fix commit lint

* fix docker run

* update git ignore
2021-05-13 23:13:57 +02:00

216 lines
5.8 KiB
TypeScript

import _ from 'lodash';
import request from 'supertest';
import { Package } from '@verdaccio/types';
import { HEADER_TYPE, HEADERS, HTTP_STATUS, TOKEN_BEARER } from '../../../src/lib/constants';
import { buildToken, encodeScopedUri } from '../../../src/lib/utils';
import { generateRandomHexString } from '../../../src/lib/crypto-utils';
import { getTaggedVersionFromPackage } from './expects';
// API Helpers
// This file should contain utilities to avoid repeated task over API unit testing,
// Please, comply with the following:
// - Promisify everything
// - Encourage using constants or create new ones if it's needed
// - // @ts-ignore or any is fine if there is no other way
export function putPackage(
request: any,
pkgName: string,
publishMetadata: Package,
token?: string
): Promise<any[]> {
return new Promise((resolve) => {
let put = request
.put(pkgName)
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON)
.send(JSON.stringify(publishMetadata));
if (_.isEmpty(token) === false) {
expect(token).toBeDefined();
put.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token as string));
}
put
.set('accept', 'gzip')
.set('accept-encoding', HEADERS.JSON)
.expect(HTTP_STATUS.CREATED)
.end(function (err, res) {
resolve([err, res]);
});
});
}
export function deletePackage(request: any, pkgName: string, token?: string): Promise<any[]> {
return new Promise((resolve) => {
let del = request
.put(`/${encodeScopedUri(pkgName)}/-rev/${generateRandomHexString(8)}`)
.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON);
if (_.isNil(token) === false) {
del.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token as string));
}
del
.set('accept-encoding', HEADERS.JSON)
.expect(HTTP_STATUS.CREATED)
.end(function (err, res) {
resolve([err, res]);
});
});
}
export function getPackage(
request: any,
token: string,
pkgName: string,
statusCode: number = HTTP_STATUS.OK
): Promise<any[]> {
return new Promise((resolve) => {
let getRequest = request.get(`/${pkgName}`);
// token is a string
if (token !== '') {
getRequest.set(HEADERS.AUTHORIZATION, buildToken(TOKEN_BEARER, token));
}
getRequest
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(statusCode)
.end(function (err, res) {
resolve([err, res]);
});
});
}
export function loginUserToken(
request: any,
user: string,
credentials: any,
token: string,
statusCode: number = HTTP_STATUS.CREATED
): Promise<any[]> {
// $FlowFixMe
return new Promise((resolve) => {
request
.put(`/-/user/org.couchdb.user:${user}`)
.send(credentials)
.set('authorization', buildToken(TOKEN_BEARER, token))
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(statusCode)
.end(function (err, res) {
return resolve([err, res]);
});
});
}
export function addUser(
request: any,
user: string,
credentials: any,
statusCode: number = HTTP_STATUS.CREATED
): Promise<any[]> {
// $FlowFixMe
return new Promise((resolve) => {
request
.put(`/-/user/org.couchdb.user:${user}`)
.send(credentials)
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(statusCode)
.end(function (err, res) {
return resolve([err, res]);
});
});
}
export async function getNewToken(request: any, credentials: any): Promise<string> {
/* eslint no-async-promise-executor: 0 */
return new Promise(async (resolve) => {
const [err, res] = await addUser(request, credentials.name, credentials);
expect(err).toBeNull();
const { token, ok } = res.body;
expect(ok).toBeDefined();
expect(token).toBeDefined();
expect(typeof token).toBe('string');
resolve(token);
});
}
export function getProfile(
request: any,
token: string,
statusCode: number = HTTP_STATUS.OK
): Promise<any[]> {
// $FlowFixMe
return new Promise((resolve) => {
request
.get(`/-/npm/v1/user`)
.set('authorization', buildToken(TOKEN_BEARER, token))
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(statusCode)
.end(function (err, res) {
return resolve([err, res]);
});
});
}
export function postProfile(
request: any,
body: any,
token: string,
statusCode: number = HTTP_STATUS.OK
): Promise<any[]> {
// $FlowFixMe
return new Promise((resolve) => {
request
.post(`/-/npm/v1/user`)
.send(body)
.set(HEADERS.AUTHORIZATION, `Bearer ${token}`)
.expect(HEADER_TYPE.CONTENT_TYPE, HEADERS.JSON_CHARSET)
.expect(statusCode)
.end(function (err, res) {
return resolve([err, res]);
});
});
}
export async function fetchPackageByVersionAndTag(
app,
encodedPkgName,
pkgName,
version,
tag = 'latest'
) {
// we retrieve the package to verify
const [err, resp] = await getPackage(request(app), '', encodedPkgName);
expect(err).toBeNull();
// we check whether the latest version match with the previous published one
return getTaggedVersionFromPackage(resp.body, pkgName, tag, version);
}
export async function isExistPackage(app, packageName) {
const [err] = await getPackage(request(app), '', encodeScopedUri(packageName), HTTP_STATUS.OK);
return _.isNull(err);
}
export async function verifyPackageVersionDoesExist(app, packageName, version, token?: string) {
const [, res] = await getPackage(
request(app),
token as string,
encodeScopedUri(packageName),
HTTP_STATUS.OK
);
const { versions } = res.body;
const versionsKeys = Object.keys(versions);
return versionsKeys.includes(version) === false;
}
export function generateUnPublishURI(pkgName) {
return `/${encodeScopedUri(pkgName)}/-rev/${generateRandomHexString(8)}`;
}