Files
discordeno/tests/channels/swap_channels.ts
T
Skillz4Killz 3d39b3878a change: ids to use bigint instead of string (#892)
* p1 of bigints change

* shtuff fixes and bits

* Commit from GitHub Actions (Lint)

* finish bigint structs

* typings fixes

* Commit from GitHub Actions (Lint)

* more fixes

* Commit from GitHub Actions (Lint)

* more fixes

* Commit from GitHub Actions (Lint)

* blame wolf

* Commit from GitHub Actions (Lint)

* foxed

* Commit from GitHub Actions (Lint)

* fix unit tests

* Commit from GitHub Actions (Lint)

* change: guildUpdate guild ID can't change

* delete server has been renamed to delete guild

* fixes

Co-authored-by: Skillz4Killz <Skillz4Killz@users.noreply.github.com>
Co-authored-by: ITOH <72305210+itohatweb@users.noreply.github.com>
2021-05-03 18:05:18 +01:00

71 lines
1.9 KiB
TypeScript

import { cache } from "../../src/cache.ts";
import { createChannel } from "../../src/helpers/channels/create_channel.ts";
import { swapChannels } from "../../src/helpers/channels/swap_channels.ts";
import { assertEquals, assertExists } from "../deps.ts";
import { delayUntil } from "../util/delay_until.ts";
import { defaultTestOptions, tempData } from "../ws/start_bot.ts";
Deno.test({
name: "[channel] swap channels",
async fn() {
const channel = await createChannel(tempData.guildId, {
name: "channel-1",
});
// Assertions
assertExists(channel);
const secondChannel = await createChannel(tempData.guildId, {
name: "channel-2",
});
// Assertions
assertExists(channel);
// Delay the execution by 5 seconds to allow CHANNEL_CREATE event to be processed
await delayUntil(
10000,
() =>
cache.channels.has(channel.id) && cache.channels.has(secondChannel.id),
);
if (
!cache.channels.has(channel.id) || !cache.channels.has(secondChannel.id)
) {
throw new Error(
"The channel seemed to be created but it was not cached.",
);
}
await swapChannels(tempData.guildId, [
{
id: channel.id.toString(),
position: secondChannel.position!,
},
{
id: secondChannel.id.toString(),
position: channel.position!,
},
]);
// Delay the execution by 5 seconds to allow CHANNEL_UPDATE event to be processed
await delayUntil(
10000,
() =>
cache.channels.get(channel.id)?.position === secondChannel.position &&
cache.channels.get(secondChannel.id)?.position === channel.position,
);
assertEquals(
cache.channels.get(channel.id)?.position,
secondChannel.position,
);
assertEquals(
cache.channels.get(secondChannel.id)?.position,
channel.position,
);
},
...defaultTestOptions,
});