Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(8ball): Add cog for !8ball #253

Merged
merged 2 commits into from
Aug 2, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions apollo.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
"cogs.commands.chatgpt",
"cogs.commands.dalle",
"cogs.commands.date",
"cogs.commands.eightball",
"cogs.commands.event_sync",
"cogs.commands.flip",
"cogs.commands.karma_admin",
Expand Down
65 changes: 65 additions & 0 deletions cogs/commands/eightball.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
from random import Random
from shlex import split
from typing import List, Optional

from discord.ext import commands
from discord.ext.commands import Bot, Context, clean_content

from utils import get_name_string

LONG_HELP_TEXT = """
Shakes a Magic 8-ball to determine the answer to any question you ask e.g. `!8ball should I get a takeaway?`
"""

SHORT_HELP_TEXT = """Asks a question to a Magic 8-ball"""


class EightBall(commands.Cog):
def __init__(self, bot: Bot, random: Random, options: List[str]):
self.bot = bot
self.random = random
self.options = options

def execute(self, author: str, args: List[str]) -> Optional[str]:
if len(args) <= 1:
return f"{author}: You must pose the Magic 8-ball a dilemma!"
else:
return f"{author}: {(self.random.choice(self.options))}"

@commands.hybrid_command(name="8ball", help=LONG_HELP_TEXT, brief=SHORT_HELP_TEXT)
async def eight_ball(self, ctx: Context, *, args: str = ""):
args = await clean_content().convert(ctx, args)
display_name = get_name_string(ctx.message)

if response := self.execute(display_name, split(args)):
await ctx.send(response)


async def setup(bot: Bot):
options = [
# Positive
"It is certain",
"It is decidedly so",
"Without a doubt",
"Yes definitely",
"You may rely on it",
"As I see it, yes",
"Most likely",
"Outlook good",
"Yes",
"Signs point to yes",
# Indeterminate
"Reply hazy, try again",
"Ask again later",
"Better not tell you now",
"Cannot predict now",
"Concentrate and ask again",
# Negative
"Don't count on it",
"My reply is no",
"My sources say no",
"Outlook not so good",
"Very doubtful",
]

await bot.add_cog(EightBall(bot, Random(), options))
35 changes: 35 additions & 0 deletions tests/test_eightball.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
from random import Random

from discord import Intents
from discord.ext.commands import Bot

from cogs.commands.eightball import EightBall


def test_eightball_no_question():
eightball = EightBall(Bot("/", intents=Intents()), Random(1), [])

assert (
eightball.execute("test", [])
== "test: You must pose the Magic 8-ball a dilemma!"
)


def test_eightball_question_with_fixed_randomness():
eightball = EightBall(
Bot("/", intents=Intents()), Random(1), ["Yes", "No", "Maybe"]
)

answers = [
eightball.execute("test", ["Should", "I", "eat", "cake?"]) for i in range(0, 7)
]

assert answers == [
"test: Yes",
"test: Maybe",
"test: Yes",
"test: No",
"test: Yes",
"test: No",
"test: No",
]
Loading