diff --git a/.gradle/7.3.3/checksums/checksums.lock b/.gradle/7.3.3/checksums/checksums.lock new file mode 100644 index 00000000..91546aa5 Binary files /dev/null and b/.gradle/7.3.3/checksums/checksums.lock differ diff --git a/.gradle/7.3.3/checksums/md5-checksums.bin b/.gradle/7.3.3/checksums/md5-checksums.bin new file mode 100644 index 00000000..b93344ce Binary files /dev/null and b/.gradle/7.3.3/checksums/md5-checksums.bin differ diff --git a/.gradle/7.3.3/checksums/sha1-checksums.bin b/.gradle/7.3.3/checksums/sha1-checksums.bin new file mode 100644 index 00000000..a4273211 Binary files /dev/null and b/.gradle/7.3.3/checksums/sha1-checksums.bin differ diff --git a/.gradle/7.3.3/dependencies-accessors/dependencies-accessors.lock b/.gradle/7.3.3/dependencies-accessors/dependencies-accessors.lock new file mode 100644 index 00000000..efdcc15d Binary files /dev/null and b/.gradle/7.3.3/dependencies-accessors/dependencies-accessors.lock differ diff --git a/.gradle/7.3.3/dependencies-accessors/gc.properties b/.gradle/7.3.3/dependencies-accessors/gc.properties new file mode 100644 index 00000000..e69de29b diff --git a/.gradle/7.3.3/executionHistory/executionHistory.bin b/.gradle/7.3.3/executionHistory/executionHistory.bin new file mode 100644 index 00000000..bf99046b Binary files /dev/null and b/.gradle/7.3.3/executionHistory/executionHistory.bin differ diff --git a/.gradle/7.3.3/executionHistory/executionHistory.lock b/.gradle/7.3.3/executionHistory/executionHistory.lock new file mode 100644 index 00000000..cca9d545 Binary files /dev/null and b/.gradle/7.3.3/executionHistory/executionHistory.lock differ diff --git a/.gradle/7.3.3/fileChanges/last-build.bin b/.gradle/7.3.3/fileChanges/last-build.bin new file mode 100644 index 00000000..f76dd238 Binary files /dev/null and b/.gradle/7.3.3/fileChanges/last-build.bin differ diff --git a/.gradle/7.3.3/fileHashes/fileHashes.bin b/.gradle/7.3.3/fileHashes/fileHashes.bin new file mode 100644 index 00000000..c15d1500 Binary files /dev/null and b/.gradle/7.3.3/fileHashes/fileHashes.bin differ diff --git a/.gradle/7.3.3/fileHashes/fileHashes.lock b/.gradle/7.3.3/fileHashes/fileHashes.lock new file mode 100644 index 00000000..23f0c2b5 Binary files /dev/null and b/.gradle/7.3.3/fileHashes/fileHashes.lock differ diff --git a/.gradle/7.3.3/fileHashes/resourceHashesCache.bin b/.gradle/7.3.3/fileHashes/resourceHashesCache.bin new file mode 100644 index 00000000..07dee091 Binary files /dev/null and b/.gradle/7.3.3/fileHashes/resourceHashesCache.bin differ diff --git a/.gradle/7.3.3/gc.properties b/.gradle/7.3.3/gc.properties new file mode 100644 index 00000000..e69de29b diff --git a/.gradle/buildOutputCleanup/buildOutputCleanup.lock b/.gradle/buildOutputCleanup/buildOutputCleanup.lock new file mode 100644 index 00000000..acd2d26b Binary files /dev/null and b/.gradle/buildOutputCleanup/buildOutputCleanup.lock differ diff --git a/.gradle/buildOutputCleanup/cache.properties b/.gradle/buildOutputCleanup/cache.properties new file mode 100644 index 00000000..1523ff41 --- /dev/null +++ b/.gradle/buildOutputCleanup/cache.properties @@ -0,0 +1,2 @@ +#Sun Mar 03 10:18:29 PST 2024 +gradle.version=7.3.3 diff --git a/.gradle/buildOutputCleanup/outputFiles.bin b/.gradle/buildOutputCleanup/outputFiles.bin new file mode 100644 index 00000000..6a2a7497 Binary files /dev/null and b/.gradle/buildOutputCleanup/outputFiles.bin differ diff --git a/.gradle/file-system.probe b/.gradle/file-system.probe new file mode 100644 index 00000000..cf4f26a9 Binary files /dev/null and b/.gradle/file-system.probe differ diff --git a/.gradle/vcs-1/gc.properties b/.gradle/vcs-1/gc.properties new file mode 100644 index 00000000..e69de29b diff --git a/build/reports/tests/test/classes/org.jointheleague.features.student.third_feature.HolidaysTest.html b/build/reports/tests/test/classes/org.jointheleague.features.student.third_feature.HolidaysTest.html new file mode 100644 index 00000000..71764f18 --- /dev/null +++ b/build/reports/tests/test/classes/org.jointheleague.features.student.third_feature.HolidaysTest.html @@ -0,0 +1,116 @@ + + + + + +Test results - HolidaysTest + + + + + +
+

HolidaysTest

