Create use effect command #419

Open
Vylpes wants to merge 26 commits from feature/380-use-effect into develop
2 changed files with 139 additions and 4 deletions
Showing only changes of commit 6f241ab349 - Show all commits

View file

@ -19,7 +19,7 @@ export default class Effects extends ButtonEvent {
}
}
private async List(interaction: ButtonInteraction) {
public async List(interaction: ButtonInteraction) {
Vylpes marked this conversation as resolved Outdated

I don't like that

I don't like that
const pageOption = interaction.customId.split(" ")[2];
const page = Number(pageOption);
@ -37,7 +37,7 @@ export default class Effects extends ButtonEvent {
});
}
private async Use(interaction: ButtonInteraction) {
public async Use(interaction: ButtonInteraction) {
Vylpes marked this conversation as resolved Outdated

I don't like that its public

I don't like that its public
const subaction = interaction.customId.split(" ")[2];
switch (subaction) {
@ -50,7 +50,7 @@ export default class Effects extends ButtonEvent {
}
}
private async UseConfirm(interaction: ButtonInteraction) {
public async UseConfirm(interaction: ButtonInteraction) {
Vylpes marked this conversation as resolved Outdated

I don't like that thats public

I don't like that thats public
const id = interaction.customId.split(" ")[3];
const effectDetail = EffectDetails.get(id);
@ -108,7 +108,7 @@ export default class Effects extends ButtonEvent {
await interaction.reply("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown");
}
private async UseCancel(interaction: ButtonInteraction) {
public async UseCancel(interaction: ButtonInteraction) {
Vylpes marked this conversation as resolved Outdated

I don't like that thats public

I don't like that thats public
const id = interaction.customId.split(" ")[3];
const effectDetail = EffectDetails.get(id);

View file

@ -0,0 +1,135 @@
import { ActionRowBuilder, ButtonBuilder, ButtonInteraction, EmbedBuilder } from "discord.js";
import Effects from "../../src/buttonEvents/Effects";
import EffectHelper from "../../src/helpers/EffectHelper";
import { EffectDetails } from "../../src/constants/EffectDetails";
import TimeLengthInput from "../../src/helpers/TimeLengthInput";
describe("Effects", () => {
let interaction: ButtonInteraction;
let effects: Effects;
beforeEach(() => {
interaction = {
customId: "effects list 1",
user: { id: "123" },
reply: jest.fn(),
update: jest.fn(),
} as unknown as ButtonInteraction;
effects = new Effects();
});
it("should call List method when action is 'list'", async () => {
const listSpy = jest.spyOn(effects, "List").mockImplementation(async () => {});
await effects.execute(interaction);
expect(listSpy).toHaveBeenCalledWith(interaction);
});
it("should call Use method when action is 'use'", async () => {
interaction.customId = "effects use confirm 1";
const useSpy = jest.spyOn(effects, "Use").mockImplementation(async () => {});
await effects.execute(interaction);
expect(useSpy).toHaveBeenCalledWith(interaction);
});
it("should reply with error message when page option is not a valid number", async () => {
interaction.customId = "effects list invalid";
await effects.execute(interaction);
expect(interaction.reply).toHaveBeenCalledWith("Page option is not a valid number");
});
it("should update interaction with generated embed and row", async () => {
const mockEmbed = {
embed: new EmbedBuilder(),
row: new ActionRowBuilder<ButtonBuilder>()
};
jest.spyOn(EffectHelper, "GenerateEffectEmbed").mockResolvedValue(mockEmbed);
await effects.List(interaction);
expect(interaction.update).toHaveBeenCalledWith({
embeds: [mockEmbed.embed],
components: [mockEmbed.row],
});
});
it("should call UseConfirm method when subaction is 'confirm'", async () => {
interaction.customId = "effects use confirm 1";
const useConfirmSpy = jest.spyOn(effects, "UseConfirm").mockImplementation(async () => {});
await effects.Use(interaction);
expect(useConfirmSpy).toHaveBeenCalledWith(interaction);
});
it("should call UseCancel method when subaction is 'cancel'", async () => {
interaction.customId = "effects use cancel 1";
const useCancelSpy = jest.spyOn(effects, "UseCancel").mockImplementation(async () => {});
await effects.Use(interaction);
expect(useCancelSpy).toHaveBeenCalledWith(interaction);
});
it("should reply with error message when effect detail is not found in UseConfirm", async () => {
interaction.customId = "effects use confirm invalid";
await effects.UseConfirm(interaction);
expect(interaction.reply).toHaveBeenCalledWith("Unable to find effect!");
});
it("should reply with error message when effect detail is not found in UseCancel", async () => {
interaction.customId = "effects use cancel invalid";
await effects.UseCancel(interaction);
expect(interaction.reply).toHaveBeenCalledWith("Unable to find effect!");
});
it("should update interaction with embed and row when effect is used successfully", async () => {
const mockEffectDetail = { id: "1", friendlyName: "Test Effect", duration: 1000, cost: 10, cooldown: 5000 };
const mockResult = true;
jest.spyOn(EffectDetails, "get").mockReturnValue(mockEffectDetail);
jest.spyOn(EffectHelper, "UseEffect").mockResolvedValue(mockResult);
await effects.UseConfirm(interaction);
expect(interaction.update).toHaveBeenCalledWith(expect.objectContaining({
embeds: expect.any(Array),
components: expect.any(Array),
}));
});
it("should reply with error message when effect is not used successfully", async () => {
const mockEffectDetail = { id: "1", friendlyName: "Test Effect", duration: 1000, cost: 0, cooldown: 0 };
const mockResult = false;
jest.spyOn(EffectDetails, "get").mockReturnValue(mockEffectDetail);
jest.spyOn(EffectHelper, "UseEffect").mockResolvedValue(mockResult);
await effects.UseConfirm(interaction);
expect(interaction.reply).toHaveBeenCalledWith("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown");
});
it("should update interaction with embed and row when effect use is cancelled", async () => {
const mockEffectDetail = { id: "1", friendlyName: "Test Effect", duration: 1000, cost: 0, cooldown: 0 };
jest.spyOn(EffectDetails, "get").mockReturnValue(mockEffectDetail);
jest.spyOn(TimeLengthInput, "ConvertFromMilliseconds").mockReturnValue({
GetLengthShort: () => "1s",
} as TimeLengthInput);
await effects.UseCancel(interaction);
expect(interaction.update).toHaveBeenCalledWith(expect.objectContaining({
embeds: expect.any(Array),
components: expect.any(Array),
}));
});
});