mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-02 12:47:41 +02:00
71efff6827
* Update eslint config * Applied linter to lib * Applied eslint config to CliClient/app * Removed prettier due to https://github.com/prettier/prettier/pull/4765 * First pass on test units * Applied linter config to test units * Applied eslint config to clipper * Applied to plugin dir * Applied to root of ElectronClient * Applied on RN root * Applied on CLI root * Applied on Clipper root * Applied config to tools * test hook * test hook * test hook * Added pre-commit hook * Applied rule no-trailing-spaces * Make sure root packages are installed when installing sub-dir * Added doc
103 lines
3.5 KiB
JavaScript
103 lines
3.5 KiB
JavaScript
/* eslint-disable no-unused-vars */
|
|
|
|
require('app-module-path').addPath(__dirname);
|
|
|
|
const { extractExecutablePath, quotePath, unquotePath, friendlySafeFilename, toFileProtocolPath} = require('lib/path-utils.js');
|
|
const { fileContentEqual, setupDatabase, setupDatabaseAndSynchronizer, db, synchronizer, fileApi, sleep, clearDatabase, switchClient, syncTargetId, objectsEqual, checkThrowAsync } = require('test-utils.js');
|
|
|
|
process.on('unhandledRejection', (reason, p) => {
|
|
console.log('Unhandled Rejection at: Promise', p, 'reason:', reason);
|
|
});
|
|
|
|
describe('pathUtils', function() {
|
|
|
|
beforeEach(async (done) => {
|
|
done();
|
|
});
|
|
|
|
it('should create friendly safe filename', async (done) => {
|
|
const testCases = [
|
|
['生活', '生活'],
|
|
['not/good', 'not_good'],
|
|
['really/not/good', 'really_not_good'],
|
|
['con', '___'],
|
|
['no space at the end ', 'no space at the end'],
|
|
['nor dots...', 'nor dots'],
|
|
[' no space before either', 'no space before either'],
|
|
['thatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylong', 'thatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylongthatsreallylong'],
|
|
];
|
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
|
const t = testCases[i];
|
|
expect(friendlySafeFilename(t[0])).toBe(t[1]);
|
|
}
|
|
|
|
expect(!!friendlySafeFilename('')).toBe(true);
|
|
expect(!!friendlySafeFilename('...')).toBe(true);
|
|
|
|
done();
|
|
});
|
|
|
|
it('should quote and unquote paths', async (done) => {
|
|
const testCases = [
|
|
['', ''],
|
|
['/my/path', '/my/path'],
|
|
['/my/path with spaces', '"/my/path with spaces"'],
|
|
['/my/weird"path', '"/my/weird\\"path"'],
|
|
['c:\\Windows\\test.dll', 'c:\\Windows\\test.dll'],
|
|
['c:\\Windows\\test test.dll', '"c:\\Windows\\test test.dll"'],
|
|
];
|
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
|
const t = testCases[i];
|
|
expect(quotePath(t[0])).toBe(t[1]);
|
|
expect(unquotePath(quotePath(t[0]))).toBe(t[0]);
|
|
}
|
|
|
|
done();
|
|
});
|
|
|
|
it('should extract executable path from command', async (done) => {
|
|
const testCases = [
|
|
['', ''],
|
|
['/my/cmd -some -args', '/my/cmd'],
|
|
['"/my/cmd" -some -args', '"/my/cmd"'],
|
|
['"/my/cmd"', '"/my/cmd"'],
|
|
['"/my/cmd and space" -some -flags', '"/my/cmd and space"'],
|
|
['"" -some -flags', '""'],
|
|
];
|
|
|
|
for (let i = 0; i < testCases.length; i++) {
|
|
const t = testCases[i];
|
|
expect(extractExecutablePath(t[0])).toBe(t[1]);
|
|
}
|
|
|
|
done();
|
|
});
|
|
|
|
it('should create correct fileURL syntax', async (done) => {
|
|
const testCases_win32 = [
|
|
['C:\\handle\\space test', 'file:///C:/handle/space+test'],
|
|
['C:\\escapeplus\\+', 'file:///C:/escapeplus/%2B'],
|
|
['C:\\handle\\single quote\'', 'file:///C:/handle/single+quote%27'],
|
|
];
|
|
const testCases_unixlike = [
|
|
['/handle/space test', 'file:///handle/space+test'],
|
|
['/escapeplus/+', 'file:///escapeplus/%2B'],
|
|
['/handle/single quote\'', 'file:///handle/single+quote%27'],
|
|
];
|
|
|
|
for (let i = 0; i < testCases_win32.length; i++) {
|
|
const t = testCases_win32[i];
|
|
expect(toFileProtocolPath(t[0], 'win32')).toBe(t[1]);
|
|
}
|
|
for (let i = 0; i < testCases_unixlike.length; i++) {
|
|
const t = testCases_unixlike[i];
|
|
expect(toFileProtocolPath(t[0], 'linux')).toBe(t[1]);
|
|
}
|
|
|
|
done();
|
|
});
|
|
|
|
});
|