Compare commits
No commits in common. "be712b08f4969e023c03a6751262ed957806d209" and "78963d6b7c0e505df44c37cbf3caa6da9d835bc0" have entirely different histories.
be712b08f4
...
78963d6b7c
2 changed files with 17 additions and 48 deletions
|
@ -4,6 +4,7 @@ import { CardRarity, CardRarityChoices, CardRarityParse } from "../../constants/
|
|||
import { readFileSync } from "fs";
|
||||
import Inventory from "../../database/entities/app/Inventory";
|
||||
import { v4 } from "uuid";
|
||||
import { CoreClient } from "../../client/client";
|
||||
import path from "path";
|
||||
import GetCardsHelper from "../../helpers/DropHelpers/GetCardsHelper";
|
||||
import DropEmbedHelper from "../../helpers/DropHelpers/DropEmbedHelper";
|
||||
|
@ -41,7 +42,7 @@ export default class Droprarity extends Command {
|
|||
return;
|
||||
}
|
||||
|
||||
const card = GetCardsHelper.GetRandomCardByRarity(rarityType);
|
||||
const card = await GetCardsHelper.GetRandomCardByRarity(rarityType);
|
||||
|
||||
if (!card) {
|
||||
await interaction.reply("Card not found");
|
||||
|
|
|
@ -9,7 +9,6 @@ import GetCardsHelper from "../../src/helpers/DropHelpers/GetCardsHelper";
|
|||
import Inventory from "../../src/database/entities/app/Inventory";
|
||||
import DropEmbedHelper from "../../src/helpers/DropHelpers/DropEmbedHelper";
|
||||
import CardConstants from "../../src/constants/CardConstants";
|
||||
import * as uuid from "uuid";
|
||||
|
||||
jest.mock("../../src/database/entities/app/Config");
|
||||
jest.mock("../../src/database/entities/app/User");
|
||||
|
@ -17,8 +16,6 @@ jest.mock("../../src/helpers/DropHelpers/GetCardsHelper");
|
|||
jest.mock("../../src/database/entities/app/Inventory");
|
||||
jest.mock("../../src/helpers/DropHelpers/DropEmbedHelper");
|
||||
|
||||
jest.mock("uuid");
|
||||
|
||||
beforeEach(() => {
|
||||
(Config.GetValue as jest.Mock).mockResolvedValue("false");
|
||||
});
|
||||
|
@ -27,12 +24,6 @@ describe("execute", () => {
|
|||
describe("GIVEN user is in the database", () => {
|
||||
let interaction: CommandInteractionMock;
|
||||
let user: User;
|
||||
const randomCard = {
|
||||
card: {
|
||||
id: "cardId",
|
||||
path: "https://google.com/",
|
||||
}
|
||||
};
|
||||
|
||||
beforeAll(async () => {
|
||||
// Arrange
|
||||
|
@ -41,25 +32,26 @@ describe("execute", () => {
|
|||
interaction = GenerateCommandInteractionMock();
|
||||
|
||||
user = {
|
||||
Currency: 500,
|
||||
RemoveCurrency: jest.fn().mockReturnValue(true),
|
||||
Save: jest.fn(),
|
||||
} as unknown as User;
|
||||
|
||||
(User.FetchOneById as jest.Mock).mockResolvedValue(user);
|
||||
(GetCardsHelper.FetchCard as jest.Mock).mockResolvedValue(randomCard);
|
||||
(GetCardsHelper.FetchCard as jest.Mock).mockResolvedValue({
|
||||
card: {
|
||||
path: "https://google.com/",
|
||||
}
|
||||
});
|
||||
(Inventory.FetchOneByCardNumberAndUserId as jest.Mock).mockResolvedValue({
|
||||
Quantity: 1,
|
||||
});
|
||||
(DropEmbedHelper.GenerateDropEmbed as jest.Mock).mockReturnValue({
|
||||
(DropEmbedHelper.GenerateDropEmbed as jest.Mock).mockResolvedValue({
|
||||
type: "Embed",
|
||||
});
|
||||
(DropEmbedHelper.GenerateDropButtons as jest.Mock).mockReturnValue({
|
||||
(DropEmbedHelper.GenerateDropButtons as jest.Mock).mockResolvedValue({
|
||||
type: "Button",
|
||||
});
|
||||
|
||||
(uuid.v4 as jest.Mock).mockReturnValue("uuid");
|
||||
|
||||
|
||||
// Act
|
||||
const drop = new Drop();
|
||||
await drop.execute(interaction as unknown as CommandInteraction);
|
||||
|
@ -75,43 +67,19 @@ describe("execute", () => {
|
|||
expect(user.RemoveCurrency).toHaveBeenCalledWith(CardConstants.ClaimCost);
|
||||
});
|
||||
|
||||
test("EXPECT user to be saved", () => {
|
||||
expect(user.Save).toHaveBeenCalledTimes(1);
|
||||
expect(user.Save).toHaveBeenCalledWith(User, user);
|
||||
});
|
||||
test.todo("EXPECT user to be saved");
|
||||
|
||||
test("EXPECT random card to be fetched", () => {
|
||||
expect(GetCardsHelper.FetchCard).toHaveBeenCalledTimes(1);
|
||||
expect(GetCardsHelper.FetchCard).toHaveBeenCalledWith("userId");
|
||||
});
|
||||
test.todo("EXPECT random card to be fetched");
|
||||
|
||||
test("EXPECT interaction to be deferred", () => {
|
||||
expect(interaction.deferReply).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
test.todo("EXPECT interaction to be deferred");
|
||||
|
||||
test("EXPECT Inventory.FetchOneByCardNumberAndUserId to be called", () => {
|
||||
expect(Inventory.FetchOneByCardNumberAndUserId).toHaveBeenCalledTimes(1);
|
||||
expect(Inventory.FetchOneByCardNumberAndUserId).toHaveBeenCalledWith("userId", "cardId");
|
||||
});
|
||||
test.todo("EXPECT Inventory.FetchOneByCardNumberAndUserId to be called");
|
||||
|
||||
test("EXPECT DropEmbedHelper.GenerateDropEmbed to be called", () => {
|
||||
expect(DropEmbedHelper.GenerateDropEmbed).toHaveBeenCalledTimes(1);
|
||||
expect(DropEmbedHelper.GenerateDropEmbed).toHaveBeenCalledWith(randomCard, 1, "", undefined, 500);
|
||||
});
|
||||
test.todo("EXPECT DropEmbedHelper.GenerateDropEmbed to be called");
|
||||
|
||||
test("EXPECT DropEmbedHelper.GenerateDropButtons to be called", () => {
|
||||
expect(DropEmbedHelper.GenerateDropButtons).toHaveBeenCalledTimes(1);
|
||||
expect(DropEmbedHelper.GenerateDropButtons).toHaveBeenCalledWith(randomCard, "uuid", "userId");
|
||||
});
|
||||
test.todo("EXPECT DropEmbedHelper.GenerateDropButtons to be called");
|
||||
|
||||
test("EXPECT interaction to be edited", () => {
|
||||
expect(interaction.editReply).toHaveBeenCalledTimes(1);
|
||||
expect(interaction.editReply).toHaveBeenCalledWith({
|
||||
embeds: [ { type: "Embed" } ],
|
||||
files: [],
|
||||
components: [ { type: "Button" } ],
|
||||
});
|
||||
});
|
||||
test.todo("EXPECT interaction to be edited");
|
||||
|
||||
describe("AND randomCard path is not a url", () => {
|
||||
test.todo("EXPECT image read from file system");
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue