2020-08-19 20:27:35 +02:00
|
|
|
import fs from 'fs';
|
2021-10-29 17:33:05 +02:00
|
|
|
import path from 'path';
|
2024-10-20 19:26:36 +02:00
|
|
|
import { describe, expect, test } from 'vitest';
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2022-02-20 18:39:38 +01:00
|
|
|
import { lockFileNext, readFileNext, unlockFileNext } from '../src/index';
|
|
|
|
import { statDir, statFile } from '../src/utils';
|
2020-08-19 20:27:35 +02:00
|
|
|
|
|
|
|
const getFilePath = (filename: string): string => {
|
|
|
|
return path.resolve(__dirname, `assets/${filename}`);
|
|
|
|
};
|
|
|
|
|
|
|
|
const removeTempFile = (filename: string): void => {
|
|
|
|
const filepath = getFilePath(filename);
|
|
|
|
fs.unlink(filepath, (error) => {
|
|
|
|
if (error) {
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('testing locking', () => {
|
|
|
|
describe('lockFile', () => {
|
2022-02-20 18:39:38 +01:00
|
|
|
test('file should be found to be locked', async () => {
|
|
|
|
await lockFileNext(getFilePath('package.json'));
|
|
|
|
removeTempFile('package.json.lock');
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2022-02-20 18:39:38 +01:00
|
|
|
test('file should fail to be found to be locked', async () => {
|
|
|
|
await expect(lockFileNext(getFilePath('package.fail.json'))).rejects.toThrow(
|
|
|
|
'ENOENT: no such file or directory'
|
|
|
|
);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('unlockFile', () => {
|
2022-02-20 18:39:38 +01:00
|
|
|
test('file should to be found to be unLock', async () => {
|
|
|
|
await expect(unlockFileNext(getFilePath('package.json.lock'))).resolves.toBeUndefined();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('statDir', () => {
|
|
|
|
test('error on missing dir', async () => {
|
|
|
|
await expect(statDir(getFilePath('package.json/package.json'))).rejects.toThrow(
|
|
|
|
'is not a directory'
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('statFile', () => {
|
|
|
|
test('error on missing dir', async () => {
|
|
|
|
await expect(statFile(getFilePath(''))).rejects.toThrow('is not a file');
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('readFile', () => {
|
2022-02-20 18:39:38 +01:00
|
|
|
test('read file with no options should to be found to be read it as string', async () => {
|
|
|
|
const data = await readFileNext(getFilePath('package.json'), {});
|
|
|
|
expect(data).toMatchInlineSnapshot(`
|
2022-09-04 11:48:51 +02:00
|
|
|
"{
|
|
|
|
"name": "assets",
|
|
|
|
"version": "0.0.1"
|
|
|
|
}
|
|
|
|
"
|
|
|
|
`);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2022-02-20 18:39:38 +01:00
|
|
|
test('read file with no options should to be found to be read it as object', async () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
const options = {
|
|
|
|
parse: true,
|
|
|
|
};
|
2022-02-20 18:39:38 +01:00
|
|
|
const data = await readFileNext(getFilePath('package.json'), options);
|
|
|
|
expect(data).toMatchInlineSnapshot(`
|
2022-09-04 11:48:51 +02:00
|
|
|
{
|
|
|
|
"name": "assets",
|
|
|
|
"version": "0.0.1",
|
|
|
|
}
|
|
|
|
`);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2022-02-20 18:39:38 +01:00
|
|
|
test('read file with options (parse) should to be not found to be read it', async () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
const options = {
|
|
|
|
parse: true,
|
|
|
|
};
|
2023-10-07 16:23:04 +02:00
|
|
|
await expect(readFileNext(getFilePath('package.fail.json'), options)).rejects.toThrow();
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2022-02-20 18:39:38 +01:00
|
|
|
test('read file with options should be found to be read it and fails to be parsed', async () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
const options = {
|
|
|
|
parse: true,
|
|
|
|
};
|
2023-10-07 16:23:04 +02:00
|
|
|
await expect(readFileNext(getFilePath('wrong.package.json'), options)).rejects.toThrow();
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2022-02-20 18:39:38 +01:00
|
|
|
test('read file with options (parse, lock) should be found to be read it as object', async () => {
|
2020-08-19 20:27:35 +02:00
|
|
|
const options = {
|
|
|
|
parse: true,
|
|
|
|
lock: true,
|
|
|
|
};
|
2022-09-04 11:48:51 +02:00
|
|
|
await expect(readFileNext(getFilePath('package2.json'), options)).resolves
|
|
|
|
.toMatchInlineSnapshot(`
|
|
|
|
{
|
|
|
|
"name": "assets",
|
|
|
|
"version": "0.0.1",
|
|
|
|
}
|
|
|
|
`);
|
2022-02-20 18:39:38 +01:00
|
|
|
removeTempFile('package2.json.lock');
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
2023-10-07 16:23:04 +02:00
|
|
|
test.skip(
|
2020-10-24 22:17:21 +11:00
|
|
|
'read file with options (parse, lock) should be found to be read and ' + 'fails to be parsed',
|
2022-02-20 18:39:38 +01:00
|
|
|
async () => {
|
2020-10-24 22:17:21 +11:00
|
|
|
const options = {
|
|
|
|
parse: true,
|
|
|
|
lock: true,
|
|
|
|
};
|
2022-02-20 18:39:38 +01:00
|
|
|
await expect(readFileNext(getFilePath('wrong.package.json'), options)).rejects.toThrow(
|
|
|
|
'Unexpected token } in JSON at position 44'
|
|
|
|
);
|
|
|
|
removeTempFile('wrong.package.json.lock');
|
2020-10-24 22:17:21 +11:00
|
|
|
}
|
|
|
|
);
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|