2024-03-20 19:32:04 +01:00
|
|
|
import { mimeTypes, Version, VersionType } from 'src/domain/domain.constant';
|
2023-07-19 16:27:25 +02:00
|
|
|
|
|
|
|
describe('mimeTypes', () => {
|
|
|
|
for (const { mimetype, extension } of [
|
|
|
|
// Please ensure this list is sorted.
|
|
|
|
{ mimetype: 'image/3fr', extension: '.3fr' },
|
|
|
|
{ mimetype: 'image/ari', extension: '.ari' },
|
|
|
|
{ mimetype: 'image/arw', extension: '.arw' },
|
|
|
|
{ mimetype: 'image/avif', extension: '.avif' },
|
2023-11-20 20:47:24 +01:00
|
|
|
{ mimetype: 'image/bmp', extension: '.bmp' },
|
2023-07-19 16:27:25 +02:00
|
|
|
{ mimetype: 'image/cap', extension: '.cap' },
|
|
|
|
{ mimetype: 'image/cin', extension: '.cin' },
|
|
|
|
{ mimetype: 'image/cr2', extension: '.cr2' },
|
|
|
|
{ mimetype: 'image/cr3', extension: '.cr3' },
|
|
|
|
{ mimetype: 'image/crw', extension: '.crw' },
|
|
|
|
{ mimetype: 'image/dcr', extension: '.dcr' },
|
|
|
|
{ mimetype: 'image/dng', extension: '.dng' },
|
|
|
|
{ mimetype: 'image/erf', extension: '.erf' },
|
|
|
|
{ mimetype: 'image/fff', extension: '.fff' },
|
|
|
|
{ mimetype: 'image/gif', extension: '.gif' },
|
|
|
|
{ mimetype: 'image/heic', extension: '.heic' },
|
|
|
|
{ mimetype: 'image/heif', extension: '.heif' },
|
2024-01-18 18:18:56 +01:00
|
|
|
{ mimetype: 'image/hif', extension: '.hif' },
|
2023-07-19 16:27:25 +02:00
|
|
|
{ mimetype: 'image/iiq', extension: '.iiq' },
|
2023-10-06 22:55:20 +02:00
|
|
|
{ mimetype: 'image/jpeg', extension: '.jpe' },
|
2023-07-19 16:27:25 +02:00
|
|
|
{ mimetype: 'image/jpeg', extension: '.jpeg' },
|
|
|
|
{ mimetype: 'image/jpeg', extension: '.jpg' },
|
|
|
|
{ mimetype: 'image/jxl', extension: '.jxl' },
|
|
|
|
{ mimetype: 'image/k25', extension: '.k25' },
|
|
|
|
{ mimetype: 'image/kdc', extension: '.kdc' },
|
|
|
|
{ mimetype: 'image/mrw', extension: '.mrw' },
|
|
|
|
{ mimetype: 'image/nef', extension: '.nef' },
|
|
|
|
{ mimetype: 'image/orf', extension: '.orf' },
|
|
|
|
{ mimetype: 'image/ori', extension: '.ori' },
|
|
|
|
{ mimetype: 'image/pef', extension: '.pef' },
|
|
|
|
{ mimetype: 'image/png', extension: '.png' },
|
2023-09-24 17:03:14 +02:00
|
|
|
{ mimetype: 'image/psd', extension: '.psd' },
|
2023-07-19 16:27:25 +02:00
|
|
|
{ mimetype: 'image/raf', extension: '.raf' },
|
|
|
|
{ mimetype: 'image/raw', extension: '.raw' },
|
|
|
|
{ mimetype: 'image/rwl', extension: '.rwl' },
|
|
|
|
{ mimetype: 'image/sr2', extension: '.sr2' },
|
|
|
|
{ mimetype: 'image/srf', extension: '.srf' },
|
|
|
|
{ mimetype: 'image/srw', extension: '.srw' },
|
2024-03-15 17:02:31 +01:00
|
|
|
{ mimetype: 'image/svg', extension: '.svg' },
|
2023-08-17 17:27:29 +02:00
|
|
|
{ mimetype: 'image/tiff', extension: '.tif' },
|
2023-07-19 16:27:25 +02:00
|
|
|
{ mimetype: 'image/tiff', extension: '.tiff' },
|
|
|
|
{ mimetype: 'image/webp', extension: '.webp' },
|
2023-09-24 17:03:14 +02:00
|
|
|
{ mimetype: 'image/vnd.adobe.photoshop', extension: '.psd' },
|
2023-07-19 16:27:25 +02:00
|
|
|
{ mimetype: 'image/x-adobe-dng', extension: '.dng' },
|
|
|
|
{ mimetype: 'image/x-arriflex-ari', extension: '.ari' },
|
|
|
|
{ mimetype: 'image/x-canon-cr2', extension: '.cr2' },
|
|
|
|
{ mimetype: 'image/x-canon-cr3', extension: '.cr3' },
|
|
|
|
{ mimetype: 'image/x-canon-crw', extension: '.crw' },
|
|
|
|
{ mimetype: 'image/x-epson-erf', extension: '.erf' },
|
|
|
|
{ mimetype: 'image/x-fuji-raf', extension: '.raf' },
|
|
|
|
{ mimetype: 'image/x-hasselblad-3fr', extension: '.3fr' },
|
|
|
|
{ mimetype: 'image/x-hasselblad-fff', extension: '.fff' },
|
|
|
|
{ mimetype: 'image/x-kodak-dcr', extension: '.dcr' },
|
|
|
|
{ mimetype: 'image/x-kodak-k25', extension: '.k25' },
|
|
|
|
{ mimetype: 'image/x-kodak-kdc', extension: '.kdc' },
|
|
|
|
{ mimetype: 'image/x-leica-rwl', extension: '.rwl' },
|
|
|
|
{ mimetype: 'image/x-minolta-mrw', extension: '.mrw' },
|
|
|
|
{ mimetype: 'image/x-nikon-nef', extension: '.nef' },
|
|
|
|
{ mimetype: 'image/x-olympus-orf', extension: '.orf' },
|
|
|
|
{ mimetype: 'image/x-olympus-ori', extension: '.ori' },
|
|
|
|
{ mimetype: 'image/x-panasonic-raw', extension: '.raw' },
|
|
|
|
{ mimetype: 'image/x-pentax-pef', extension: '.pef' },
|
|
|
|
{ mimetype: 'image/x-phantom-cin', extension: '.cin' },
|
|
|
|
{ mimetype: 'image/x-phaseone-cap', extension: '.cap' },
|
|
|
|
{ mimetype: 'image/x-phaseone-iiq', extension: '.iiq' },
|
|
|
|
{ mimetype: 'image/x-samsung-srw', extension: '.srw' },
|
|
|
|
{ mimetype: 'image/x-sigma-x3f', extension: '.x3f' },
|
|
|
|
{ mimetype: 'image/x-sony-arw', extension: '.arw' },
|
|
|
|
{ mimetype: 'image/x-sony-sr2', extension: '.sr2' },
|
|
|
|
{ mimetype: 'image/x-sony-srf', extension: '.srf' },
|
|
|
|
{ mimetype: 'image/x3f', extension: '.x3f' },
|
|
|
|
{ mimetype: 'video/3gpp', extension: '.3gp' },
|
|
|
|
{ mimetype: 'video/avi', extension: '.avi' },
|
|
|
|
{ mimetype: 'video/mp2t', extension: '.m2ts' },
|
|
|
|
{ mimetype: 'video/mp2t', extension: '.mts' },
|
|
|
|
{ mimetype: 'video/mp4', extension: '.mp4' },
|
|
|
|
{ mimetype: 'video/mpeg', extension: '.mpg' },
|
|
|
|
{ mimetype: 'video/msvideo', extension: '.avi' },
|
|
|
|
{ mimetype: 'video/quicktime', extension: '.mov' },
|
|
|
|
{ mimetype: 'video/vnd.avi', extension: '.avi' },
|
|
|
|
{ mimetype: 'video/webm', extension: '.webm' },
|
|
|
|
{ mimetype: 'video/x-flv', extension: '.flv' },
|
|
|
|
{ mimetype: 'video/x-matroska', extension: '.mkv' },
|
|
|
|
{ mimetype: 'video/x-ms-wmv', extension: '.wmv' },
|
|
|
|
{ mimetype: 'video/x-msvideo', extension: '.avi' },
|
|
|
|
]) {
|
2023-08-17 17:27:29 +02:00
|
|
|
it(`should map ${extension} to ${mimetype}`, () => {
|
2023-07-19 16:27:25 +02:00
|
|
|
expect({ ...mimeTypes.image, ...mimeTypes.video }[extension]).toContain(mimetype);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('profile', () => {
|
|
|
|
it('should contain only lowercase mime types', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.profile);
|
|
|
|
expect(keys).toEqual(keys.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
|
|
|
|
const values = Object.values(mimeTypes.profile).flat();
|
|
|
|
expect(values).toEqual(values.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be a sorted list', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.profile);
|
|
|
|
// TODO: use toSorted in NodeJS 20.
|
|
|
|
expect(keys).toEqual([...keys].sort());
|
|
|
|
});
|
|
|
|
|
2024-02-02 04:18:00 +01:00
|
|
|
for (const [extension, v] of Object.entries(mimeTypes.profile)) {
|
|
|
|
it(`should lookup ${extension}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${extension}`)).toEqual(v[0]);
|
2023-07-19 16:27:25 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('image', () => {
|
|
|
|
it('should contain only lowercase mime types', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.image);
|
|
|
|
expect(keys).toEqual(keys.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
|
|
|
|
const values = Object.values(mimeTypes.image).flat();
|
|
|
|
expect(values).toEqual(values.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be a sorted list', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.image);
|
|
|
|
// TODO: use toSorted in NodeJS 20.
|
|
|
|
expect(keys).toEqual([...keys].sort());
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should contain only image mime types', () => {
|
|
|
|
const values = Object.values(mimeTypes.image).flat();
|
|
|
|
expect(values).toEqual(values.filter((mimeType) => mimeType.startsWith('image/')));
|
|
|
|
});
|
|
|
|
|
2024-02-02 04:18:00 +01:00
|
|
|
for (const [extension, v] of Object.entries(mimeTypes.image)) {
|
|
|
|
it(`should lookup ${extension}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${extension}`)).toEqual(v[0]);
|
2023-07-19 16:27:25 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('video', () => {
|
|
|
|
it('should contain only lowercase mime types', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.video);
|
|
|
|
expect(keys).toEqual(keys.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
|
|
|
|
const values = Object.values(mimeTypes.video).flat();
|
|
|
|
expect(values).toEqual(values.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be a sorted list', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.video);
|
|
|
|
// TODO: use toSorted in NodeJS 20.
|
|
|
|
expect(keys).toEqual([...keys].sort());
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should contain only video mime types', () => {
|
|
|
|
const values = Object.values(mimeTypes.video).flat();
|
|
|
|
expect(values).toEqual(values.filter((mimeType) => mimeType.startsWith('video/')));
|
|
|
|
});
|
|
|
|
|
2024-02-02 04:18:00 +01:00
|
|
|
for (const [extension, v] of Object.entries(mimeTypes.video)) {
|
|
|
|
it(`should lookup ${extension}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${extension}`)).toEqual(v[0]);
|
2023-07-19 16:27:25 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('sidecar', () => {
|
|
|
|
it('should contain only lowercase mime types', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.sidecar);
|
|
|
|
expect(keys).toEqual(keys.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
|
|
|
|
const values = Object.values(mimeTypes.sidecar).flat();
|
|
|
|
expect(values).toEqual(values.map((mimeType) => mimeType.toLowerCase()));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should be a sorted list', () => {
|
|
|
|
const keys = Object.keys(mimeTypes.sidecar);
|
|
|
|
// TODO: use toSorted in NodeJS 20.
|
|
|
|
expect(keys).toEqual([...keys].sort());
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should contain only xml mime types', () => {
|
|
|
|
expect(Object.values(mimeTypes.sidecar).flat()).toEqual(['application/xml', 'text/xml']);
|
|
|
|
});
|
|
|
|
|
2024-02-02 04:18:00 +01:00
|
|
|
for (const [extension, v] of Object.entries(mimeTypes.sidecar)) {
|
|
|
|
it(`should lookup ${extension}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`it.${extension}`)).toEqual(v[0]);
|
2023-10-24 17:05:42 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2024-02-07 03:46:38 +01:00
|
|
|
describe('Version', () => {
|
2023-12-21 17:06:26 +01:00
|
|
|
const tests = [
|
2024-02-07 03:46:38 +01:00
|
|
|
{ this: new Version(0, 0, 1), other: new Version(0, 0, 0), compare: 1, type: VersionType.PATCH },
|
|
|
|
{ this: new Version(0, 1, 0), other: new Version(0, 0, 0), compare: 1, type: VersionType.MINOR },
|
|
|
|
{ this: new Version(1, 0, 0), other: new Version(0, 0, 0), compare: 1, type: VersionType.MAJOR },
|
|
|
|
{ this: new Version(0, 0, 0), other: new Version(0, 0, 1), compare: -1, type: VersionType.PATCH },
|
|
|
|
{ this: new Version(0, 0, 0), other: new Version(0, 1, 0), compare: -1, type: VersionType.MINOR },
|
|
|
|
{ this: new Version(0, 0, 0), other: new Version(1, 0, 0), compare: -1, type: VersionType.MAJOR },
|
|
|
|
{ this: new Version(0, 0, 0), other: new Version(0, 0, 0), compare: 0, type: VersionType.EQUAL },
|
|
|
|
{ this: new Version(0, 0, 1), other: new Version(0, 0, 1), compare: 0, type: VersionType.EQUAL },
|
|
|
|
{ this: new Version(0, 1, 0), other: new Version(0, 1, 0), compare: 0, type: VersionType.EQUAL },
|
|
|
|
{ this: new Version(1, 0, 0), other: new Version(1, 0, 0), compare: 0, type: VersionType.EQUAL },
|
|
|
|
{ this: new Version(1, 0), other: new Version(1, 0, 0), compare: 0, type: VersionType.EQUAL },
|
|
|
|
{ this: new Version(1, 0), other: new Version(1, 0, 1), compare: -1, type: VersionType.PATCH },
|
|
|
|
{ this: new Version(1, 1), other: new Version(1, 0, 1), compare: 1, type: VersionType.MINOR },
|
|
|
|
{ this: new Version(1), other: new Version(1, 0, 0), compare: 0, type: VersionType.EQUAL },
|
|
|
|
{ this: new Version(1), other: new Version(1, 0, 1), compare: -1, type: VersionType.PATCH },
|
2023-12-21 17:06:26 +01:00
|
|
|
];
|
2023-10-24 17:05:42 +02:00
|
|
|
|
2023-12-21 17:06:26 +01:00
|
|
|
describe('isOlderThan', () => {
|
2024-02-07 03:46:38 +01:00
|
|
|
for (const { this: thisVersion, other: otherVersion, compare, type } of tests) {
|
|
|
|
const expected = compare < 0 ? type : VersionType.EQUAL;
|
|
|
|
it(`should return '${expected}' when comparing ${thisVersion} to ${otherVersion}`, () => {
|
|
|
|
expect(thisVersion.isOlderThan(otherVersion)).toEqual(expected);
|
2023-12-21 17:06:26 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2023-10-24 17:05:42 +02:00
|
|
|
|
2023-12-21 17:06:26 +01:00
|
|
|
describe('isEqual', () => {
|
2024-02-07 03:46:38 +01:00
|
|
|
for (const { this: thisVersion, other: otherVersion, compare } of tests) {
|
|
|
|
const bool = compare === 0;
|
2023-12-21 17:06:26 +01:00
|
|
|
it(`should return ${bool} when comparing ${thisVersion} to ${otherVersion}`, () => {
|
|
|
|
expect(thisVersion.isEqual(otherVersion)).toEqual(bool);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2023-10-24 17:05:42 +02:00
|
|
|
|
2023-12-21 17:06:26 +01:00
|
|
|
describe('isNewerThan', () => {
|
2024-02-07 03:46:38 +01:00
|
|
|
for (const { this: thisVersion, other: otherVersion, compare, type } of tests) {
|
|
|
|
const expected = compare > 0 ? type : VersionType.EQUAL;
|
|
|
|
it(`should return ${expected} when comparing ${thisVersion} to ${otherVersion}`, () => {
|
|
|
|
expect(thisVersion.isNewerThan(otherVersion)).toEqual(expected);
|
2023-12-21 17:06:26 +01:00
|
|
|
});
|
|
|
|
}
|
2023-10-24 17:05:42 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('fromString', () => {
|
|
|
|
const tests = [
|
2023-12-21 17:06:26 +01:00
|
|
|
{ scenario: 'leading v', value: 'v1.72.2', expected: new Version(1, 72, 2) },
|
|
|
|
{ scenario: 'uppercase v', value: 'V1.72.2', expected: new Version(1, 72, 2) },
|
|
|
|
{ scenario: 'missing v', value: '1.72.2', expected: new Version(1, 72, 2) },
|
|
|
|
{ scenario: 'large patch', value: '1.72.123', expected: new Version(1, 72, 123) },
|
|
|
|
{ scenario: 'large minor', value: '1.123.0', expected: new Version(1, 123, 0) },
|
|
|
|
{ scenario: 'large major', value: '123.0.0', expected: new Version(123, 0, 0) },
|
|
|
|
{ scenario: 'major bump', value: 'v2.0.0', expected: new Version(2, 0, 0) },
|
|
|
|
{ scenario: 'has dash', value: '14.10-1', expected: new Version(14, 10, 1) },
|
|
|
|
{ scenario: 'missing patch', value: '14.10', expected: new Version(14, 10, 0) },
|
|
|
|
{ scenario: 'only major', value: '14', expected: new Version(14, 0, 0) },
|
2023-10-24 17:05:42 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
for (const { scenario, value, expected } of tests) {
|
|
|
|
it(`should correctly parse ${scenario}`, () => {
|
2023-12-21 17:06:26 +01:00
|
|
|
const actual = Version.fromString(value);
|
2023-10-24 17:05:42 +02:00
|
|
|
expect(actual.major).toEqual(expected.major);
|
|
|
|
expect(actual.minor).toEqual(expected.minor);
|
|
|
|
expect(actual.patch).toEqual(expected.patch);
|
2023-07-19 16:27:25 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|