2023-07-19 16:27:25 +02:00
|
|
|
import { mimeTypes } from '@app/domain';
|
|
|
|
|
|
|
|
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' },
|
|
|
|
{ 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' },
|
|
|
|
{ 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' },
|
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());
|
|
|
|
});
|
|
|
|
|
|
|
|
for (const [ext, v] of Object.entries(mimeTypes.profile)) {
|
|
|
|
it(`should lookup ${ext}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${ext}`)).toEqual(v[0]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
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/')));
|
|
|
|
});
|
|
|
|
|
|
|
|
for (const [ext, v] of Object.entries(mimeTypes.image)) {
|
|
|
|
it(`should lookup ${ext}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${ext}`)).toEqual(v[0]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
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/')));
|
|
|
|
});
|
|
|
|
|
|
|
|
for (const [ext, v] of Object.entries(mimeTypes.video)) {
|
|
|
|
it(`should lookup ${ext}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${ext}`)).toEqual(v[0]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
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']);
|
|
|
|
});
|
|
|
|
|
|
|
|
for (const [ext, v] of Object.entries(mimeTypes.sidecar)) {
|
|
|
|
it(`should lookup ${ext}`, () => {
|
|
|
|
expect(mimeTypes.lookup(`test.${ext}`)).toEqual(v[0]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|