Vylpes
04a4a6204c
* Change rules.txt to rules.json (#31) * Migrate to yarn * Add role configs to config template * Install packges and setup typescript * Migrate entry point * Migrate about command * Migrate ban command * Migrate clear command * Migrate kick command * Migrate mute command * Migrate poll command * Migrate bunny command * Update required roles checker * Migrate role command * Migrate unmute command * Migrate warn command * Migrate eval command * Migrate help command * Migrate rules command * Migrate events to typescript * Update about command to use the PublicEmbed class * Update ErrorMessage to ChannelNotFound * Update messageDelete event to ignore bots * Feature/74 merge vylbot core (#80) * Merge VylBot-Core * Update commands to new system * Fix issue where events would not load * Feature/12 create tests (#102) * Fix tests * Update coverage * Remove unrequired mock files * Add about command test * Update about tests * Ban command tests * eval command tests * Start help command tests * Add help command tests * Add kick command tests * Mute command tests * Poll command tests * Add role command tests Signed-off-by: Ethan Lane <ethan@vylpes.com> * Add rules command tests * Add unmute command tests * Add warn command tests * Add MemberEvents tests * Add GuildMemberUpdate tests Signed-off-by: Ethan Lane <ethan@vylpes.com> * Add MessageEvents tests * Add StringTools test Signed-off-by: Ethan Lane <ethan@vylpes.com> * Add embed tests Signed-off-by: Ethan Lane <ethan@vylpes.com> * Add GitHub Actions Signed-off-by: Ethan Lane <ethan@vylpes.com> * Move to tslint Signed-off-by: Ethan Lane <ethan@vylpes.com> * Remove tslint Signed-off-by: Ethan Lane <ethan@vylpes.com> * Remove linting script Signed-off-by: Ethan Lane <ethan@vylpes.com> * Update rules with blog website and event spoilers rule" (#106) Signed-off-by: Ethan Lane <ethan@vylpes.com> * Containerise bot (#107) * Add moderator names to audit reason (#108) * Feature/48 database (#114) * Add database and default values * Add ability to save a setting to the database * Get commands and events to use database * Setup and config command * Update commands to check roles per server * Different rules per server Signed-off-by: Ethan Lane <ethan@vylpes.com> * Different prefix per server Signed-off-by: Ethan Lane <ethan@vylpes.com> * Add verification system Signed-off-by: Ethan Lane <ethan@vylpes.com> * Disabled commands per server * Add devmode for default prefix * Update embeds * Fix broken tests * Feature/66 add different commands per server (#122) * Add ability for server exclusive commands * Add MankBot server-exclusive commands * Add lobby entity to database * Add documentation * Add setup command for lobby (#123) * Update bot to discord.js v13 (#125) * Update bot to discord.js v13 * Remove debug code * 110 commandshelp about command errors which causes command to not run (#126) * Change onMessage to onMessageCreate * Fix help command * Add override for bot owner and server owner (#135) * Change help command so exclusive commands can only be seen for the server they're assigned to (#136) * Change parsing to not crash if invalid (#142) * 137 role command cannot read properties of undefined (#141) * Fix issue with bot crashing * Fix server prefix not showing * Add easy way to configure role command * Move help text to its own directory * Make role config command to use role id * Get lobby command to use IDs instead of names (#144) Co-authored-by: Vylpes <getgravitysoftware@gmail.com>
164 lines
No EOL
5.1 KiB
TypeScript
164 lines
No EOL
5.1 KiB
TypeScript
import { GuildMember, TextChannel, User } from "discord.js";
|
|
import MemberEvents from "../../src/events/MemberEvents";
|
|
import GuildMemberUpdate from "../../src/events/MemberEvents/GuildMemberUpdate";
|
|
|
|
describe('GuildMemberAdd', () => {
|
|
test('When event is fired, expect embed to be sent to logs channel', async () => {
|
|
const currentDate = new Date();
|
|
|
|
const textChannel = {
|
|
send: jest.fn()
|
|
} as unknown as TextChannel;
|
|
|
|
const memberGuildChannelsCacheFind = jest.fn()
|
|
.mockReturnValue(textChannel);
|
|
const userDisplayAvatarURL = jest.fn();
|
|
|
|
const guildUser = {
|
|
tag: 'USERTAG',
|
|
createdAt: currentDate,
|
|
id: 'USERID',
|
|
displayAvatarURL: userDisplayAvatarURL
|
|
} as unknown as User;
|
|
|
|
const guildMember = {
|
|
user: guildUser,
|
|
guild: {
|
|
channels: {
|
|
cache: {
|
|
find: memberGuildChannelsCacheFind
|
|
}
|
|
}
|
|
}
|
|
} as unknown as GuildMember;
|
|
|
|
const memberEvents = new MemberEvents();
|
|
|
|
const result = await memberEvents.guildMemberAdd(guildMember);
|
|
|
|
expect(textChannel.send).toBeCalledTimes(1);
|
|
expect(userDisplayAvatarURL).toBeCalledTimes(1);
|
|
expect(result.embeds.length).toBe(1);
|
|
|
|
// Embed
|
|
const embed = result.embeds[0];
|
|
|
|
expect(embed.title).toBe("Member Joined");
|
|
expect(embed.footer?.text).toBe("Id: USERID");
|
|
expect(embed.fields.length).toBe(2);
|
|
|
|
// Embed -> User Field
|
|
const embedFieldUser = embed.fields[0];
|
|
|
|
expect(embedFieldUser.name).toBe("User");
|
|
expect(embedFieldUser.value).toBe("[object Object] `USERTAG`");
|
|
expect(embedFieldUser.inline).toBeTruthy();
|
|
|
|
// Embed -> Created Field
|
|
const embedFieldCreated = embed.fields[1];
|
|
|
|
expect(embedFieldCreated.name).toBe("Created");
|
|
expect(embedFieldCreated.value).toBe(currentDate.toString());
|
|
});
|
|
});
|
|
|
|
describe('GuildMemberRemove', () => {
|
|
test('When event is fired, expect embed to be sent to logs channel', async () => {
|
|
const currentDate = new Date();
|
|
|
|
const textChannel = {
|
|
send: jest.fn()
|
|
} as unknown as TextChannel;
|
|
|
|
const memberGuildChannelsCacheFind = jest.fn()
|
|
.mockReturnValue(textChannel);
|
|
const userDisplayAvatarURL = jest.fn();
|
|
|
|
const guildUser = {
|
|
tag: 'USERTAG',
|
|
createdAt: currentDate,
|
|
id: 'USERID',
|
|
displayAvatarURL: userDisplayAvatarURL
|
|
} as unknown as User;
|
|
|
|
const guildMember = {
|
|
user: guildUser,
|
|
guild: {
|
|
channels: {
|
|
cache: {
|
|
find: memberGuildChannelsCacheFind
|
|
}
|
|
}
|
|
},
|
|
joinedAt: currentDate
|
|
} as unknown as GuildMember;
|
|
|
|
const memberEvents = new MemberEvents();
|
|
|
|
const result = await memberEvents.guildMemberRemove(guildMember);
|
|
|
|
expect(textChannel.send).toBeCalledTimes(1);
|
|
expect(userDisplayAvatarURL).toBeCalledTimes(1);
|
|
expect(result.embeds.length).toBe(1);
|
|
|
|
// Embed
|
|
const embed = result.embeds[0];
|
|
|
|
expect(embed.title).toBe("Member Left");
|
|
expect(embed.footer?.text).toBe("Id: USERID");
|
|
expect(embed.fields.length).toBe(2);
|
|
|
|
// Embed -> User Field
|
|
const embedFieldUser = embed.fields[0];
|
|
|
|
expect(embedFieldUser.name).toBe("User");
|
|
expect(embedFieldUser.value).toBe("[object Object] `USERTAG`");
|
|
expect(embedFieldUser.inline).toBeTruthy();
|
|
|
|
// Embed -> Joined Field
|
|
const embedFieldJoined = embed.fields[1];
|
|
|
|
expect(embedFieldJoined.name).toBe("Joined");
|
|
expect(embedFieldJoined.value).toBe(currentDate.toString());
|
|
});
|
|
});
|
|
|
|
describe('GuildMemberUpdate', () => {
|
|
test('Given nicknames are the same, expect NicknameChanged NOT to be called', async () => {
|
|
const member = {
|
|
nickname: 'member'
|
|
} as unknown as GuildMember;
|
|
|
|
const nicknameChanged = jest.fn();
|
|
|
|
GuildMemberUpdate.prototype.NicknameChanged = nicknameChanged;
|
|
|
|
const memberEvents = new MemberEvents();
|
|
|
|
const result = await memberEvents.guildMemberUpdate(member, member);
|
|
|
|
expect(result.embeds.length).toBe(0);
|
|
expect(nicknameChanged).not.toBeCalled();
|
|
});
|
|
|
|
test('Given nicknames are the different, expect NicknameChanged to be called', async () => {
|
|
const oldMember = {
|
|
nickname: 'oldMember'
|
|
} as unknown as GuildMember;
|
|
|
|
const newMember = {
|
|
nickname: 'newMember'
|
|
} as unknown as GuildMember;
|
|
|
|
const nicknameChanged = jest.fn();
|
|
|
|
GuildMemberUpdate.prototype.NicknameChanged = nicknameChanged;
|
|
|
|
const memberEvents = new MemberEvents();
|
|
|
|
const result = await memberEvents.guildMemberUpdate(oldMember, newMember);
|
|
|
|
expect(result.embeds.length).toBe(0);
|
|
expect(nicknameChanged).toBeCalledTimes(1);
|
|
});
|
|
}); |