From 255d07c718f5fab9ec28741abf4cc41fc2b52b13 Mon Sep 17 00:00:00 2001 From: Unknown Date: Wed, 7 Mar 2018 21:35:39 -0500 Subject: getting ready for ci --- package.json | 2 +- test.js | 72 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 73 insertions(+), 1 deletion(-) create mode 100644 test.js diff --git a/package.json b/package.json index 3660393..dd8cc47 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,7 @@ "description": "", "main": "bot.js", "scripts": { - "test": "echo \"Error: no test specified\" && exit 1" + "test": "node test.js" }, "author": "Alee, Justin, and Trey", "license": "GPL-3.0", diff --git a/test.js b/test.js new file mode 100644 index 0000000..69b8e71 --- /dev/null +++ b/test.js @@ -0,0 +1,72 @@ +const Discord = require('discord.js'); +const bot = new Discord.Client(); +const fs = require('fs'); + +bot.commands = new Discord.Collection(); +bot.aliases = new Discord.Collection(); +bot.categories = new Discord.Collection(); +bot.queue = new Discord.Collection(); +bot.plugins = { music : require('./Plugins/Music.js') }; +cmdLoader(); + +async function cmdLoader() { + const categories = await fs.readdirSync('./commands'); + console.log(`Loading ${categories.length} categories(s) into memory\n`); + categories.forEach(x => { + loadGroup(x); + }); +} +async function loadGroup(name) { + const files = await fs.readdirSync(`./commands/${name}`); + + console.log(`Loading the category '${name}' into memory with a total of ${files.length} command(s)`); + + bot.commands.set(name, new Map()); + bot.aliases.set(name, new Map()); + + const commands = []; + files.forEach(x => { + loadCmd(name, x); + commands.push(x.split('.')[0]); + }); + + bot.categories.set(name, commands); + console.log(`The category ${name} has been loaded.\n`); +} + +async function loadCmd(category, cmd) { + try { + console.log(`Loading the Command ${cmd.split('.')[0]}`); + const command = require(`./commands/${category}/${cmd}`); + bot.commands.get(category).set(command.help.name, command); + command.conf.aliases.forEach(alias => { + console.log(`Loading the alias ${alias} for the command ${command.help.name}`); + bot.aliases.get(category).set(alias, command.help.name); + }); + } + catch (err) { + console.log(`An error has occured trying to load the command '${cmd.split('.')[0]}'`); + console.log(err.stack); + } +} + + +fs.readdir('./events', (err, files) => { + if (err) console.error(err); + console.log(`Attempting to load a total of ${files.length} events into the memory.`); + files.forEach(file => { + try { + const eventName = file.split('.')[0]; + const event = require(`./events/${file}`); + console.log(`Attempting to load the event "${eventName}".`); + bot.on(eventName, event.bind(null, bot)); + delete require.cache[require.resolve(`./events/${file}`)]; + } + catch (err) { + console.log('An error has occured trying to load a event. Here is the error.'); + console.log(err.stack); + } + }); + console.log('Event Loading complete!'); + console.log('\n'); +}); -- cgit v1.2.3