Compare commits
1 commit
607685aa43
...
b02ad146bb
Author | SHA1 | Date | |
---|---|---|---|
b02ad146bb |
11 changed files with 42 additions and 693 deletions
|
@ -1,33 +0,0 @@
|
||||||
import {ButtonInteraction} from "discord.js";
|
|
||||||
import {ButtonEvent} from "../type/buttonEvent";
|
|
||||||
import EffectHelper from "../helpers/EffectHelper";
|
|
||||||
|
|
||||||
export default class Effects extends ButtonEvent {
|
|
||||||
public override async execute(interaction: ButtonInteraction) {
|
|
||||||
const action = interaction.customId.split(" ")[1];
|
|
||||||
|
|
||||||
switch (action) {
|
|
||||||
case "list":
|
|
||||||
await this.List(interaction);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private async List(interaction: ButtonInteraction) {
|
|
||||||
const pageOption = interaction.customId.split(" ")[2];
|
|
||||||
|
|
||||||
const page = Number(pageOption);
|
|
||||||
|
|
||||||
if (!page) {
|
|
||||||
await interaction.reply("Page option is not a valid number");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const result = await EffectHelper.GenerateEffectEmbed(interaction.user.id, page);
|
|
||||||
|
|
||||||
await interaction.update({
|
|
||||||
embeds: [ result.embed ],
|
|
||||||
components: [ result.row ],
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
import {CommandInteraction, SlashCommandBuilder} from "discord.js";
|
|
||||||
import {Command} from "../type/command";
|
|
||||||
import EffectHelper from "../helpers/EffectHelper";
|
|
||||||
|
|
||||||
export default class Effects extends Command {
|
|
||||||
constructor() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
this.CommandBuilder = new SlashCommandBuilder()
|
|
||||||
.setName("effects")
|
|
||||||
.setDescription("Effects")
|
|
||||||
.addSubcommand(x => x
|
|
||||||
.setName("list")
|
|
||||||
.setDescription("List all effects I have")
|
|
||||||
.addNumberOption(x => x
|
|
||||||
.setName("page")
|
|
||||||
.setDescription("The page number")
|
|
||||||
.setMinValue(1)));
|
|
||||||
}
|
|
||||||
|
|
||||||
public override async execute(interaction: CommandInteraction) {
|
|
||||||
if (!interaction.isChatInputCommand()) return;
|
|
||||||
|
|
||||||
const subcommand = interaction.options.getSubcommand();
|
|
||||||
|
|
||||||
switch (subcommand) {
|
|
||||||
case "list":
|
|
||||||
await this.List(interaction);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private async List(interaction: CommandInteraction) {
|
|
||||||
const pageOption = interaction.options.get("page");
|
|
||||||
|
|
||||||
const page = !isNaN(Number(pageOption?.value)) ? Number(pageOption?.value) : 1;
|
|
||||||
|
|
||||||
const result = await EffectHelper.GenerateEffectEmbed(interaction.user.id, page);
|
|
||||||
|
|
||||||
await interaction.reply({
|
|
||||||
embeds: [ result.embed ],
|
|
||||||
components: [ result.row ],
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -57,18 +57,4 @@ export default class UserEffect extends AppBaseEntity {
|
||||||
|
|
||||||
return single;
|
return single;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async FetchAllByUserIdPaginated(userId: string, page: number = 0, itemsPerPage: number = 10): Promise<[UserEffect[], number]> {
|
|
||||||
const repository = AppDataSource.getRepository(UserEffect);
|
|
||||||
|
|
||||||
const query = await repository.createQueryBuilder("effect")
|
|
||||||
.where("effect.UserId = :userId", { userId })
|
|
||||||
.where("effect.Unused > 0")
|
|
||||||
.orderBy("effect.Name", "ASC")
|
|
||||||
.skip(page * itemsPerPage)
|
|
||||||
.take(itemsPerPage)
|
|
||||||
.getManyAndCount();
|
|
||||||
|
|
||||||
return query;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
import {ActionRowBuilder, ButtonBuilder, ButtonStyle, EmbedBuilder} from "discord.js";
|
|
||||||
import UserEffect from "../database/entities/app/UserEffect";
|
import UserEffect from "../database/entities/app/UserEffect";
|
||||||
import EmbedColours from "../constants/EmbedColours";
|
|
||||||
|
|
||||||
export default class EffectHelper {
|
export default class EffectHelper {
|
||||||
public static async AddEffectToUserInventory(userId: string, name: string, quantity: number = 1) {
|
public static async AddEffectToUserInventory(userId: string, name: string, quantity: number = 1) {
|
||||||
|
@ -48,49 +46,4 @@ export default class EffectHelper {
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async GenerateEffectEmbed(userId: string, page: number): Promise<{
|
|
||||||
embed: EmbedBuilder,
|
|
||||||
row: ActionRowBuilder<ButtonBuilder>,
|
|
||||||
}> {
|
|
||||||
const itemsPerPage = 10;
|
|
||||||
|
|
||||||
const query = await UserEffect.FetchAllByUserIdPaginated(userId, page - 1, itemsPerPage);
|
|
||||||
|
|
||||||
const effects = query[0];
|
|
||||||
const count = query[1];
|
|
||||||
|
|
||||||
const totalPages = count > 0 ? Math.ceil(count / itemsPerPage) : 1;
|
|
||||||
|
|
||||||
let description = "*none*";
|
|
||||||
|
|
||||||
if (effects.length > 0) {
|
|
||||||
description = effects.map(x => `${x.Name} x${x.Unused}`).join("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
const embed = new EmbedBuilder()
|
|
||||||
.setTitle("Effects")
|
|
||||||
.setDescription(description)
|
|
||||||
.setColor(EmbedColours.Ok)
|
|
||||||
.setFooter({ text: `Page ${page} of ${totalPages}` });
|
|
||||||
|
|
||||||
const row = new ActionRowBuilder<ButtonBuilder>()
|
|
||||||
.addComponents(
|
|
||||||
new ButtonBuilder()
|
|
||||||
.setCustomId(`effects list ${page - 1}`)
|
|
||||||
.setLabel("Previous")
|
|
||||||
.setStyle(ButtonStyle.Primary)
|
|
||||||
.setDisabled(page == 1),
|
|
||||||
new ButtonBuilder()
|
|
||||||
.setCustomId(`effects list ${page + 1}`)
|
|
||||||
.setLabel("Next")
|
|
||||||
.setStyle(ButtonStyle.Primary)
|
|
||||||
.setDisabled(page == totalPages),
|
|
||||||
);
|
|
||||||
|
|
||||||
return {
|
|
||||||
embed,
|
|
||||||
row,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,6 @@ import AllBalance from "./commands/allbalance";
|
||||||
import Balance from "./commands/balance";
|
import Balance from "./commands/balance";
|
||||||
import Daily from "./commands/daily";
|
import Daily from "./commands/daily";
|
||||||
import Drop from "./commands/drop";
|
import Drop from "./commands/drop";
|
||||||
import Effects from "./commands/effects";
|
|
||||||
import Gdrivesync from "./commands/gdrivesync";
|
import Gdrivesync from "./commands/gdrivesync";
|
||||||
import Give from "./commands/give";
|
import Give from "./commands/give";
|
||||||
import Id from "./commands/id";
|
import Id from "./commands/id";
|
||||||
|
@ -26,7 +25,6 @@ import Droprarity from "./commands/stage/droprarity";
|
||||||
|
|
||||||
// Button Event Imports
|
// Button Event Imports
|
||||||
import Claim from "./buttonEvents/Claim";
|
import Claim from "./buttonEvents/Claim";
|
||||||
import EffectsButtonEvent from "./buttonEvents/Effects";
|
|
||||||
import InventoryButtonEvent from "./buttonEvents/Inventory";
|
import InventoryButtonEvent from "./buttonEvents/Inventory";
|
||||||
import MultidropButtonEvent from "./buttonEvents/Multidrop";
|
import MultidropButtonEvent from "./buttonEvents/Multidrop";
|
||||||
import Reroll from "./buttonEvents/Reroll";
|
import Reroll from "./buttonEvents/Reroll";
|
||||||
|
@ -46,7 +44,6 @@ export default class Registry {
|
||||||
CoreClient.RegisterCommand("balance", new Balance());
|
CoreClient.RegisterCommand("balance", new Balance());
|
||||||
CoreClient.RegisterCommand("daily", new Daily());
|
CoreClient.RegisterCommand("daily", new Daily());
|
||||||
CoreClient.RegisterCommand("drop", new Drop());
|
CoreClient.RegisterCommand("drop", new Drop());
|
||||||
CoreClient.RegisterCommand("effects", new Effects());
|
|
||||||
CoreClient.RegisterCommand("gdrivesync", new Gdrivesync());
|
CoreClient.RegisterCommand("gdrivesync", new Gdrivesync());
|
||||||
CoreClient.RegisterCommand("give", new Give());
|
CoreClient.RegisterCommand("give", new Give());
|
||||||
CoreClient.RegisterCommand("id", new Id());
|
CoreClient.RegisterCommand("id", new Id());
|
||||||
|
@ -66,7 +63,6 @@ export default class Registry {
|
||||||
|
|
||||||
public static RegisterButtonEvents() {
|
public static RegisterButtonEvents() {
|
||||||
CoreClient.RegisterButtonEvent("claim", new Claim());
|
CoreClient.RegisterButtonEvent("claim", new Claim());
|
||||||
CoreClient.RegisterButtonEvent("effects", new EffectsButtonEvent());
|
|
||||||
CoreClient.RegisterButtonEvent("inventory", new InventoryButtonEvent());
|
CoreClient.RegisterButtonEvent("inventory", new InventoryButtonEvent());
|
||||||
CoreClient.RegisterButtonEvent("multidrop", new MultidropButtonEvent());
|
CoreClient.RegisterButtonEvent("multidrop", new MultidropButtonEvent());
|
||||||
CoreClient.RegisterButtonEvent("reroll", new Reroll());
|
CoreClient.RegisterButtonEvent("reroll", new Reroll());
|
||||||
|
|
|
@ -1,127 +0,0 @@
|
||||||
import {ButtonInteraction} from "discord.js";
|
|
||||||
import Effects from "../../src/buttonEvents/Effects";
|
|
||||||
import EffectHelper from "../../src/helpers/EffectHelper";
|
|
||||||
|
|
||||||
describe("execute", () => {
|
|
||||||
describe("GIVEN action in custom id is list", () => {
|
|
||||||
const interaction = {
|
|
||||||
customId: "effects list",
|
|
||||||
} as unknown as ButtonInteraction;
|
|
||||||
|
|
||||||
let listSpy: jest.SpyInstance;
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
listSpy = jest.spyOn(effects as unknown as {"List": () => object}, "List")
|
|
||||||
.mockImplementation();
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT list function to be called", () => {
|
|
||||||
expect(listSpy).toHaveBeenCalledTimes(1);
|
|
||||||
expect(listSpy).toHaveBeenCalledWith(interaction);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("List", () => {
|
|
||||||
let interaction: ButtonInteraction;
|
|
||||||
|
|
||||||
const embed = {
|
|
||||||
name: "Embed",
|
|
||||||
};
|
|
||||||
|
|
||||||
const row = {
|
|
||||||
name: "Row",
|
|
||||||
};
|
|
||||||
|
|
||||||
beforeEach(() => {
|
|
||||||
interaction = {
|
|
||||||
customId: "effects list",
|
|
||||||
user: {
|
|
||||||
id: "userId",
|
|
||||||
},
|
|
||||||
update: jest.fn(),
|
|
||||||
reply: jest.fn(),
|
|
||||||
} as unknown as ButtonInteraction;
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN page is a valid number", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction.customId += " 1";
|
|
||||||
|
|
||||||
EffectHelper.GenerateEffectEmbed = jest.fn()
|
|
||||||
.mockResolvedValue({
|
|
||||||
embed,
|
|
||||||
row,
|
|
||||||
});
|
|
||||||
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT EffectHelper.GenerateEffectEmbed to be called", () => {
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledTimes(1);
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledWith("userId", 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT interaction to be updated", () => {
|
|
||||||
expect(interaction.update).toHaveBeenCalledTimes(1);
|
|
||||||
expect(interaction.update).toHaveBeenCalledWith({
|
|
||||||
embeds: [ embed ],
|
|
||||||
components: [ row ],
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN page in custom id is not supplied", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
EffectHelper.GenerateEffectEmbed = jest.fn()
|
|
||||||
.mockResolvedValue({
|
|
||||||
embed,
|
|
||||||
row,
|
|
||||||
});
|
|
||||||
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT interaction to be replied with error", () => {
|
|
||||||
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
||||||
expect(interaction.reply).toHaveBeenCalledWith("Page option is not a valid number");
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT interaction to not be updated", () => {
|
|
||||||
expect(interaction.update).not.toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN page in custom id is not a number", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction.customId += " test";
|
|
||||||
|
|
||||||
EffectHelper.GenerateEffectEmbed = jest.fn()
|
|
||||||
.mockResolvedValue({
|
|
||||||
embed,
|
|
||||||
row,
|
|
||||||
});
|
|
||||||
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT interaction to be replied with error", () => {
|
|
||||||
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
||||||
expect(interaction.reply).toHaveBeenCalledWith("Page option is not a valid number");
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT interaction to not be updated", () => {
|
|
||||||
expect(interaction.update).not.toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,40 +0,0 @@
|
||||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
||||||
|
|
||||||
exports[`constructor EXPECT CommandBuilder to be defined 1`] = `
|
|
||||||
{
|
|
||||||
"contexts": undefined,
|
|
||||||
"default_member_permissions": undefined,
|
|
||||||
"default_permission": undefined,
|
|
||||||
"description": "Effects",
|
|
||||||
"description_localizations": undefined,
|
|
||||||
"dm_permission": undefined,
|
|
||||||
"integration_types": undefined,
|
|
||||||
"name": "effects",
|
|
||||||
"name_localizations": undefined,
|
|
||||||
"nsfw": undefined,
|
|
||||||
"options": [
|
|
||||||
{
|
|
||||||
"description": "List all effects I have",
|
|
||||||
"description_localizations": undefined,
|
|
||||||
"name": "list",
|
|
||||||
"name_localizations": undefined,
|
|
||||||
"options": [
|
|
||||||
{
|
|
||||||
"autocomplete": undefined,
|
|
||||||
"choices": undefined,
|
|
||||||
"description": "The page number",
|
|
||||||
"description_localizations": undefined,
|
|
||||||
"max_value": undefined,
|
|
||||||
"min_value": 1,
|
|
||||||
"name": "page",
|
|
||||||
"name_localizations": undefined,
|
|
||||||
"required": false,
|
|
||||||
"type": 10,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"type": 1,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"type": 1,
|
|
||||||
}
|
|
||||||
`;
|
|
|
@ -1,164 +0,0 @@
|
||||||
import {ChatInputCommandInteraction} from "discord.js";
|
|
||||||
import Effects from "../../src/commands/effects";
|
|
||||||
import EffectHelper from "../../src/helpers/EffectHelper";
|
|
||||||
|
|
||||||
describe("constructor", () => {
|
|
||||||
let effects: Effects;
|
|
||||||
|
|
||||||
beforeEach(() => {
|
|
||||||
effects = new Effects();
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT CommandBuilder to be defined", () => {
|
|
||||||
expect(effects.CommandBuilder).toMatchSnapshot();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("execute", () => {
|
|
||||||
describe("GIVEN interaction is not a chat input command", () => {
|
|
||||||
let interaction: ChatInputCommandInteraction;
|
|
||||||
|
|
||||||
let listSpy: jest.SpyInstance;
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction = {
|
|
||||||
isChatInputCommand: jest.fn().mockReturnValue(false),
|
|
||||||
} as unknown as ChatInputCommandInteraction;
|
|
||||||
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
listSpy = jest.spyOn(effects as unknown as {"List": () => object}, "List")
|
|
||||||
.mockImplementation();
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT isChatInputCommand to have been called", () => {
|
|
||||||
expect(interaction.isChatInputCommand).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT nothing to happen", () => {
|
|
||||||
expect(listSpy).not.toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN subcommand is list", () => {
|
|
||||||
let interaction: ChatInputCommandInteraction;
|
|
||||||
|
|
||||||
let listSpy: jest.SpyInstance;
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction = {
|
|
||||||
isChatInputCommand: jest.fn().mockReturnValue(true),
|
|
||||||
options: {
|
|
||||||
getSubcommand: jest.fn().mockReturnValue("list"),
|
|
||||||
},
|
|
||||||
} as unknown as ChatInputCommandInteraction;
|
|
||||||
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
listSpy = jest.spyOn(effects as unknown as {"List": () => object}, "List")
|
|
||||||
.mockImplementation();
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT subcommand function to be called", () => {
|
|
||||||
expect(interaction.options.getSubcommand).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT list function to be called", () => {
|
|
||||||
expect(listSpy).toHaveBeenCalledTimes(1);
|
|
||||||
expect(listSpy).toHaveBeenCalledWith(interaction);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("List", () => {
|
|
||||||
const effects: Effects = new Effects();
|
|
||||||
let interaction: ChatInputCommandInteraction;
|
|
||||||
|
|
||||||
const embed = {
|
|
||||||
name: "embed",
|
|
||||||
};
|
|
||||||
|
|
||||||
const row = {
|
|
||||||
name: "row",
|
|
||||||
};
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction = {
|
|
||||||
isChatInputCommand: jest.fn().mockReturnValue(true),
|
|
||||||
options: {
|
|
||||||
getSubcommand: jest.fn().mockReturnValue("list"),
|
|
||||||
},
|
|
||||||
reply: jest.fn(),
|
|
||||||
user: {
|
|
||||||
id: "userId",
|
|
||||||
},
|
|
||||||
} as unknown as ChatInputCommandInteraction;
|
|
||||||
|
|
||||||
const effects = new Effects();
|
|
||||||
|
|
||||||
EffectHelper.GenerateEffectEmbed = jest.fn().mockReturnValue({
|
|
||||||
embed,
|
|
||||||
row,
|
|
||||||
});
|
|
||||||
|
|
||||||
jest.spyOn(effects as unknown as {"List": () => object}, "List")
|
|
||||||
.mockImplementation();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN page option is supplied", () => {
|
|
||||||
describe("AND page is a valid number", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction.options.get = jest.fn().mockReturnValueOnce({
|
|
||||||
value: "2",
|
|
||||||
});
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT EffectHelper.GenerateEffectEmbed to have been called with page", () => {
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledTimes(1);
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledWith("userId", 2);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT interaction to have been replied", () => {
|
|
||||||
expect(interaction.reply).toHaveBeenCalledTimes(1);
|
|
||||||
expect(interaction.reply).toHaveBeenCalledWith({
|
|
||||||
embeds: [ embed ],
|
|
||||||
components: [ row ],
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("AND page is not a valid number", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction.options.get = jest.fn().mockReturnValueOnce({
|
|
||||||
value: "test",
|
|
||||||
});
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT EffectHelper.GenerateEffectEmbed to have been called with page of 1", () => {
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledTimes(1);
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledWith("userId", 1);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN page option is not supplied", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
interaction.options.get = jest.fn().mockReturnValueOnce(undefined);
|
|
||||||
|
|
||||||
await effects.execute(interaction);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT EffectHelper.GenerateEffectEmbed to have been called with page of 1", () => {
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledTimes(1);
|
|
||||||
expect(EffectHelper.GenerateEffectEmbed).toHaveBeenCalledWith("userId", 1);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,4 +1,3 @@
|
||||||
import {ActionRowBuilder, ButtonBuilder, EmbedBuilder} from "discord.js";
|
|
||||||
import UserEffect from "../../src/database/entities/app/UserEffect";
|
import UserEffect from "../../src/database/entities/app/UserEffect";
|
||||||
import EffectHelper from "../../src/helpers/EffectHelper";
|
import EffectHelper from "../../src/helpers/EffectHelper";
|
||||||
|
|
||||||
|
@ -280,101 +279,3 @@ describe("HasEffect", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("GenerateEffectEmbed", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
UserEffect.FetchAllByUserIdPaginated = jest.fn()
|
|
||||||
.mockResolvedValue([
|
|
||||||
[],
|
|
||||||
0,
|
|
||||||
]);
|
|
||||||
|
|
||||||
await EffectHelper.GenerateEffectEmbed("userId", 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT UserEffect.FetchAllByUserIdPaginated to be called", () => {
|
|
||||||
expect(UserEffect.FetchAllByUserIdPaginated).toHaveBeenCalledTimes(1);
|
|
||||||
expect(UserEffect.FetchAllByUserIdPaginated).toHaveBeenCalledWith("userId", 0, 10);
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN there are no effects returned", () => {
|
|
||||||
let result: {
|
|
||||||
embed: EmbedBuilder,
|
|
||||||
row: ActionRowBuilder<ButtonBuilder>,
|
|
||||||
};
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
UserEffect.FetchAllByUserIdPaginated = jest.fn()
|
|
||||||
.mockResolvedValue([
|
|
||||||
[],
|
|
||||||
0,
|
|
||||||
]);
|
|
||||||
|
|
||||||
result = await EffectHelper.GenerateEffectEmbed("userId", 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT result returned", () => {
|
|
||||||
expect(result).toMatchSnapshot();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("GIVEN there are effects returned", () => {
|
|
||||||
let result: {
|
|
||||||
embed: EmbedBuilder,
|
|
||||||
row: ActionRowBuilder<ButtonBuilder>,
|
|
||||||
};
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
UserEffect.FetchAllByUserIdPaginated = jest.fn()
|
|
||||||
.mockResolvedValue([
|
|
||||||
[
|
|
||||||
{
|
|
||||||
Name: "name",
|
|
||||||
Unused: 1,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
1,
|
|
||||||
]);
|
|
||||||
|
|
||||||
result = await EffectHelper.GenerateEffectEmbed("userId", 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT result returned", () => {
|
|
||||||
expect(result).toMatchSnapshot();
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("AND it is the first page", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
result = await EffectHelper.GenerateEffectEmbed("userId", 1)
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT Previous button to be disabled", () => {
|
|
||||||
const button = result.row.components[0].data as unknown as {
|
|
||||||
label: string,
|
|
||||||
disabled: boolean
|
|
||||||
};
|
|
||||||
|
|
||||||
expect(button).toBeDefined();
|
|
||||||
expect(button.label).toBe("Previous");
|
|
||||||
expect(button.disabled).toBe(true);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("AND it is the last page", () => {
|
|
||||||
beforeEach(async () => {
|
|
||||||
result = await EffectHelper.GenerateEffectEmbed("userId", 1)
|
|
||||||
});
|
|
||||||
|
|
||||||
test("EXPECT Next button to be disabled", () => {
|
|
||||||
const button = result.row.components[1].data as unknown as {
|
|
||||||
label: string,
|
|
||||||
disabled: boolean
|
|
||||||
};
|
|
||||||
|
|
||||||
expect(button).toBeDefined();
|
|
||||||
expect(button.label).toBe("Next");
|
|
||||||
expect(button.disabled).toBe(true);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
|
@ -1,71 +0,0 @@
|
||||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
||||||
|
|
||||||
exports[`GenerateEffectEmbed GIVEN there are effects returned EXPECT result returned 1`] = `
|
|
||||||
{
|
|
||||||
"embed": {
|
|
||||||
"color": 3166394,
|
|
||||||
"description": "name x1",
|
|
||||||
"footer": {
|
|
||||||
"icon_url": undefined,
|
|
||||||
"text": "Page 1 of 1",
|
|
||||||
},
|
|
||||||
"title": "Effects",
|
|
||||||
},
|
|
||||||
"row": {
|
|
||||||
"components": [
|
|
||||||
{
|
|
||||||
"custom_id": "effects list 0",
|
|
||||||
"disabled": true,
|
|
||||||
"emoji": undefined,
|
|
||||||
"label": "Previous",
|
|
||||||
"style": 1,
|
|
||||||
"type": 2,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"custom_id": "effects list 2",
|
|
||||||
"disabled": true,
|
|
||||||
"emoji": undefined,
|
|
||||||
"label": "Next",
|
|
||||||
"style": 1,
|
|
||||||
"type": 2,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"type": 1,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
||||||
exports[`GenerateEffectEmbed GIVEN there are no effects returned EXPECT result returned 1`] = `
|
|
||||||
{
|
|
||||||
"embed": {
|
|
||||||
"color": 3166394,
|
|
||||||
"description": "*none*",
|
|
||||||
"footer": {
|
|
||||||
"icon_url": undefined,
|
|
||||||
"text": "Page 1 of 1",
|
|
||||||
},
|
|
||||||
"title": "Effects",
|
|
||||||
},
|
|
||||||
"row": {
|
|
||||||
"components": [
|
|
||||||
{
|
|
||||||
"custom_id": "effects list 0",
|
|
||||||
"disabled": true,
|
|
||||||
"emoji": undefined,
|
|
||||||
"label": "Previous",
|
|
||||||
"style": 1,
|
|
||||||
"type": 2,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"custom_id": "effects list 2",
|
|
||||||
"disabled": true,
|
|
||||||
"emoji": undefined,
|
|
||||||
"label": "Next",
|
|
||||||
"style": 1,
|
|
||||||
"type": 2,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"type": 1,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
`;
|
|
91
yarn.lock
91
yarn.lock
|
@ -1305,15 +1305,15 @@
|
||||||
ts-api-utils "^1.3.0"
|
ts-api-utils "^1.3.0"
|
||||||
|
|
||||||
"@typescript-eslint/eslint-plugin@^8.11.0":
|
"@typescript-eslint/eslint-plugin@^8.11.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.17.0.tgz#2ee073c421f4e81e02d10e731241664b6253b23c"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.16.0.tgz#ac56825bcdf3b392fc76a94b1315d4a162f201a6"
|
||||||
integrity sha512-HU1KAdW3Tt8zQkdvNoIijfWDMvdSweFYm4hWh+KwhPstv+sCmWb89hCIP8msFm9N1R/ooh9honpSuvqKWlYy3w==
|
integrity sha512-5YTHKV8MYlyMI6BaEG7crQ9BhSc8RxzshOReKwZwRWN0+XvvTOm+L/UYLCYxFpfwYuAAqhxiq4yae0CMFwbL7Q==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@eslint-community/regexpp" "^4.10.0"
|
"@eslint-community/regexpp" "^4.10.0"
|
||||||
"@typescript-eslint/scope-manager" "8.17.0"
|
"@typescript-eslint/scope-manager" "8.16.0"
|
||||||
"@typescript-eslint/type-utils" "8.17.0"
|
"@typescript-eslint/type-utils" "8.16.0"
|
||||||
"@typescript-eslint/utils" "8.17.0"
|
"@typescript-eslint/utils" "8.16.0"
|
||||||
"@typescript-eslint/visitor-keys" "8.17.0"
|
"@typescript-eslint/visitor-keys" "8.16.0"
|
||||||
graphemer "^1.4.0"
|
graphemer "^1.4.0"
|
||||||
ignore "^5.3.1"
|
ignore "^5.3.1"
|
||||||
natural-compare "^1.4.0"
|
natural-compare "^1.4.0"
|
||||||
|
@ -1338,13 +1338,13 @@
|
||||||
"@typescript-eslint/types" "8.11.0"
|
"@typescript-eslint/types" "8.11.0"
|
||||||
"@typescript-eslint/visitor-keys" "8.11.0"
|
"@typescript-eslint/visitor-keys" "8.11.0"
|
||||||
|
|
||||||
"@typescript-eslint/scope-manager@8.17.0":
|
"@typescript-eslint/scope-manager@8.16.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-8.17.0.tgz#a3f49bf3d4d27ff8d6b2ea099ba465ef4dbcaa3a"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-8.16.0.tgz#ebc9a3b399a69a6052f3d88174456dd399ef5905"
|
||||||
integrity sha512-/ewp4XjvnxaREtqsZjF4Mfn078RD/9GmiEAtTeLQ7yFdKnqwTOgRMSvFz4et9U5RiJQ15WTGXPLj89zGusvxBg==
|
integrity sha512-mwsZWubQvBki2t5565uxF0EYvG+FwdFb8bMtDuGQLdCCnGPrDEDvm1gtfynuKlnpzeBRqdFCkMf9jg1fnAK8sg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@typescript-eslint/types" "8.17.0"
|
"@typescript-eslint/types" "8.16.0"
|
||||||
"@typescript-eslint/visitor-keys" "8.17.0"
|
"@typescript-eslint/visitor-keys" "8.16.0"
|
||||||
|
|
||||||
"@typescript-eslint/type-utils@8.11.0":
|
"@typescript-eslint/type-utils@8.11.0":
|
||||||
version "8.11.0"
|
version "8.11.0"
|
||||||
|
@ -1356,13 +1356,13 @@
|
||||||
debug "^4.3.4"
|
debug "^4.3.4"
|
||||||
ts-api-utils "^1.3.0"
|
ts-api-utils "^1.3.0"
|
||||||
|
|
||||||
"@typescript-eslint/type-utils@8.17.0":
|
"@typescript-eslint/type-utils@8.16.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-8.17.0.tgz#d326569f498cdd0edf58d5bb6030b4ad914e63d3"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-8.16.0.tgz#585388735f7ac390f07c885845c3d185d1b64740"
|
||||||
integrity sha512-q38llWJYPd63rRnJ6wY/ZQqIzPrBCkPdpIsaCfkR3Q4t3p6sb422zougfad4TFW9+ElIFLVDzWGiGAfbb/v2qw==
|
integrity sha512-IqZHGG+g1XCWX9NyqnI/0CX5LL8/18awQqmkZSl2ynn8F76j579dByc0jhfVSnSnhf7zv76mKBQv9HQFKvDCgg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@typescript-eslint/typescript-estree" "8.17.0"
|
"@typescript-eslint/typescript-estree" "8.16.0"
|
||||||
"@typescript-eslint/utils" "8.17.0"
|
"@typescript-eslint/utils" "8.16.0"
|
||||||
debug "^4.3.4"
|
debug "^4.3.4"
|
||||||
ts-api-utils "^1.3.0"
|
ts-api-utils "^1.3.0"
|
||||||
|
|
||||||
|
@ -1371,10 +1371,10 @@
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-8.11.0.tgz#7c766250502097f49bbc2e651132e6bf489e20b8"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-8.11.0.tgz#7c766250502097f49bbc2e651132e6bf489e20b8"
|
||||||
integrity sha512-tn6sNMHf6EBAYMvmPUaKaVeYvhUsrE6x+bXQTxjQRp360h1giATU0WvgeEys1spbvb5R+VpNOZ+XJmjD8wOUHw==
|
integrity sha512-tn6sNMHf6EBAYMvmPUaKaVeYvhUsrE6x+bXQTxjQRp360h1giATU0WvgeEys1spbvb5R+VpNOZ+XJmjD8wOUHw==
|
||||||
|
|
||||||
"@typescript-eslint/types@8.17.0":
|
"@typescript-eslint/types@8.16.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-8.17.0.tgz#ef84c709ef8324e766878834970bea9a7e3b72cf"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-8.16.0.tgz#49c92ae1b57942458ab83d9ec7ccab3005e64737"
|
||||||
integrity sha512-gY2TVzeve3z6crqh2Ic7Cr+CAv6pfb0Egee7J5UAVWCpVvDI/F71wNfolIim4FE6hT15EbpZFVUj9j5i38jYXA==
|
integrity sha512-NzrHj6thBAOSE4d9bsuRNMvk+BvaQvmY4dDglgkgGC0EW/tB3Kelnp3tAKH87GEwzoxgeQn9fNGRyFJM/xd+GQ==
|
||||||
|
|
||||||
"@typescript-eslint/typescript-estree@8.11.0":
|
"@typescript-eslint/typescript-estree@8.11.0":
|
||||||
version "8.11.0"
|
version "8.11.0"
|
||||||
|
@ -1390,13 +1390,13 @@
|
||||||
semver "^7.6.0"
|
semver "^7.6.0"
|
||||||
ts-api-utils "^1.3.0"
|
ts-api-utils "^1.3.0"
|
||||||
|
|
||||||
"@typescript-eslint/typescript-estree@8.17.0":
|
"@typescript-eslint/typescript-estree@8.16.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-8.17.0.tgz#40b5903bc929b1e8dd9c77db3cb52cfb199a2a34"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-8.16.0.tgz#9d741e56e5b13469b5190e763432ce5551a9300c"
|
||||||
integrity sha512-JqkOopc1nRKZpX+opvKqnM3XUlM7LpFMD0lYxTqOTKQfCWAmxw45e3qlOCsEqEB2yuacujivudOFpCnqkBDNMw==
|
integrity sha512-E2+9IzzXMc1iaBy9zmo+UYvluE3TW7bCGWSF41hVWUE01o8nzr1rvOQYSxelxr6StUvRcTMe633eY8mXASMaNw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@typescript-eslint/types" "8.17.0"
|
"@typescript-eslint/types" "8.16.0"
|
||||||
"@typescript-eslint/visitor-keys" "8.17.0"
|
"@typescript-eslint/visitor-keys" "8.16.0"
|
||||||
debug "^4.3.4"
|
debug "^4.3.4"
|
||||||
fast-glob "^3.3.2"
|
fast-glob "^3.3.2"
|
||||||
is-glob "^4.0.3"
|
is-glob "^4.0.3"
|
||||||
|
@ -1414,15 +1414,15 @@
|
||||||
"@typescript-eslint/types" "8.11.0"
|
"@typescript-eslint/types" "8.11.0"
|
||||||
"@typescript-eslint/typescript-estree" "8.11.0"
|
"@typescript-eslint/typescript-estree" "8.11.0"
|
||||||
|
|
||||||
"@typescript-eslint/utils@8.17.0":
|
"@typescript-eslint/utils@8.16.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-8.17.0.tgz#41c05105a2b6ab7592f513d2eeb2c2c0236d8908"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-8.16.0.tgz#c71264c437157feaa97842809836254a6fc833c3"
|
||||||
integrity sha512-bQC8BnEkxqG8HBGKwG9wXlZqg37RKSMY7v/X8VEWD8JG2JuTHuNK0VFvMPMUKQcbk6B+tf05k+4AShAEtCtJ/w==
|
integrity sha512-C1zRy/mOL8Pj157GiX4kaw7iyRLKfJXBR3L82hk5kS/GyHcOFmy4YUq/zfZti72I9wnuQtA/+xzft4wCC8PJdA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@eslint-community/eslint-utils" "^4.4.0"
|
"@eslint-community/eslint-utils" "^4.4.0"
|
||||||
"@typescript-eslint/scope-manager" "8.17.0"
|
"@typescript-eslint/scope-manager" "8.16.0"
|
||||||
"@typescript-eslint/types" "8.17.0"
|
"@typescript-eslint/types" "8.16.0"
|
||||||
"@typescript-eslint/typescript-estree" "8.17.0"
|
"@typescript-eslint/typescript-estree" "8.16.0"
|
||||||
|
|
||||||
"@typescript-eslint/visitor-keys@8.11.0":
|
"@typescript-eslint/visitor-keys@8.11.0":
|
||||||
version "8.11.0"
|
version "8.11.0"
|
||||||
|
@ -1432,12 +1432,12 @@
|
||||||
"@typescript-eslint/types" "8.11.0"
|
"@typescript-eslint/types" "8.11.0"
|
||||||
eslint-visitor-keys "^3.4.3"
|
eslint-visitor-keys "^3.4.3"
|
||||||
|
|
||||||
"@typescript-eslint/visitor-keys@8.17.0":
|
"@typescript-eslint/visitor-keys@8.16.0":
|
||||||
version "8.17.0"
|
version "8.16.0"
|
||||||
resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-8.17.0.tgz#4dbcd0e28b9bf951f4293805bf34f98df45e1aa8"
|
resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-8.16.0.tgz#d5086afc060b01ff7a4ecab8d49d13d5a7b07705"
|
||||||
integrity sha512-1Hm7THLpO6ww5QU6H/Qp+AusUUl+z/CAm3cNZZ0jQvon9yicgO7Rwd+/WWRpMKLYV6p2UvdbR27c86rzCPpreg==
|
integrity sha512-pq19gbaMOmFE3CbL0ZB8J8BFCo2ckfHBfaIsaOZgBIF4EoISJIdLX5xRhd0FGB0LlHReNRuzoJoMGpTjq8F2CQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@typescript-eslint/types" "8.17.0"
|
"@typescript-eslint/types" "8.16.0"
|
||||||
eslint-visitor-keys "^4.2.0"
|
eslint-visitor-keys "^4.2.0"
|
||||||
|
|
||||||
"@vladfrangu/async_event_emitter@^2.2.4", "@vladfrangu/async_event_emitter@^2.4.6":
|
"@vladfrangu/async_event_emitter@^2.2.4", "@vladfrangu/async_event_emitter@^2.4.6":
|
||||||
|
@ -2279,20 +2279,13 @@ debug@2.6.9:
|
||||||
dependencies:
|
dependencies:
|
||||||
ms "2.0.0"
|
ms "2.0.0"
|
||||||
|
|
||||||
debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2:
|
debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.4:
|
||||||
version "4.3.7"
|
version "4.3.7"
|
||||||
resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.7.tgz#87945b4151a011d76d95a198d7111c865c360a52"
|
resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.7.tgz#87945b4151a011d76d95a198d7111c865c360a52"
|
||||||
integrity sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==
|
integrity sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
ms "^2.1.3"
|
ms "^2.1.3"
|
||||||
|
|
||||||
debug@^4.3.4:
|
|
||||||
version "4.4.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/debug/-/debug-4.4.0.tgz#2b3f2aea2ffeb776477460267377dc8710faba8a"
|
|
||||||
integrity sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==
|
|
||||||
dependencies:
|
|
||||||
ms "^2.1.3"
|
|
||||||
|
|
||||||
decompress-response@^4.2.0:
|
decompress-response@^4.2.0:
|
||||||
version "4.2.1"
|
version "4.2.1"
|
||||||
resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-4.2.1.tgz#414023cc7a302da25ce2ec82d0d5238ccafd8986"
|
resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-4.2.1.tgz#414023cc7a302da25ce2ec82d0d5238ccafd8986"
|
||||||
|
|
Loading…
Reference in a new issue