2018-02-19 19:29:14 +01:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import _ from 'lodash';
|
2018-06-28 08:26:07 +02:00
|
|
|
import path from 'path';
|
2019-01-29 11:54:47 +08:00
|
|
|
import fs from 'fs';
|
|
|
|
import rimraf from 'rimraf';
|
2018-02-19 19:29:14 +01:00
|
|
|
// $FlowFixMe
|
2018-06-17 13:34:59 +02:00
|
|
|
import configExample from '../partials/config/index';
|
|
|
|
import AppConfig from '../../../src/lib/config';
|
|
|
|
import Storage from '../../../src/lib/storage';
|
|
|
|
import {setup} from '../../../src/lib/logger';
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-02-26 21:28:09 +01:00
|
|
|
import type {Config} from '@verdaccio/types';
|
2018-06-17 13:34:59 +02:00
|
|
|
import type {IStorageHandler} from '../../../types/index';
|
2018-06-27 08:52:52 +02:00
|
|
|
import {API_ERROR, HTTP_STATUS} from '../../../src/lib/constants';
|
2018-06-24 22:39:09 +02:00
|
|
|
import {mockServer} from './mock';
|
|
|
|
import {DOMAIN_SERVERS} from '../../functional/config.functional';
|
2018-02-19 19:29:14 +01:00
|
|
|
|
|
|
|
setup(configExample.logs);
|
|
|
|
|
2019-01-29 11:54:47 +08:00
|
|
|
const storagePath = path.join(__dirname, '../partials/store/test-storage-store.spec');
|
2018-06-24 22:39:09 +02:00
|
|
|
const mockServerPort: number = 55548;
|
2018-06-27 08:52:52 +02:00
|
|
|
const generateStorage = async function(port = mockServerPort, configDefault = configExample) {
|
|
|
|
const storageConfig = _.clone(configDefault);
|
2018-02-19 19:29:14 +01:00
|
|
|
storageConfig.self_path = __dirname;
|
2019-01-29 11:54:47 +08:00
|
|
|
storageConfig.storage = storagePath;
|
2018-06-24 22:39:09 +02:00
|
|
|
storageConfig.uplinks = {
|
|
|
|
npmjs: {
|
|
|
|
url: `http://${DOMAIN_SERVERS}:${port}`
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const config: Config = new AppConfig(storageConfig);
|
2018-04-21 18:36:06 +02:00
|
|
|
const store: IStorageHandler = new Storage(config);
|
|
|
|
await store.init(config);
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-24 22:39:09 +02:00
|
|
|
return store;
|
2018-02-19 19:29:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
describe('StorageTest', () => {
|
2018-06-24 22:39:09 +02:00
|
|
|
let mockRegistry;
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2019-01-29 11:54:47 +08:00
|
|
|
beforeAll(done => {
|
|
|
|
rimraf(storagePath, async () => {
|
|
|
|
mockRegistry = await mockServer(mockServerPort).init();
|
|
|
|
done()
|
|
|
|
})
|
2018-06-24 22:39:09 +02:00
|
|
|
});
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-24 22:39:09 +02:00
|
|
|
afterAll(function(done) {
|
|
|
|
mockRegistry[0].stop();
|
|
|
|
done();
|
|
|
|
});
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-24 22:39:09 +02:00
|
|
|
test('should be defined', async () => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
2018-02-19 19:29:14 +01:00
|
|
|
|
|
|
|
expect(storage).toBeDefined();
|
2018-06-24 22:39:09 +02:00
|
|
|
});
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-27 08:52:52 +02:00
|
|
|
describe('test _syncUplinksMetadata', () => {
|
|
|
|
test('should fetch from uplink jquery metadata from registry', async (done) => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-27 08:52:52 +02:00
|
|
|
// $FlowFixMe
|
|
|
|
storage._syncUplinksMetadata('jquery', null, {}, (err, metadata, errors) => {
|
|
|
|
expect(err).toBeNull();
|
|
|
|
expect(metadata).toBeDefined();
|
|
|
|
expect(metadata).toBeInstanceOf(Object);
|
|
|
|
done();
|
|
|
|
});
|
2018-06-24 22:39:09 +02:00
|
|
|
});
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-27 08:52:52 +02:00
|
|
|
test('should fails on fetch from uplink non existing from registry', async (done) => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
|
|
|
|
|
|
|
// $FlowFixMe
|
|
|
|
storage._syncUplinksMetadata('@verdaccio/404', null, {}, (err, metadata, errors) => {
|
|
|
|
expect(err).not.toBeNull();
|
|
|
|
expect(errors).toBeInstanceOf(Array);
|
|
|
|
expect(errors[0][0].statusCode).toBe(HTTP_STATUS.NOT_FOUND);
|
|
|
|
expect(errors[0][0].message).toMatch(API_ERROR.NOT_PACKAGE_UPLINK);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should fails on fetch from uplink corrupted pkg from registry', async (done) => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
2018-02-19 19:29:14 +01:00
|
|
|
|
2018-06-27 08:52:52 +02:00
|
|
|
// $FlowFixMe
|
|
|
|
storage._syncUplinksMetadata('corrupted-package', null, {}, (err, metadata, errors) => {
|
|
|
|
expect(err).not.toBeNull();
|
|
|
|
expect(errors).toBeInstanceOf(Array);
|
|
|
|
expect(errors[0][0].statusCode).toBe(HTTP_STATUS.INTERNAL_ERROR);
|
|
|
|
expect(errors[0][0].message).toMatch(API_ERROR.BAD_STATUS_CODE);
|
|
|
|
done();
|
|
|
|
});
|
2018-06-24 22:39:09 +02:00
|
|
|
});
|
2019-01-29 11:54:47 +08:00
|
|
|
|
|
|
|
test('should not touch if the package exists and has no uplinks', async (done) => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
2019-01-30 11:21:36 +08:00
|
|
|
const metadataSource = path.join(__dirname, '../partials/metadata');
|
|
|
|
const metadataPath = path.join(storagePath, 'npm_test/package.json');
|
|
|
|
fs.mkdirSync(path.join(storagePath, 'npm_test'));
|
2019-01-29 14:03:04 +08:00
|
|
|
fs.writeFileSync(metadataPath, fs.readFileSync(metadataSource));
|
2019-01-30 11:21:36 +08:00
|
|
|
const metadata = JSON.parse(fs.readFileSync(metadataPath).toString());
|
2019-01-30 11:19:54 +08:00
|
|
|
// $FlowFixMe
|
2019-01-30 11:21:36 +08:00
|
|
|
storage.localStorage.updateVersions = jest.fn(storage.localStorage.updateVersions);
|
2019-01-29 11:54:47 +08:00
|
|
|
storage._syncUplinksMetadata('npm_test', metadata, {}, (err) => {
|
2019-01-30 11:21:36 +08:00
|
|
|
expect(err).toBeNull();
|
|
|
|
expect(storage.localStorage.updateVersions).not.toHaveBeenCalled();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2018-02-19 19:29:14 +01:00
|
|
|
});
|
|
|
|
});
|