235 lines
No EOL
7.3 KiB
TypeScript
235 lines
No EOL
7.3 KiB
TypeScript
import {ButtonInteraction, EmbedBuilder} from "discord.js";
|
|
import List from "../../../../src/buttonEvents/304276391837302787/moons/list";
|
|
import UserSetting from "../../../../src/database/entities/UserSetting";
|
|
import Moon from "../../../../src/database/entities/304276391837302787/Moon";
|
|
|
|
describe("GIVEN interaction.guild is null", () => {
|
|
const interaction = {
|
|
guild: null,
|
|
reply: jest.fn(),
|
|
update: jest.fn(),
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT function to return", () => {
|
|
expect(interaction.reply).not.toHaveBeenCalled();
|
|
expect(interaction.update).not.toHaveBeenCalled();
|
|
expect(UserSetting.FetchOneByKey).not.toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe("GIVEN userId parameter is undefined", () => {
|
|
const interaction = {
|
|
guild: {},
|
|
reply: jest.fn(),
|
|
update: jest.fn(),
|
|
customId: "moons list",
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT function to return", () => {
|
|
expect(interaction.reply).not.toHaveBeenCalled();
|
|
expect(interaction.update).not.toHaveBeenCalled();
|
|
expect(UserSetting.FetchOneByKey).not.toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe("GIVEN page parameter is undefined", () => {
|
|
const interaction = {
|
|
guild: {},
|
|
reply: jest.fn(),
|
|
update: jest.fn(),
|
|
customId: "moons list userId",
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT function to return", () => {
|
|
expect(interaction.reply).not.toHaveBeenCalled();
|
|
expect(interaction.update).not.toHaveBeenCalled();
|
|
expect(UserSetting.FetchOneByKey).not.toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe("GIVEN no moons for the user is returned", () => {
|
|
const interaction = {
|
|
guild: {
|
|
members: {
|
|
cache: {
|
|
find: jest.fn().mockReturnValue({
|
|
user: {
|
|
username: "username",
|
|
},
|
|
}),
|
|
},
|
|
},
|
|
},
|
|
reply: jest.fn(),
|
|
update: jest.fn(),
|
|
customId: "moons list userId 0",
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
Moon.FetchPaginatedMoonsByUserId = jest.fn().mockResolvedValue(undefined)
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT moons function to be called", () => {
|
|
expect(Moon.FetchPaginatedMoonsByUserId).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
test("EXPECT error replied", () => {
|
|
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
expect(interaction.reply).toHaveBeenCalledWith("username does not have any moons or page is invalid.");
|
|
});
|
|
|
|
describe("GIVEN member is not in cache", () => {
|
|
const interaction = {
|
|
guild: {
|
|
members: {
|
|
cache: {
|
|
find: jest.fn().mockReturnValue(undefined),
|
|
},
|
|
fetch: jest.fn().mockResolvedValue({
|
|
user: {
|
|
username: "username",
|
|
},
|
|
}),
|
|
},
|
|
},
|
|
reply: jest.fn(),
|
|
update: jest.fn(),
|
|
customId: "moons list userId 0",
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
Moon.FetchPaginatedMoonsByUserId = jest.fn().mockResolvedValue(undefined)
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT API to be called", () => {
|
|
expect(interaction.guild?.members.fetch).toHaveBeenCalledTimes(1);
|
|
expect(interaction.guild?.members.fetch).toHaveBeenCalledWith("userId");
|
|
});
|
|
|
|
test("EXPECT error replied with username", () => {
|
|
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
expect(interaction.reply).toHaveBeenCalledWith("username does not have any moons or page is invalid.");
|
|
});
|
|
});
|
|
|
|
describe("GIVEN member can not be found", () => {
|
|
const interaction = {
|
|
guild: {
|
|
members: {
|
|
cache: {
|
|
find: jest.fn().mockReturnValue(undefined),
|
|
},
|
|
fetch: jest.fn().mockResolvedValue(undefined),
|
|
},
|
|
},
|
|
reply: jest.fn(),
|
|
update: jest.fn(),
|
|
customId: "moons list userId 0",
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
Moon.FetchPaginatedMoonsByUserId = jest.fn().mockResolvedValue(undefined)
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT API to be called", () => {
|
|
expect(interaction.guild?.members.fetch).toHaveBeenCalledTimes(1);
|
|
expect(interaction.guild?.members.fetch).toHaveBeenCalledWith("userId");
|
|
});
|
|
|
|
test("EXPECT error replied with username", () => {
|
|
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
expect(interaction.reply).toHaveBeenCalledWith("This user does not have any moons or page is invalid.");
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("GIVEN no moons on current page", () => {
|
|
let updatedWith: EmbedBuilder[] | undefined;
|
|
|
|
const interaction = {
|
|
guild: {
|
|
members: {
|
|
cache: {
|
|
find: jest.fn().mockReturnValue({
|
|
user: {
|
|
username: "username",
|
|
},
|
|
}),
|
|
},
|
|
},
|
|
},
|
|
reply: jest.fn(),
|
|
update: jest.fn((options: any) => {
|
|
updatedWith = options.embeds;
|
|
}),
|
|
customId: "moons list userId 0",
|
|
} as unknown as ButtonInteraction;
|
|
|
|
beforeAll(async () => {
|
|
UserSetting.FetchOneByKey = jest.fn();
|
|
Moon.FetchPaginatedMoonsByUserId = jest.fn().mockResolvedValue([
|
|
[],
|
|
0,
|
|
]);
|
|
|
|
await List(interaction);
|
|
});
|
|
|
|
test("EXPECT description to say so", () => {
|
|
expect(updatedWith).toBeDefined();
|
|
expect(updatedWith?.length).toBe(1);
|
|
|
|
expect(updatedWith![0].data.description).toBe("*none*");
|
|
});
|
|
});
|
|
|
|
describe("GIVEN happy flow", () => {
|
|
test.todo("EXPECT moons to be fetched");
|
|
|
|
test.todo("EXPECT embed to be updated");
|
|
|
|
test.todo("EXPECT row to be updated");
|
|
|
|
describe("GIVEN it is the first page", () => {
|
|
test.todo("EXPECT Previous button to be disabled");
|
|
});
|
|
|
|
describe("GIVEN it is the last page", () => {
|
|
test.todo("EXPECT Next button to be disabled");
|
|
|
|
describe("GIVEN there are more moons in the counter than in the database", () => {
|
|
test.todo("EXPECT untracked counter to be present");
|
|
});
|
|
});
|
|
|
|
describe("GIVEN no moons on the current page", () => {
|
|
test.todo("EXPECT Next button to be disabled");
|
|
});
|
|
}); |