2018-02-19 13:29:14 -05:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import _ from 'lodash';
|
2018-06-28 01:26:07 -05:00
|
|
|
import path from 'path';
|
2019-01-28 22:54:47 -05:00
|
|
|
import fs from 'fs';
|
|
|
|
import rimraf from 'rimraf';
|
2018-02-19 13:29:14 -05:00
|
|
|
// $FlowFixMe
|
2018-06-17 06:34:59 -05: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 13:29:14 -05:00
|
|
|
|
2018-02-26 15:28:09 -05:00
|
|
|
import type {Config} from '@verdaccio/types';
|
2018-06-17 06:34:59 -05:00
|
|
|
import type {IStorageHandler} from '../../../types/index';
|
2018-06-27 01:52:52 -05:00
|
|
|
import {API_ERROR, HTTP_STATUS} from '../../../src/lib/constants';
|
2018-06-24 15:39:09 -05:00
|
|
|
import {mockServer} from './mock';
|
|
|
|
import {DOMAIN_SERVERS} from '../../functional/config.functional';
|
2018-02-19 13:29:14 -05:00
|
|
|
|
|
|
|
setup(configExample.logs);
|
|
|
|
|
2019-01-28 22:54:47 -05:00
|
|
|
const storagePath = path.join(__dirname, '../partials/store/test-storage-store.spec');
|
2018-06-24 15:39:09 -05:00
|
|
|
const mockServerPort: number = 55548;
|
2018-06-27 01:52:52 -05:00
|
|
|
const generateStorage = async function(port = mockServerPort, configDefault = configExample) {
|
|
|
|
const storageConfig = _.clone(configDefault);
|
2018-02-19 13:29:14 -05:00
|
|
|
storageConfig.self_path = __dirname;
|
2019-01-28 22:54:47 -05:00
|
|
|
storageConfig.storage = storagePath;
|
2018-06-24 15:39:09 -05:00
|
|
|
storageConfig.uplinks = {
|
|
|
|
npmjs: {
|
|
|
|
url: `http://${DOMAIN_SERVERS}:${port}`
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const config: Config = new AppConfig(storageConfig);
|
2018-04-21 11:36:06 -05:00
|
|
|
const store: IStorageHandler = new Storage(config);
|
|
|
|
await store.init(config);
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2018-06-24 15:39:09 -05:00
|
|
|
return store;
|
2018-02-19 13:29:14 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
describe('StorageTest', () => {
|
2018-06-24 15:39:09 -05:00
|
|
|
let mockRegistry;
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2019-01-28 22:54:47 -05:00
|
|
|
beforeAll(done => {
|
|
|
|
rimraf(storagePath, async () => {
|
|
|
|
mockRegistry = await mockServer(mockServerPort).init();
|
|
|
|
done()
|
|
|
|
})
|
2018-06-24 15:39:09 -05:00
|
|
|
});
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2018-06-24 15:39:09 -05:00
|
|
|
afterAll(function(done) {
|
|
|
|
mockRegistry[0].stop();
|
|
|
|
done();
|
|
|
|
});
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2018-06-24 15:39:09 -05:00
|
|
|
test('should be defined', async () => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
2018-02-19 13:29:14 -05:00
|
|
|
|
|
|
|
expect(storage).toBeDefined();
|
2018-06-24 15:39:09 -05:00
|
|
|
});
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2018-06-27 01:52:52 -05:00
|
|
|
describe('test _syncUplinksMetadata', () => {
|
|
|
|
test('should fetch from uplink jquery metadata from registry', async (done) => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2018-06-27 01:52:52 -05:00
|
|
|
// $FlowFixMe
|
|
|
|
storage._syncUplinksMetadata('jquery', null, {}, (err, metadata, errors) => {
|
|
|
|
expect(err).toBeNull();
|
|
|
|
expect(metadata).toBeDefined();
|
|
|
|
expect(metadata).toBeInstanceOf(Object);
|
|
|
|
done();
|
|
|
|
});
|
2018-06-24 15:39:09 -05:00
|
|
|
});
|
2018-02-19 13:29:14 -05:00
|
|
|
|
2018-06-27 01:52:52 -05: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 13:29:14 -05:00
|
|
|
|
2018-06-27 01:52:52 -05: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 15:39:09 -05:00
|
|
|
});
|
2019-01-28 22:54:47 -05:00
|
|
|
|
|
|
|
test('should not touch if the package exists and has no uplinks', async (done) => {
|
|
|
|
const storage: IStorageHandler = await generateStorage();
|
|
|
|
const metadataPath = path.join(storagePath, 'npm_test/package.json')
|
|
|
|
fs.mkdirSync(path.join(storagePath, 'npm_test'))
|
|
|
|
fs.copyFileSync(path.join(__dirname, '../partials/metadata'), metadataPath)
|
|
|
|
const metadata = JSON.parse(fs.readFileSync(metadataPath).toString())
|
|
|
|
const prevStat = fs.statSync(metadataPath)
|
|
|
|
storage._syncUplinksMetadata('npm_test', metadata, {}, (err) => {
|
|
|
|
expect(err).toBeFalsy()
|
|
|
|
const nextStat = fs.statSync(metadataPath)
|
|
|
|
expect(nextStat).toEqual(prevStat)
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
})
|
2018-02-19 13:29:14 -05:00
|
|
|
});
|
|
|
|
});
|