+ +
+ + + + + +
+
+ + + + + + + +
+
+
5
+

tests

+
+
+
+
0
+

failures

+
+
+
+
0
+

ignored

+
+
+
+
1.637s
+

duration

+
+
+
+
+
+
100%
+

successful

+
+
+
+
+ +
+

Tests

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
TestDurationResult
itShouldHandleMessagesWithCommand()0.035spassed
itShouldHaveACommand()1.470spassed
itShouldHaveAHelpEmbed()0.021spassed
itShouldHaveTheCommandAsTheTitleOfTheHelpEmbed()0.008spassed
itShouldNotHandleMessagesWithoutCommand()0.103spassed
+
+
+ +
+ + diff --git a/build/reports/tests/test/css/base-style.css b/build/reports/tests/test/css/base-style.css new file mode 100644 index 00000000..4afa73e3 --- /dev/null +++ b/build/reports/tests/test/css/base-style.css @@ -0,0 +1,179 @@ + +body { + margin: 0; + padding: 0; + font-family: sans-serif; + font-size: 12pt; +} + +body, a, a:visited { + color: #303030; +} + +#content { + padding-left: 50px; + padding-right: 50px; + padding-top: 30px; + padding-bottom: 30px; +} + +#content h1 { + font-size: 160%; + margin-bottom: 10px; +} + +#footer { + margin-top: 100px; + font-size: 80%; + white-space: nowrap; +} + +#footer, #footer a { + color: #a0a0a0; +} + +#line-wrapping-toggle { + vertical-align: middle; +} + +#label-for-line-wrapping-toggle { + vertical-align: middle; +} + +ul { + margin-left: 0; +} + +h1, h2, h3 { + white-space: nowrap; +} + +h2 { + font-size: 120%; +} + +ul.tabLinks { + padding-left: 0; + padding-top: 10px; + padding-bottom: 10px; + overflow: auto; + min-width: 800px; + width: auto !important; + width: 800px; +} + +ul.tabLinks li { + float: left; + height: 100%; + list-style: none; + padding-left: 10px; + padding-right: 10px; + padding-top: 5px; + padding-bottom: 5px; + margin-bottom: 0; + -moz-border-radius: 7px; + border-radius: 7px; + margin-right: 25px; + border: solid 1px #d4d4d4; + background-color: #f0f0f0; +} + +ul.tabLinks li:hover { + background-color: #fafafa; +} + +ul.tabLinks li.selected { + background-color: #c5f0f5; + border-color: #c5f0f5; +} + +ul.tabLinks a { + font-size: 120%; + display: block; + outline: none; + text-decoration: none; + margin: 0; + padding: 0; +} + +ul.tabLinks li h2 { + margin: 0; + padding: 0; +} + +div.tab { +} + +div.selected { + display: block; +} + +div.deselected { + display: none; +} + +div.tab table { + min-width: 350px; + width: auto !important; + width: 350px; + border-collapse: collapse; +} + +div.tab th, div.tab table { + border-bottom: solid #d0d0d0 1px; +} + +div.tab th { + text-align: left; + white-space: nowrap; + padding-left: 6em; +} + +div.tab th:first-child { + padding-left: 0; +} + +div.tab td { + white-space: nowrap; + padding-left: 6em; + padding-top: 5px; + padding-bottom: 5px; +} + +div.tab td:first-child { + padding-left: 0; +} + +div.tab td.numeric, div.tab th.numeric { + text-align: right; +} + +span.code { + display: inline-block; + margin-top: 0em; + margin-bottom: 1em; +} + +span.code pre { + font-size: 11pt; + padding-top: 10px; + padding-bottom: 10px; + padding-left: 10px; + padding-right: 10px; + margin: 0; + background-color: #f7f7f7; + border: solid 1px #d0d0d0; + min-width: 700px; + width: auto !important; + width: 700px; +} + +span.wrapped pre { + word-wrap: break-word; + white-space: pre-wrap; + word-break: break-all; +} + +label.hidden { + display: none; +} \ No newline at end of file diff --git a/build/reports/tests/test/css/style.css b/build/reports/tests/test/css/style.css new file mode 100644 index 00000000..3dc4913e --- /dev/null +++ b/build/reports/tests/test/css/style.css @@ -0,0 +1,84 @@ + +#summary { + margin-top: 30px; + margin-bottom: 40px; +} + +#summary table { + border-collapse: collapse; +} + +#summary td { + vertical-align: top; +} + +.breadcrumbs, .breadcrumbs a { + color: #606060; +} + +.infoBox { + width: 110px; + padding-top: 15px; + padding-bottom: 15px; + text-align: center; +} + +.infoBox p { + margin: 0; +} + +.counter, .percent { + font-size: 120%; + font-weight: bold; + margin-bottom: 8px; +} + +#duration { + width: 125px; +} + +#successRate, .summaryGroup { + border: solid 2px #d0d0d0; + -moz-border-radius: 10px; + border-radius: 10px; +} + +#successRate { + width: 140px; + margin-left: 35px; +} + +#successRate .percent { + font-size: 180%; +} + +.success, .success a { + color: #008000; +} + +div.success, #successRate.success { + background-color: #bbd9bb; + border-color: #008000; +} + +.failures, .failures a { + color: #b60808; +} + +.skipped, .skipped a { + color: #c09853; +} + +div.failures, #successRate.failures { + background-color: #ecdada; + border-color: #b60808; +} + +ul.linkList { + padding-left: 0; +} + +ul.linkList li { + list-style: none; + margin-bottom: 5px; +} diff --git a/build/reports/tests/test/index.html b/build/reports/tests/test/index.html new file mode 100644 index 00000000..cf301751 --- /dev/null +++ b/build/reports/tests/test/index.html @@ -0,0 +1,133 @@ + + + + + +Test results - Test Summary + + + + + +
+

Test Summary

+
+ + + + + +
+
+ + + + + + + +
+
+
5
+

tests

+
+
+
+
0
+

failures

+
+
+
+
0
+

ignored

+
+
+
+
1.637s
+

duration

+
+
+
+
+
+
100%
+

successful

+
+
+
+
+ +
+

Packages

+ + + + + + + + + + + + + + + + + + + + + +
PackageTestsFailuresIgnoredDurationSuccess rate
+org.jointheleague.features.student.third_feature +5001.637s100%
+
+
+

Classes

+ + + + + + + + + + + + + + + + + + + + + +
ClassTestsFailuresIgnoredDurationSuccess rate
+org.jointheleague.features.student.third_feature.HolidaysTest +5001.637s100%
+
+
+ +
+ + diff --git a/build/reports/tests/test/js/report.js b/build/reports/tests/test/js/report.js new file mode 100644 index 00000000..83bab4a1 --- /dev/null +++ b/build/reports/tests/test/js/report.js @@ -0,0 +1,194 @@ +(function (window, document) { + "use strict"; + + var tabs = {}; + + function changeElementClass(element, classValue) { + if (element.getAttribute("className")) { + element.setAttribute("className", classValue); + } else { + element.setAttribute("class", classValue); + } + } + + function getClassAttribute(element) { + if (element.getAttribute("className")) { + return element.getAttribute("className"); + } else { + return element.getAttribute("class"); + } + } + + function addClass(element, classValue) { + changeElementClass(element, getClassAttribute(element) + " " + classValue); + } + + function removeClass(element, classValue) { + changeElementClass(element, getClassAttribute(element).replace(classValue, "")); + } + + function initTabs() { + var container = document.getElementById("tabs"); + + tabs.tabs = findTabs(container); + tabs.titles = findTitles(tabs.tabs); + tabs.headers = findHeaders(container); + tabs.select = select; + tabs.deselectAll = deselectAll; + tabs.select(0); + + return true; + } + + function getCheckBox() { + return document.getElementById("line-wrapping-toggle"); + } + + function getLabelForCheckBox() { + return document.getElementById("label-for-line-wrapping-toggle"); + } + + function findCodeBlocks() { + var spans = document.getElementById("tabs").getElementsByTagName("span"); + var codeBlocks = []; + for (var i = 0; i < spans.length; ++i) { + if (spans[i].className.indexOf("code") >= 0) { + codeBlocks.push(spans[i]); + } + } + return codeBlocks; + } + + function forAllCodeBlocks(operation) { + var codeBlocks = findCodeBlocks(); + + for (var i = 0; i < codeBlocks.length; ++i) { + operation(codeBlocks[i], "wrapped"); + } + } + + function toggleLineWrapping() { + var checkBox = getCheckBox(); + + if (checkBox.checked) { + forAllCodeBlocks(addClass); + } else { + forAllCodeBlocks(removeClass); + } + } + + function initControls() { + if (findCodeBlocks().length > 0) { + var checkBox = getCheckBox(); + var label = getLabelForCheckBox(); + + checkBox.onclick = toggleLineWrapping; + checkBox.checked = false; + + removeClass(label, "hidden"); + } + } + + function switchTab() { + var id = this.id.substr(1); + + for (var i = 0; i < tabs.tabs.length; i++) { + if (tabs.tabs[i].id === id) { + tabs.select(i); + break; + } + } + + return false; + } + + function select(i) { + this.deselectAll(); + + changeElementClass(this.tabs[i], "tab selected"); + changeElementClass(this.headers[i], "selected"); + + while (this.headers[i].firstChild) { + this.headers[i].removeChild(this.headers[i].firstChild); + } + + var h2 = document.createElement("H2"); + + h2.appendChild(document.createTextNode(this.titles[i])); + this.headers[i].appendChild(h2); + } + + function deselectAll() { + for (var i = 0; i < this.tabs.length; i++) { + changeElementClass(this.tabs[i], "tab deselected"); + changeElementClass(this.headers[i], "deselected"); + + while (this.headers[i].firstChild) { + this.headers[i].removeChild(this.headers[i].firstChild); + } + + var a = document.createElement("A"); + + a.setAttribute("id", "ltab" + i); + a.setAttribute("href", "#tab" + i); + a.onclick = switchTab; + a.appendChild(document.createTextNode(this.titles[i])); + + this.headers[i].appendChild(a); + } + } + + function findTabs(container) { + return findChildElements(container, "DIV", "tab"); + } + + function findHeaders(container) { + var owner = findChildElements(container, "UL", "tabLinks"); + return findChildElements(owner[0], "LI", null); + } + + function findTitles(tabs) { + var titles = []; + + for (var i = 0; i < tabs.length; i++) { + var tab = tabs[i]; + var header = findChildElements(tab, "H2", null)[0]; + + header.parentNode.removeChild(header); + + if (header.innerText) { + titles.push(header.innerText); + } else { + titles.push(header.textContent); + } + } + + return titles; + } + + function findChildElements(container, name, targetClass) { + var elements = []; + var children = container.childNodes; + + for (var i = 0; i < children.length; i++) { + var child = children.item(i); + + if (child.nodeType === 1 && child.nodeName === name) { + if (targetClass && child.className.indexOf(targetClass) < 0) { + continue; + } + + elements.push(child); + } + } + + return elements; + } + + // Entry point. + + window.onload = function() { + initTabs(); + initControls(); + }; +} (window, window.document)); \ No newline at end of file diff --git a/build/reports/tests/test/packages/org.jointheleague.features.student.third_feature.html b/build/reports/tests/test/packages/org.jointheleague.features.student.third_feature.html new file mode 100644 index 00000000..b175a3cf --- /dev/null +++ b/build/reports/tests/test/packages/org.jointheleague.features.student.third_feature.html @@ -0,0 +1,103 @@ + + + + + +Test results - Package org.jointheleague.features.student.third_feature + + + + + +
+

Package org.jointheleague.features.student.third_feature

+ +
+ + + + + +
+
+ + + + + + + +
+
+
5
+

tests

+
+
+
+
0
+

failures

+
+
+
+
0
+

ignored

+
+
+
+
1.637s
+

duration

+
+
+
+
+
+
100%
+

successful

+
+
+
+
+ +
+

Classes

+ + + + + + + + + + + + + + + + + + + +
ClassTestsFailuresIgnoredDurationSuccess rate
+HolidaysTest +5001.637s100%
+
+
+ +
+ + diff --git a/build/test-results/test/binary/output.bin b/build/test-results/test/binary/output.bin new file mode 100644 index 00000000..e69de29b diff --git a/build/test-results/test/binary/output.bin.idx b/build/test-results/test/binary/output.bin.idx new file mode 100644 index 00000000..f76dd238 Binary files /dev/null and b/build/test-results/test/binary/output.bin.idx differ diff --git a/build/test-results/test/binary/results.bin b/build/test-results/test/binary/results.bin new file mode 100644 index 00000000..823dfca9 Binary files /dev/null and b/build/test-results/test/binary/results.bin differ diff --git a/build/tmp/compileJava/previous-compilation-data.bin b/build/tmp/compileJava/previous-compilation-data.bin new file mode 100644 index 00000000..a103abd9 Binary files /dev/null and b/build/tmp/compileJava/previous-compilation-data.bin differ diff --git a/build/tmp/compileTestJava/previous-compilation-data.bin b/build/tmp/compileTestJava/previous-compilation-data.bin new file mode 100644 index 00000000..2866c021 Binary files /dev/null and b/build/tmp/compileTestJava/previous-compilation-data.bin differ diff --git a/src/main/java/org/jointheleague/discord_bot/DiscordBot.java b/src/main/java/org/jointheleague/discord_bot/DiscordBot.java index ae863505..f3fd8d6e 100644 --- a/src/main/java/org/jointheleague/discord_bot/DiscordBot.java +++ b/src/main/java/org/jointheleague/discord_bot/DiscordBot.java @@ -8,9 +8,11 @@ import org.jointheleague.features.examples.third_features.CatFactsApi; import org.jointheleague.features.examples.third_features.NewsApi; import org.jointheleague.features.examples.first_features.CurrentTime; -import org.jointheleague.features.examples.first_features.RandomNumber; import org.jointheleague.features.help_embed.HelpListener; import org.jointheleague.features.student.first_feature.FeatureOne; +import org.jointheleague.features.student.first_feature.Hello; +import org.jointheleague.features.student.second_feature.Trivia; +import org.jointheleague.features.student.third_feature.Holidays; public class DiscordBot { @@ -50,6 +52,9 @@ public void connect(boolean printInvite) { addFeature(new HighLowGame(channelName)); addFeature(new NewsApi(channelName)); addFeature(new CatFactsApi(channelName)); + addFeature(new Trivia(channelName)); + addFeature(new Hello(channelName)); + addFeature(new Holidays(channelName)); } private void addFeature(Feature feature){ diff --git a/src/main/java/org/jointheleague/features/student/first_feature/Hello.java b/src/main/java/org/jointheleague/features/student/first_feature/Hello.java new file mode 100644 index 00000000..d633ae3d --- /dev/null +++ b/src/main/java/org/jointheleague/features/student/first_feature/Hello.java @@ -0,0 +1,49 @@ +package org.jointheleague.features.student.first_feature; + +import org.javacord.api.event.message.MessageCreateEvent; +import org.jointheleague.features.abstract_classes.Feature; +import org.jointheleague.features.help_embed.plain_old_java_objects.help_embed.HelpEmbed; + +import java.util.Random; + +public class Hello extends Feature{ + public final String COMMAND = "!hello"; + Random ran = new Random(); + int responseNum; + + public Hello(String channelName) { + super(channelName); + + //Create a help embed to describe feature when !help command is sent + helpEmbed = new HelpEmbed( + COMMAND, + "The bot will respond with hello in a random language." + ); + } + + @Override + public void handle(MessageCreateEvent event) { + String messageContent = event.getMessageContent(); + if (messageContent.startsWith(COMMAND)) { + responseNum = ran.nextInt(5); + switch(responseNum){ + case 0: + event.getChannel().sendMessage("Hello"); + break; + case 1: + event.getChannel().sendMessage("Bonjour"); + break; + case 2: + event.getChannel().sendMessage("Hola"); + break; + case 3: + event.getChannel().sendMessage("Ciao"); + break; + case 4: + event.getChannel().sendMessage("Shalom"); + break; + } + + } + } +} diff --git a/src/main/java/org/jointheleague/features/student/second_feature/Trivia.java b/src/main/java/org/jointheleague/features/student/second_feature/Trivia.java new file mode 100644 index 00000000..5ce1a7f4 --- /dev/null +++ b/src/main/java/org/jointheleague/features/student/second_feature/Trivia.java @@ -0,0 +1,95 @@ +package org.jointheleague.features.student.second_feature; + +import org.javacord.api.event.message.MessageCreateEvent; +import org.jointheleague.features.abstract_classes.Feature; +import org.jointheleague.features.help_embed.plain_old_java_objects.help_embed.HelpEmbed; + +import java.util.ArrayList; +import java.util.Random; + +public class Trivia extends Feature { + + public final String COMMAND = "!trivia"; + public boolean questionRight = false; + int questionNumber; + String answer; + Random ran = new Random(); + int score = 0; + public Trivia(String channelName) { + super(channelName); + + //Create a help embed to describe feature when !help command is sent + helpEmbed = new HelpEmbed( + COMMAND, + "Trivia questions for the user to answer. Start the game with !trivia ask and enter a guess using !trivia 'your guess'. E.g. !trivia b. To end the game, use !trivia end. To view your score, use !trivia score." + ); + } + + @Override + public void handle(MessageCreateEvent event) { + String messageContent = event.getMessageContent(); + + //System.out.println(messageContent); + + if (messageContent.equals(COMMAND + " ask")) { + questionRight = false; + questionNumber = ran.nextInt(6); + + switch(questionNumber) { + case 0: + event.getChannel().sendMessage("Trivia: What is the main ingredient in guacamole?\na) Tomatoes\nb) Avocados\nc) Lemons\nd) Tortilla chips"); + answer = "b"; + break; + case 1: + event.getChannel().sendMessage("Trivia: How many Harry Potter books are there?\na) 8\nb) 6\nc) 5\nd) 7"); + answer = "d"; + break; + case 2: + event.getChannel().sendMessage("Trivia: What does www stand for in a website addresss bar?\na) World Wide Web\nb) Web World Wide\nc) Wild Wild West\nd) Wet Windows Web"); + answer = "a"; + break; + case 3: + event.getChannel().sendMessage("Trivia: Which country drinks the most amount of coffee per person?\na) USA\nb) Italy\nc) Finland\nd) Columbia"); + answer = "c"; + break; + case 4: + event.getChannel().sendMessage("Trivia: How many stars are there on the US Flag?\na) USA\nb) 50\nc) 75\nd) 45"); + answer = "b"; + break; + case 5: + event.getChannel().sendMessage("Trivia: In what year was the iPhone first released?\na) 2007\nb) 2008\nc) 1998\nd) 2002"); + answer = "a"; + break; + } + + } + //check a command + else if (messageContent.contains(COMMAND) + && !messageContent.contains("Trivia:")) + { + + String guessMessage = messageContent.replaceAll(" ", "").replace(COMMAND, ""); + if (guessMessage.equalsIgnoreCase(answer)) { + + event.getChannel().sendMessage("Trivia: "+answer + " is correct!"); + questionRight = true; + score++; + event.getChannel().sendMessage("Trivia: " + "Your score is now: " + score); + } else if(guessMessage.equalsIgnoreCase("score")){ + event.getChannel().sendMessage("Trivia: "+ "Your score is: "+ score); + } + else if(guessMessage.equalsIgnoreCase("end")){ + event.getChannel().sendMessage("Trivia: " + "Thanks for playing! Your final score is: " + score); + score=0; + } + else if(!guessMessage.equalsIgnoreCase("")){ + questionRight = false; + event.getChannel().sendMessage("Trivia: " + "Wrong, try again!"); + score--; + event.getChannel().sendMessage("Trivia: " + "Your score is now: " + score); + + } + } + } + +} \ No newline at end of file diff --git a/src/main/java/org/jointheleague/features/student/third_feature/Holidays.java b/src/main/java/org/jointheleague/features/student/third_feature/Holidays.java new file mode 100644 index 00000000..fdcdc88f --- /dev/null +++ b/src/main/java/org/jointheleague/features/student/third_feature/Holidays.java @@ -0,0 +1,106 @@ +package org.jointheleague.features.student.third_feature; +import net.aksingh.owmjapis.api.APIException; +import org.javacord.api.event.message.MessageCreateEvent; +import org.jointheleague.features.abstract_classes.Feature; +import org.jointheleague.features.examples.third_features.plain_old_java_objects.cat_facts_api.CatWrapper; +import org.jointheleague.features.help_embed.plain_old_java_objects.help_embed.HelpEmbed; +import org.springframework.core.ParameterizedTypeReference; +import org.springframework.http.HttpHeaders; +import org.springframework.http.MediaType; +import org.springframework.web.reactive.function.client.WebClient; +import org.springframework.web.util.UriBuilder; +import reactor.core.publisher.Mono; + +import java.util.List; + + +public class Holidays extends Feature { + + public final String COMMAND = "!holidays"; + private static final String baseUrl = "https://holidays.abstractapi.com/v1/"; + private final String apiKey = "736d5028a46c42ada682689ef387e002"; + private WebClient webClient; + String month = ""; + String day = ""; + + public Holidays(String channelName) { + super(channelName); + + //Create a help embed to describe feature when !help command is sent + helpEmbed = new HelpEmbed( + COMMAND, + "A command to get holidays on any date. Use !holidays M/D. Eg. !holidays 12/25"); + + this.webClient = WebClient + .builder() + .baseUrl(baseUrl) + .build(); + } + + + public String getHoliday() { + try { + Mono> holidaysWrapperMono = webClient.get() + .uri(uriBuilder -> uriBuilder + .queryParam("api_key", apiKey) + .queryParam("country", "US") + .queryParam("year", "2024") + .queryParam("month", month) + .queryParam("day", day) + .build()) + .retrieve() + .bodyToMono(new ParameterizedTypeReference>() {}); + + List holidaysWrapper = holidaysWrapperMono.block(); + + String message = holidaysWrapper.get(0).getName(); + + return message; + } + catch(Exception e){ + e.printStackTrace(); + + } + return null; + } + + + + + @Override + public void handle(MessageCreateEvent event) { + String messageContent = event.getMessageContent(); + + System.out.println(messageContent); + String dateMessage = messageContent.replaceAll(" ", "").replace(COMMAND, ""); + String[] dates = dateMessage.split("/"); + System.out.println(dateMessage); + + for(int i = 0; i additionalProperties = new LinkedHashMap(); + + @JsonProperty("name") + public String getName() { + return name; + } + + @JsonProperty("name") + public void setName(String name) { + this.name = name; + } + + @JsonProperty("name_local") + public String getNameLocal() { + return nameLocal; + } + + @JsonProperty("name_local") + public void setNameLocal(String nameLocal) { + this.nameLocal = nameLocal; + } + + @JsonProperty("language") + public String getLanguage() { + return language; + } + + @JsonProperty("language") + public void setLanguage(String language) { + this.language = language; + } + + @JsonProperty("description") + public String getDescription() { + return description; + } + + @JsonProperty("description") + public void setDescription(String description) { + this.description = description; + } + + @JsonProperty("country") + public String getCountry() { + return country; + } + + @JsonProperty("country") + public void setCountry(String country) { + this.country = country; + } + + @JsonProperty("location") + public String getLocation() { + return location; + } + + @JsonProperty("location") + public void setLocation(String location) { + this.location = location; + } + + @JsonProperty("type") + public String getType() { + return type; + } + + @JsonProperty("type") + public void setType(String type) { + this.type = type; + } + + @JsonProperty("date") + public String getDate() { + return date; + } + + @JsonProperty("date") + public void setDate(String date) { + this.date = date; + } + + @JsonProperty("date_year") + public String getDateYear() { + return dateYear; + } + + @JsonProperty("date_year") + public void setDateYear(String dateYear) { + this.dateYear = dateYear; + } + + @JsonProperty("date_month") + public String getDateMonth() { + return dateMonth; + } + + @JsonProperty("date_month") + public void setDateMonth(String dateMonth) { + this.dateMonth = dateMonth; + } + + @JsonProperty("date_day") + public String getDateDay() { + return dateDay; + } + + @JsonProperty("date_day") + public void setDateDay(String dateDay) { + this.dateDay = dateDay; + } + + @JsonProperty("week_day") + public String getWeekDay() { + return weekDay; + } + + @JsonProperty("week_day") + public void setWeekDay(String weekDay) { + this.weekDay = weekDay; + } + + @JsonAnyGetter + public Map getAdditionalProperties() { + return this.additionalProperties; + } + + @JsonAnySetter + public void setAdditionalProperty(String name, Object value) { + this.additionalProperties.put(name, value); + } + + } + diff --git a/src/main/resources/logback.xml b/src/main/resources/logback.xml index bbc1ec3c..3184648f 100644 --- a/src/main/resources/logback.xml +++ b/src/main/resources/logback.xml @@ -2,5 +2,5 @@ - + diff --git a/src/test/java/org/jointheleague/features/examples/second_features/HighLowGameTest.java b/src/test/java/org/jointheleague/features/examples/second_features/HighLowGameTest.java index 3874bcad..a60c992a 100644 --- a/src/test/java/org/jointheleague/features/examples/second_features/HighLowGameTest.java +++ b/src/test/java/org/jointheleague/features/examples/second_features/HighLowGameTest.java @@ -169,7 +169,7 @@ void itShouldTellTheUserIfTheirGuessIsCorrect() { when(messageCreateEvent.getChannel()).thenReturn((textChannel)); //When - highLowGame.handle(messageCreateEvent); + highLowGame.handle(messageCreateEvent); //Then verify(textChannel, times(1)).sendMessage("Correct! The number I picked was " + guess); diff --git a/src/test/java/org/jointheleague/features/student/first_feature/HelloTest.java b/src/test/java/org/jointheleague/features/student/first_feature/HelloTest.java new file mode 100644 index 00000000..83d1d767 --- /dev/null +++ b/src/test/java/org/jointheleague/features/student/first_feature/HelloTest.java @@ -0,0 +1,121 @@ +package org.jointheleague.features.student.first_feature; + +import org.javacord.api.entity.channel.TextChannel; +import org.javacord.api.event.message.MessageCreateEvent; +import org.jointheleague.features.abstract_classes.Feature; +import org.jointheleague.features.help_embed.plain_old_java_objects.help_embed.HelpEmbed; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.io.ByteArrayOutputStream; +import java.io.PrintStream; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.*; +import static org.mockito.ArgumentMatchers.anyString; +import static org.mockito.Mockito.*; +import static org.mockito.Mockito.never; + +class HelloTest { + + private final String testChannelName = "test"; + private final Hello hello = new Hello(testChannelName); + + private final ByteArrayOutputStream outContent = new ByteArrayOutputStream(); + private final PrintStream originalOut = System.out; + + @Mock + private MessageCreateEvent messageCreateEvent; + + @Mock + private TextChannel textChannel; + + @BeforeEach + void setUp() { + MockitoAnnotations.openMocks(this); + System.setOut(new PrintStream(outContent)); + } + + @AfterEach + public void itShouldNotPrintToSystemOut() { + String expected = ""; + String actual = outContent.toString(); + + assertEquals(expected, actual); + System.setOut(originalOut); + } + + @Test + void itShouldHaveACommand() { + //Given + + //When + String command = hello.COMMAND; + + //Then + + if(!(hello instanceof Hello)){ + assertNotEquals("!command", command); + } + + assertNotEquals("", command); + assertNotEquals("!", command); + assertEquals('!', command.charAt(0)); + assertNotNull(command); + } + + @Test + void itShouldHandleMessagesWithCommand() { + //Given + HelpEmbed helpEmbed = new HelpEmbed(hello.COMMAND, "test"); + when(messageCreateEvent.getMessageContent()).thenReturn(hello.COMMAND); + when(messageCreateEvent.getChannel()).thenReturn((textChannel)); + + //When + hello.handle(messageCreateEvent); + + //Then + verify(textChannel, times(1)).sendMessage(anyString()); + } + + @Test + void itShouldNotHandleMessagesWithoutCommand() { + //Given + String command = ""; + when(messageCreateEvent.getMessageContent()).thenReturn(command); + + //When + hello.handle(messageCreateEvent); + + //Then + verify(textChannel, never()).sendMessage(""); + } + + @Test + void itShouldHaveAHelpEmbed() { + //Given + + //When + HelpEmbed actualHelpEmbed = hello.getHelpEmbed(); + + //Then + assertNotNull(actualHelpEmbed); + } + + @Test + void itShouldHaveTheCommandAsTheTitleOfTheHelpEmbed() { + //Given + + //When + String helpEmbedTitle = hello.getHelpEmbed().getTitle(); + String command = hello.COMMAND; + + //Then + assertEquals(command, helpEmbedTitle); + } + +} \ No newline at end of file diff --git a/src/test/java/org/jointheleague/features/student/second_feature/TriviaTest.java b/src/test/java/org/jointheleague/features/student/second_feature/TriviaTest.java new file mode 100644 index 00000000..f6b34042 --- /dev/null +++ b/src/test/java/org/jointheleague/features/student/second_feature/TriviaTest.java @@ -0,0 +1,125 @@ +package org.jointheleague.features.student.second_feature; + +import org.javacord.api.entity.channel.TextChannel; +import org.javacord.api.event.message.MessageCreateEvent; +import org.jointheleague.features.help_embed.plain_old_java_objects.help_embed.HelpEmbed; +import org.jointheleague.features.templates.FeatureTemplate; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.io.ByteArrayOutputStream; +import java.io.PrintStream; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNotEquals; +import static org.mockito.ArgumentMatchers.anyString; +import static org.mockito.Mockito.*; +import static org.mockito.Mockito.never; + +public class TriviaTest { + private final String testChannelName = "test"; + private final Trivia trivia = new Trivia(testChannelName); + + private final ByteArrayOutputStream outContent = new ByteArrayOutputStream(); + private final PrintStream originalOut = System.out; + + @Mock + private MessageCreateEvent messageCreateEvent; + + @Mock + private TextChannel textChannel; + + @BeforeEach + void setUp() { + MockitoAnnotations.openMocks(this); + System.setOut(new PrintStream(outContent)); + } + + @AfterEach + public void itShouldNotPrintToSystemOut() { + String expected = ""; + String actual = outContent.toString(); + + assertEquals(expected, actual); + System.setOut(originalOut); + } + + @Test + void itShouldHaveACommand() { + //Given + + //When + String command = trivia.COMMAND; + + //Then + + if(!(trivia instanceof Trivia)){ + assertNotEquals("!command", command); + } + + assertNotEquals("", command); + assertNotEquals("!", command); + assertEquals('!', command.charAt(0)); + assertNotNull(command); + } + + + @Test + void itShouldNotHandleMessagesWithoutCommand() { + //Given + String command = ""; + when(messageCreateEvent.getMessageContent()).thenReturn(command); + + //When + trivia.handle(messageCreateEvent); + + //Then + verify(textChannel, never()).sendMessage(""); + } + + @Test + void itShouldHaveAHelpEmbed() { + //Given + + //When + HelpEmbed actualHelpEmbed = trivia.getHelpEmbed(); + + //Then + assertNotNull(actualHelpEmbed); + } + + @Test + void itShouldHaveTheCommandAsTheTitleOfTheHelpEmbed() { + //Given + + //When + String helpEmbedTitle = trivia.getHelpEmbed().getTitle(); + String command = trivia.COMMAND; + + //Then + assertEquals(command, helpEmbedTitle); + } + + @Test + void theScoreShouldBeZeroWhenTheGameEnds(){ + //Given + String command = "end"; + int score = trivia.score; + + assertEquals(score,0); + } + + @Test + void theScoreShouldBeZeroWhenTheGameStarts(){ + //Given + String command = "ask"; + int score = trivia.score; + + assertEquals(score,0); + } + +} diff --git a/src/test/java/org/jointheleague/features/student/third_feature/HolidaysTest.java b/src/test/java/org/jointheleague/features/student/third_feature/HolidaysTest.java new file mode 100644 index 00000000..abe415c3 --- /dev/null +++ b/src/test/java/org/jointheleague/features/student/third_feature/HolidaysTest.java @@ -0,0 +1,122 @@ +package org.jointheleague.features.student.third_feature; + +import org.javacord.api.entity.channel.TextChannel; +import org.javacord.api.event.message.MessageCreateEvent; +import org.jointheleague.features.help_embed.plain_old_java_objects.help_embed.HelpEmbed; +import org.jointheleague.features.templates.FeatureTemplate; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.io.ByteArrayOutputStream; +import java.io.PrintStream; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertNotEquals; +import static org.mockito.ArgumentMatchers.anyString; +import static org.mockito.Mockito.*; +import static org.mockito.Mockito.never; + +public class HolidaysTest { + + + private final String testChannelName = "test"; + private final FeatureTemplate featureTemplate = new FeatureTemplate(testChannelName); + + private final ByteArrayOutputStream outContent = new ByteArrayOutputStream(); + private final PrintStream originalOut = System.out; + + @Mock + private MessageCreateEvent messageCreateEvent; + + @Mock + private TextChannel textChannel; + + @BeforeEach + void setUp() { + MockitoAnnotations.openMocks(this); + System.setOut(new PrintStream(outContent)); + } + + @AfterEach + public void itShouldNotPrintToSystemOut() { + String expected = ""; + String actual = outContent.toString(); + + assertEquals(expected, actual); + System.setOut(originalOut); + } + + @Test + void itShouldHaveACommand() { + //Given + + //When + String command = featureTemplate.COMMAND; + + //Then + + if(!(featureTemplate instanceof FeatureTemplate)){ + assertNotEquals("!command", command); + } + + assertNotEquals("", command); + assertNotEquals("!", command); + assertEquals('!', command.charAt(0)); + assertNotNull(command); + } + + @Test + void itShouldHandleMessagesWithCommand() { + //Given + HelpEmbed helpEmbed = new HelpEmbed(featureTemplate.COMMAND, "test"); + when(messageCreateEvent.getMessageContent()).thenReturn(featureTemplate.COMMAND); + when(messageCreateEvent.getChannel()).thenReturn((textChannel)); + + //When + featureTemplate.handle(messageCreateEvent); + + //Then + verify(textChannel, times(1)).sendMessage(anyString()); + } + + @Test + void itShouldNotHandleMessagesWithoutCommand() { + //Given + String command = ""; + when(messageCreateEvent.getMessageContent()).thenReturn(command); + + //When + featureTemplate.handle(messageCreateEvent); + + //Then + verify(textChannel, never()).sendMessage(""); + } + + @Test + void itShouldHaveAHelpEmbed() { + //Given + + //When + HelpEmbed actualHelpEmbed = featureTemplate.getHelpEmbed(); + + //Then + assertNotNull(actualHelpEmbed); + } + + @Test + void itShouldHaveTheCommandAsTheTitleOfTheHelpEmbed() { + //Given + + //When + String helpEmbedTitle = featureTemplate.getHelpEmbed().getTitle(); + String command = featureTemplate.COMMAND; + + //Then + assertEquals(command, helpEmbedTitle); + } + +} \ No newline at end of file