forked from PluralFlux/PluralFlux
Tests are mostly complete (though some are failing -- to be fixed in the async/await refactor. Also refactored, fixed bugs found while testing, and added ability to type `pf;m` instead of `pf;member`. --------- Co-authored-by: Aster Fialla <asterfialla@gmail.com>
183 lines
7.0 KiB
JavaScript
183 lines
7.0 KiB
JavaScript
import {enums} from "../src/enums.js";
|
|
|
|
jest.mock("../src/helpers/messageHelper.js", () => {
|
|
return {
|
|
messageHelper: {
|
|
returnBufferFromText: jest.fn(),
|
|
prefix: 'pf;'
|
|
}
|
|
}
|
|
})
|
|
|
|
jest.mock('../src/helpers/memberHelper.js', () => {
|
|
return {
|
|
memberHelper: {
|
|
parseMemberCommand: jest.fn()
|
|
}
|
|
}
|
|
})
|
|
|
|
jest.mock('../src/helpers/importHelper.js', () => {
|
|
return {
|
|
importHelper: {
|
|
pluralKitImport: jest.fn()
|
|
}
|
|
}
|
|
})
|
|
jest.mock('console', () => {
|
|
return {error: jest.fn()}
|
|
})
|
|
|
|
import {messageHelper, prefix} from "../src/helpers/messageHelper.js";
|
|
|
|
import {memberHelper} from "../src/helpers/memberHelper.js";
|
|
import {EmbedBuilder} from "@fluxerjs/core";
|
|
import {importHelper} from "../src/helpers/importHelper.js";
|
|
import {commands} from "../src/commands.js";
|
|
|
|
|
|
describe('commands', () => {
|
|
const authorId = '123';
|
|
const discriminator = '123';
|
|
const username = 'somePerson'
|
|
const attachmentUrl = 'oya.png';
|
|
const attachmentExpiration = new Date('2026-01-01').toDateString();
|
|
const message = {
|
|
author: {
|
|
username: username,
|
|
id: authorId,
|
|
discriminator: discriminator,
|
|
},
|
|
attachments: {
|
|
size: 1,
|
|
first: jest.fn().mockImplementation(() => ({
|
|
expires_at: attachmentExpiration,
|
|
url: attachmentUrl
|
|
}))
|
|
},
|
|
reply: jest.fn().mockResolvedValue(),
|
|
}
|
|
const args = ['new']
|
|
|
|
beforeEach(() => {
|
|
|
|
jest.resetModules();
|
|
jest.clearAllMocks();
|
|
})
|
|
|
|
describe('memberCommand', () => {
|
|
|
|
|
|
test('calls parseMemberCommand with the correct arguments', () => {
|
|
// Arrange
|
|
memberHelper.parseMemberCommand = jest.fn().mockResolvedValue("parsed command");
|
|
// Act
|
|
return commands.memberCommand(message, args).then(() => {
|
|
expect(memberHelper.parseMemberCommand).toHaveBeenCalledTimes(1);
|
|
expect(memberHelper.parseMemberCommand).toHaveBeenCalledWith(authorId, `${username}#${discriminator}`, args, attachmentUrl, attachmentExpiration);
|
|
});
|
|
})
|
|
|
|
test('if parseMemberCommand returns error, log error and reply with error', () => {
|
|
// Arrange
|
|
memberHelper.parseMemberCommand = jest.fn().mockImplementation(() => {throw new Error('error')});
|
|
// Act
|
|
return commands.memberCommand(message, args).catch(() => {
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith('error');
|
|
expect(console.error).toHaveBeenCalledWith(new Error('error'));
|
|
});
|
|
})
|
|
|
|
test('if parseMemberCommand returns embed, reply with embed', () => {
|
|
// Arrange
|
|
const embed = new EmbedBuilder();
|
|
memberHelper.parseMemberCommand = jest.fn().mockResolvedValue();
|
|
// Act
|
|
return commands.memberCommand(message, args).catch(() => {
|
|
// Assert
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith({embeds: [embed]})
|
|
});
|
|
})
|
|
|
|
test('if parseMemberCommand returns object, reply with embed and content', () => {
|
|
// Arrange
|
|
const reply = {
|
|
errors: ['error', 'error2'],
|
|
success: 'success',
|
|
embed: {}
|
|
}
|
|
memberHelper.parseMemberCommand = jest.fn().mockResolvedValue(reply);
|
|
// Act
|
|
return commands.memberCommand(message, args).catch(() => {
|
|
// Assert
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith({content: `success\n\n${enums.err.ERRORS_OCCURRED}\n\nerror\nerror2}`, embeds: [reply.embed]})
|
|
});
|
|
})
|
|
})
|
|
|
|
describe('importCommand', () => {
|
|
test('if message includes --help and no attachmentURL, return help message', () => {
|
|
const args = ["--help"];
|
|
message.content = "pf;import --help";
|
|
message.attachments.size = 0;
|
|
return commands.importCommand(message, args).then(() => {
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith(enums.help.IMPORT);
|
|
expect(importHelper.pluralKitImport).not.toHaveBeenCalled();
|
|
})
|
|
})
|
|
|
|
test('if no args and no attachmentURL, return help message', () => {
|
|
const args = [""];
|
|
message.content = 'pf;import'
|
|
message.attachments.size = 0;
|
|
return commands.importCommand(message, args).then(() => {
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith(enums.help.IMPORT);
|
|
expect(importHelper.pluralKitImport).not.toHaveBeenCalled();
|
|
})
|
|
})
|
|
|
|
test('if attachment URL, call pluralKitImport with correct arguments', () => {
|
|
const args = [""];
|
|
message.content = 'pf;import'
|
|
importHelper.pluralKitImport = jest.fn().mockResolvedValue('success');
|
|
return commands.importCommand(message, args).then(() => {
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith('success');
|
|
expect(importHelper.pluralKitImport).toHaveBeenCalledTimes(1);
|
|
expect(importHelper.pluralKitImport).toHaveBeenCalledWith(authorId, attachmentUrl);
|
|
})
|
|
})
|
|
|
|
test('if pluralKitImport returns aggregate errors, send errors.', () => {
|
|
const args = [""];
|
|
message.content = 'pf;import'
|
|
importHelper.pluralKitImport = jest.fn().mockImplementation(() => {throw new AggregateError(['error1', 'error2'], 'errors')});
|
|
return commands.importCommand(message, args).catch(() => {
|
|
expect(message.reply).toHaveBeenCalledTimes(1);
|
|
expect(message.reply).toHaveBeenCalledWith(`errors. \n\n${enums.err.ERRORS_OCCURRED}\n\nerror1\nerror2`);
|
|
})
|
|
})
|
|
|
|
test('if message.reply throws error, call returnBufferFromText and message.reply again.', () => {
|
|
// Arrange
|
|
const args = [""];
|
|
message.content = 'pf;import'
|
|
message.reply = jest.fn().mockImplementationOnce(() => {throw e})
|
|
messageHelper.returnBufferFromText = jest.fn().mockResolvedValue({file: 'test.txt', text: 'normal content'});
|
|
return commands.importCommand(message, args).catch(() => {
|
|
expect(message.reply).toHaveBeenCalledTimes(2);
|
|
expect(message.reply).toHaveBeenNthCalledWith(1, {content: 'normal content', files: [{name: 'test.txt', data: 'test.txt' }],});
|
|
})
|
|
})
|
|
})
|
|
|
|
afterEach(() => {
|
|
// restore the spy created with spyOn
|
|
jest.restoreAllMocks();
|
|
});
|
|
}) |