# Description - Create a command to generate an embed for the user to be able to buy more effects - This embed will contain the details about the effect as well as 2 buttons; Confirm and Cancel - The confirm button will call the button event to: - Remove the currency from the user - Give the user the effect to their inventory - The cancel button will just disable the buttons, so the user can't accidentally use it if they don't want to. #381 ## Type of change Please delete options that are not relevant. - [x] New feature (non-breaking change which adds functionality) # How Has This Been Tested? - Have created unit tests and tested locally # Checklist - [ ] My code follows the style guidelines of this project - [ ] I have performed a self-review of my own code - [ ] I have commented my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [ ] My changes generate no new warnings - [ ] I have added tests that provde my fix is effective or that my feature works - [ ] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules Reviewed-on: #424 Reviewed-by: VylpesTester <tester@vylpes.com> Co-authored-by: Ethan Lane <ethan@vylpes.com> Co-committed-by: Ethan Lane <ethan@vylpes.com>
50 lines
No EOL
1.6 KiB
TypeScript
50 lines
No EOL
1.6 KiB
TypeScript
import { ActionRowBuilder, ButtonBuilder, ButtonInteraction, EmbedBuilder } from "discord.js";
|
|
import List from "../../../src/buttonEvents/Effects/List";
|
|
import EffectHelper from "../../../src/helpers/EffectHelper";
|
|
import { mock } from "jest-mock-extended";
|
|
|
|
jest.mock("../../../src/helpers/EffectHelper");
|
|
|
|
let interaction: ReturnType<typeof mock<ButtonInteraction>>;
|
|
|
|
beforeEach(() => {
|
|
jest.resetAllMocks();
|
|
|
|
(EffectHelper.GenerateEffectListEmbed as jest.Mock).mockResolvedValue({
|
|
embed: mock<EmbedBuilder>(),
|
|
row: mock<ActionRowBuilder<ButtonBuilder>>(),
|
|
});
|
|
|
|
interaction = mock<ButtonInteraction>();
|
|
interaction.user.id = "userId";
|
|
interaction.customId = "effects list 1";
|
|
});
|
|
|
|
test("GIVEN pageOption is NOT a number, EXPECT error", async () => {
|
|
// Arrange
|
|
interaction.customId = "effects list invalid";
|
|
|
|
// Act
|
|
await List(interaction);
|
|
|
|
// Assert
|
|
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
expect(interaction.reply).toHaveBeenCalledWith("Page option is not a valid number")
|
|
|
|
expect(EffectHelper.GenerateEffectListEmbed).not.toHaveBeenCalled();
|
|
expect(interaction.update).not.toHaveBeenCalled();
|
|
});
|
|
|
|
test("GIVEN pageOption is a number, EXPECT interaction updated", async () => {
|
|
// Arrange
|
|
interaction.customId = "effects list 1";
|
|
|
|
// Act
|
|
await List(interaction);
|
|
|
|
// Assert
|
|
expect(EffectHelper.GenerateEffectListEmbed).toHaveBeenCalledTimes(1);
|
|
expect(EffectHelper.GenerateEffectListEmbed).toHaveBeenCalledWith("userId", 1);
|
|
|
|
expect(interaction.update).toHaveBeenCalledTimes(1);
|
|
}); |