forked from PluralFlux/PluralFlux
* refactored async/await for import helper to not also use then/catch * added enum * refactor webhookHelper and tests to not use then/catch * changed docstring * refactoring bot and tests to not use then/catch * refactoring commands.js and tests to not use then/catch * refactoring memberHelper.js and tests to not use then/catch * removing then/catch from messageHelper.test.js * fixed set up for commands tests * edited bot to have top level main function * one more test in commands.js, and removed console.error * fixed typo in webhookHelper * forgot to switch over some tests in bot.test and commands.test * removed console.log from import helper * put console.error in commands * converted utils.js to not use then/catch * tested utils checkImageFormatValidity * removed jest-fetch-mock since it turns out I was just manually mocking it anyway * refactored database to not use then/catch * added dash to commands.js and test to pass * added the remaining webhook tests * changed utils to check for 10MB size not 1MB * removed unnecessary try/catch from utils * Simplify getWebhook to use .find() instead of foreach logic * make memberCommand exit when error occurs with parseMemberCommand * changed commands.js to not have user interaction within the catch * updated console.error message in database.js * made importHelper mock throw error instead of "resolve" error * replaced "pk;" with "pf;" in test * Got rid of unnecessary check for empty message from user (Fluxer doesn't allow this to happen) Removed export of token * getAllMembersInfo checks for fields.length * added default case to memberCommandHandler to throw error if command is not recognized * reversed check for valid proxy (was returning valid if the proxy existed and invalid if it didn't) * pushes e.message instead of full error object to errors array in importHelper * adjusted tests to properly use mockRejectedValue for async rejections * changed getAllMembersInfo map to say `index` not `name` as it actually gets the index of a member and then the member object * adjusted importHelper to properly test throwing of aggregate error * revamped setting of expiration warning (moved to utils and changed logic, wrote tests) --------- Co-authored-by: Aster Fialla <asterfialla@gmail.com>
90 lines
3.2 KiB
JavaScript
90 lines
3.2 KiB
JavaScript
const {enums} = require("../../src/enums");
|
|
|
|
const {utils} = require("../../src/helpers/utils.js");
|
|
|
|
describe('utils', () => {
|
|
|
|
const attachmentUrl = 'oya.png';
|
|
const expirationString = new Date("2026-01-01").toDateString();
|
|
let blob;
|
|
|
|
beforeEach(() => {
|
|
jest.resetModules();
|
|
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().mockRejectedValue(new 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);
|
|
})
|
|
})
|
|
|
|
describe('setExpirationWarning', () => {
|
|
test('sets warning if image Url starts with Fluxer host', () => {
|
|
// Act
|
|
const result = utils.setExpirationWarning(`${enums.misc.FLUXER_ATTACHMENT_URL}${attachmentUrl}`);
|
|
// Assert
|
|
expect(result).toEqual(enums.misc.ATTACHMENT_EXPIRATION_WARNING);
|
|
})
|
|
|
|
test('sets warning if expiration string exists', () => {
|
|
const result = utils.setExpirationWarning(null, expirationString);
|
|
// Assert
|
|
expect(result).toEqual(`${enums.misc.ATTACHMENT_EXPIRATION_WARNING}. Expiration date: *${expirationString}*.`);
|
|
})
|
|
|
|
test('returns null if img url does not start iwth fluxer host and no expiration', () => {
|
|
// Act
|
|
const result = utils.setExpirationWarning(attachmentUrl);
|
|
// Assert
|
|
expect(result).toBeNull();
|
|
})
|
|
})
|
|
|
|
afterEach(() => {
|
|
// restore the spy created with spyOn
|
|
jest.restoreAllMocks();
|
|
});
|
|
}) |