mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-13 22:48:31 -05:00
e54ec4b5d0
* feat: remove level for token by lowdb * chore: fix format * chore: fix config * chore: add changeset
81 lines
2.5 KiB
TypeScript
81 lines
2.5 KiB
TypeScript
/* eslint-disable jest/no-mocks-import */
|
|
import fs from 'fs';
|
|
import path from 'path';
|
|
|
|
import { assign } from 'lodash';
|
|
import { ILocalData, PluginOptions, Token } from '@verdaccio/types';
|
|
|
|
import LocalDatabase from '../src/local-database';
|
|
import { ILocalFSPackageManager } from '../src/local-fs';
|
|
import * as pkgUtils from '../src/pkg-utils';
|
|
|
|
// FIXME: remove this mocks imports
|
|
import Config from './__mocks__/Config';
|
|
import logger from './__mocks__/Logger';
|
|
|
|
const optionsPlugin: PluginOptions<{}> = {
|
|
logger,
|
|
config: new Config(),
|
|
};
|
|
|
|
let locaDatabase: ILocalData<{}>;
|
|
let loadPrivatePackages;
|
|
|
|
describe('Local Database', () => {
|
|
beforeEach(() => {
|
|
const writeMock = jest.spyOn(fs, 'writeFileSync').mockImplementation();
|
|
loadPrivatePackages = jest
|
|
.spyOn(pkgUtils, 'loadPrivatePackages')
|
|
.mockReturnValue({ list: [], secret: '' });
|
|
locaDatabase = new LocalDatabase(optionsPlugin.config, optionsPlugin.logger);
|
|
(locaDatabase as LocalDatabase).clean();
|
|
writeMock.mockClear();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.clearAllMocks();
|
|
});
|
|
|
|
describe('token', () => {
|
|
let token: Token = {
|
|
user: 'someUser',
|
|
viewToken: 'viewToken',
|
|
key: 'someHash',
|
|
readonly: true,
|
|
createdTimestamp: new Date().getTime(),
|
|
};
|
|
|
|
test('should save and get token', async () => {
|
|
await locaDatabase.saveToken(token);
|
|
const tokens = await locaDatabase.readTokens({ user: token.user });
|
|
expect(tokens).toHaveLength(1);
|
|
expect(tokens[0]).toEqual(token);
|
|
});
|
|
|
|
test('should revoke and get token', async () => {
|
|
await locaDatabase.saveToken(token);
|
|
const tokens = await locaDatabase.readTokens({ user: token.user });
|
|
expect(tokens).toHaveLength(1);
|
|
expect(tokens[0]).toEqual(token);
|
|
await locaDatabase.deleteToken(token.user, token.key);
|
|
const tokens2 = await locaDatabase.readTokens({ user: token.user });
|
|
expect(tokens2).toHaveLength(0);
|
|
});
|
|
|
|
test('should fail on revoke', async () => {
|
|
await expect(locaDatabase.deleteToken({ user: 'foo', key: 'bar' })).rejects.toThrow(
|
|
'user not found'
|
|
);
|
|
});
|
|
|
|
test('should verify save more than one token', async () => {
|
|
await locaDatabase.saveToken(token);
|
|
const tokens = await locaDatabase.readTokens({ user: token.user });
|
|
expect(tokens).toHaveLength(1);
|
|
expect(tokens[0]).toEqual(token);
|
|
await locaDatabase.saveToken({ ...token, key: 'foo' });
|
|
expect(tokens).toHaveLength(2);
|
|
expect(tokens[1].key).toEqual('foo');
|
|
});
|
|
});
|
|
});
|