tested utils checkImageFormatValidity

This commit is contained in:
Aster Fialla
2026-02-24 18:03:55 -05:00
parent 34cb8f3cdb
commit cdf5c6e537
2 changed files with 57 additions and 6 deletions

View File

@@ -15,6 +15,7 @@ u.debounce = function(func, delay) {
* *
* @async * @async
* @param {string} imageUrl - The url of the image * @param {string} imageUrl - The url of the image
* @returns {bool} - Whether the image is in a valid format
* @throws {Error} When loading the profile picture from a URL doesn't work, or it fails requirements. * @throws {Error} When loading the profile picture from a URL doesn't work, or it fails requirements.
*/ */
u.checkImageFormatValidity = async function (imageUrl) { u.checkImageFormatValidity = async function (imageUrl) {
@@ -24,15 +25,17 @@ u.checkImageFormatValidity = async function (imageUrl) {
response = await fetch(imageUrl); response = await fetch(imageUrl);
} }
catch(e) { catch(e) {
throw new Error(`${enums.err.CANNOT_FETCH_RESOURCE}: {error.message}`); throw new Error(`${enums.err.PROPIC_CANNOT_LOAD}: ${e.message}`);
} }
try { try {
blobFile = response.blob(); blobFile = await response.blob();
if (blobFile.size > 1000000 || !acceptableImages.includes(blobFile.type)) throw new Error(enums.err.PROPIC_FAILS_REQUIREMENTS); if (blobFile.size > 1000000 || !acceptableImages.includes(blobFile.type)) throw new Error(enums.err.PROPIC_FAILS_REQUIREMENTS);
return true;
} }
catch(error) { catch(error) {
throw new Error(`${enums.err.PROPIC_CANNOT_LOAD}: ${error.message}`); throw new Error(error.message);
} }
} }

View File

@@ -1,15 +1,63 @@
const {enums} = require("../../src/enums"); const {enums} = require("../../src/enums");
const fetchMock = require('jest-fetch-mock');
fetchMock.enableMocks();
const {utils} = require("../../src/helpers/utils.js"); const {utils} = require("../../src/helpers/utils.js");
describe('utils', () => { describe('utils', () => {
const attachmentUrl = 'oya.png';
let blob;
beforeEach(() => { beforeEach(() => {
jest.resetModules(); jest.resetModules();
jest.clearAllMocks(); jest.clearAllMocks();
blob = new Blob([JSON.stringify({attachmentUrl: attachmentUrl})], {type: 'image/png'});
global.fetch = jest.fn(() =>
Promise.resolve({
blob: () => Promise.resolve(blob),
})
);
})
describe('checkImageFormatValidity', () => {
test('calls fetch with imageUrl and returns true if no errors', async() => {
// Act
const res = await utils.checkImageFormatValidity(attachmentUrl);
// Assert
expect(res).toBe(true);
expect(fetch).toHaveBeenCalledTimes(1);
expect(fetch).toHaveBeenCalledWith(attachmentUrl);
})
test('throws error if fetch returns error', async() => {
// Arrange
global.fetch = jest.fn().mockImplementation(() =>{throw Error('error');});
// Act & Assert
await expect(utils.checkImageFormatValidity(attachmentUrl)).rejects.toThrow(`${enums.err.PROPIC_CANNOT_LOAD}: error`);
})
test('throws error if blob returns error', async() => {
// Arrange
global.fetch = jest.fn(() =>
Promise.resolve({
blob: () => Promise.reject(new Error('error'))
}))
// Act & Assert
await expect(utils.checkImageFormatValidity(attachmentUrl)).rejects.toThrow('error');
})
test('throws error if blob in wrong format', async() => {
// Arrange
blob = new Blob([JSON.stringify({attachmentUrl})], {type: 'text/html'});
global.fetch = jest.fn(() =>
Promise.resolve({
blob: () => Promise.resolve(blob),
})
);
// Act & Assert
await expect(utils.checkImageFormatValidity(attachmentUrl)).rejects.toThrow(enums.err.PROPIC_FAILS_REQUIREMENTS);
})
}) })
afterEach(() => { afterEach(() => {