aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--package.json2
-rw-r--r--test.js72
2 files changed, 73 insertions, 1 deletions
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');
+});