2020-08-19 20:27:35 +02:00
|
|
|
import fs from 'fs';
|
2021-10-29 17:33:05 +02:00
|
|
|
import path from 'path';
|
2022-07-29 20:51:45 +02:00
|
|
|
import { Readable } from 'stream';
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
import { fileUtils } from '@verdaccio/core';
|
|
|
|
import { createTempFolder } from '@verdaccio/test-helper';
|
|
|
|
import { ILocalPackageManager, Logger, Manifest } from '@verdaccio/types';
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
import LocalDriver from '../src/local-fs';
|
2020-08-19 20:27:35 +02:00
|
|
|
import pkg from './__fixtures__/pkg';
|
|
|
|
|
|
|
|
let localTempStorage: string;
|
2022-07-29 20:51:45 +02:00
|
|
|
|
|
|
|
// returns a promise which resolves true if file exists:
|
|
|
|
function checkFileExists(filepath) {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
fs.access(filepath, fs.constants.F_OK, (error) => {
|
|
|
|
resolve(!error);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2021-10-03 09:21:01 -03:00
|
|
|
const logger: Logger = {
|
|
|
|
error: jest.fn(),
|
|
|
|
info: jest.fn(),
|
|
|
|
debug: jest.fn(),
|
|
|
|
child: jest.fn(),
|
|
|
|
warn: jest.fn(),
|
|
|
|
http: jest.fn(),
|
|
|
|
trace: jest.fn(),
|
|
|
|
};
|
|
|
|
|
2020-08-19 20:27:35 +02:00
|
|
|
describe('Local FS test', () => {
|
2021-09-08 19:06:37 +02:00
|
|
|
let tmpFolder;
|
2022-07-29 20:51:45 +02:00
|
|
|
beforeEach(async () => {
|
|
|
|
tmpFolder = await fileUtils.createTempFolder('local-fs');
|
|
|
|
localTempStorage = path.join(tmpFolder, './_storage');
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
describe.skip('deletePackage() group', () => {
|
|
|
|
test('should delete a package', async () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
const localFs = new LocalDriver(path.join(localTempStorage, 'createPackage'), logger);
|
2022-07-29 20:51:45 +02:00
|
|
|
await localFs.createPackag('createPackage', pkg as unknown as Manifest);
|
|
|
|
// verdaccio removes the package.json instead the package name
|
|
|
|
await localFs.deletePackage('package.json');
|
|
|
|
// verify if the `package.json` does not exist anymore
|
|
|
|
// note: the folder still remains
|
|
|
|
await expect(checkFileExists(localFs._getStorage('package.json'))).resolves.toBeFalsy();
|
|
|
|
});
|
|
|
|
test('should fails on delete a package', async () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
const localFs = new LocalDriver(path.join(localTempStorage, 'createPackage'), logger);
|
2022-07-29 20:51:45 +02:00
|
|
|
// verdaccio removes the package.json instead the package name
|
|
|
|
await expect(localFs.deletePackage('package.json')).rejects.toThrow('ENOENT');
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('removePackage() group', () => {
|
|
|
|
beforeEach(() => {
|
2021-05-02 10:52:12 +03:00
|
|
|
fs.mkdirSync(path.join(localTempStorage, '_toDelete'), { recursive: true });
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2021-09-08 19:06:37 +02:00
|
|
|
test('should successfully remove the package', async () => {
|
2020-09-17 06:48:16 +02:00
|
|
|
const localFs: ILocalPackageManager = new LocalDriver(
|
|
|
|
path.join(localTempStorage, '_toDelete'),
|
|
|
|
logger
|
|
|
|
);
|
2021-09-08 19:06:37 +02:00
|
|
|
|
|
|
|
await expect(localFs.removePackage()).resolves.toBeUndefined();
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2021-09-08 19:06:37 +02:00
|
|
|
test('removePackage() fails', async () => {
|
2020-09-17 06:48:16 +02:00
|
|
|
const localFs: ILocalPackageManager = new LocalDriver(
|
|
|
|
path.join(localTempStorage, '_toDelete_fake'),
|
|
|
|
logger
|
|
|
|
);
|
2021-09-08 19:06:37 +02:00
|
|
|
await expect(localFs.removePackage()).rejects.toThrow(/ENOENT/);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
describe('writeTarballNext', () => {
|
|
|
|
test('should write a tarball', (done) => {
|
|
|
|
const abort = new AbortController();
|
|
|
|
const tmp = createTempFolder('local-fs-write-tarball');
|
|
|
|
const localFs = new LocalDriver(tmp, logger);
|
|
|
|
const readableStream = Readable.from('foooo');
|
|
|
|
// TODO: verify file exist
|
|
|
|
localFs.writeTarball('juan-1.0.0.tgz', { signal: abort.signal }).then((stream) => {
|
|
|
|
stream.on('finish', () => {
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
readableStream.pipe(stream);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
describe('readTarballNext', () => {
|
|
|
|
test('should read a tarball', (done) => {
|
|
|
|
const abort = new AbortController();
|
|
|
|
const localFs = new LocalDriver(
|
|
|
|
path.join(__dirname, '__fixtures__/readme-test-next'),
|
2020-09-17 06:48:16 +02:00
|
|
|
logger
|
|
|
|
);
|
2022-07-29 20:51:45 +02:00
|
|
|
localFs.readTarball('test-readme-0.0.0.tgz', { signal: abort.signal }).then((stream) => {
|
|
|
|
stream.on('data', (data) => {
|
|
|
|
expect(data.length).toEqual(352);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
2022-07-29 20:51:45 +02:00
|
|
|
stream.on('end', () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2022-07-29 20:51:45 +02:00
|
|
|
});
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
test('should aboort read a tarball', (done) => {
|
|
|
|
const abort = new AbortController();
|
|
|
|
const localFs = new LocalDriver(
|
|
|
|
path.join(__dirname, '__fixtures__/readme-test-next'),
|
|
|
|
logger
|
|
|
|
);
|
|
|
|
localFs.readTarball('test-readme-0.0.0.tgz', { signal: abort.signal }).then((stream) => {
|
|
|
|
stream.on('error', (error: any) => {
|
|
|
|
expect(error.code).toEqual('ABORT_ERR');
|
2020-08-19 20:27:35 +02:00
|
|
|
done();
|
|
|
|
});
|
2022-07-29 20:51:45 +02:00
|
|
|
abort.abort();
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
2022-07-29 20:51:45 +02:00
|
|
|
});
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
test('fails on read a tarball doex not exist', (done) => {
|
|
|
|
const abort = new AbortController();
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
const localFs = new LocalDriver(
|
|
|
|
path.join(__dirname, '__fixtures__/readme-test-next'),
|
|
|
|
logger
|
|
|
|
);
|
|
|
|
localFs.readTarball('does-not-exist-0.0.0.tgz', { signal: abort.signal }).then((stream) => {
|
|
|
|
stream.on('error', (error: any) => {
|
|
|
|
expect(error.code).toEqual('ENOENT');
|
2020-08-19 20:27:35 +02:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2022-07-29 20:51:45 +02:00
|
|
|
});
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
test('should return content-length', (done) => {
|
|
|
|
const localFs = new LocalDriver(
|
|
|
|
path.join(__dirname, '__fixtures__/readme-test-next'),
|
|
|
|
logger
|
|
|
|
);
|
|
|
|
const abort = new AbortController();
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-07-29 20:51:45 +02:00
|
|
|
localFs.readTarball('test-readme-0.0.0.tgz', { signal: abort.signal }).then((stream) => {
|
|
|
|
stream.on('data', (data) => {
|
|
|
|
expect(data.length).toEqual(352);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
2022-07-29 20:51:45 +02:00
|
|
|
stream.on('content-length', (content) => {
|
|
|
|
expect(content).toEqual(352);
|
2020-08-19 20:27:35 +02:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|