77 lines
3.2 KiB
Python
77 lines
3.2 KiB
Python
import unittest
|
|
import re
|
|
|
|
from sqlite_utils.db import NotFoundError
|
|
|
|
from dbot import constants, db
|
|
|
|
|
|
class TestDatabase(unittest.TestCase):
|
|
def setUp(self):
|
|
self.db = db.DiscordDB()
|
|
|
|
def test_member(self):
|
|
member = {"id": 1200, "name": "username"}
|
|
self.db.add_member(**member)
|
|
self.assertEqual(self.db.add_member(**member), member)
|
|
|
|
self.assertRaises(NotFoundError, self.db.get_member, member_id=100)
|
|
self.assertEqual(self.db.get_member(member_id=member["id"]), member)
|
|
|
|
member.update(name="Success")
|
|
self.assertTrue(self.db.update_member(member["id"], member["name"]))
|
|
self.assertEqual(self.db.get_member(member_id=member["id"]), member)
|
|
|
|
def test_player(self):
|
|
player = {"id": 1, "name": "plato"}
|
|
self.assertTrue(self.db.add_player(player["id"], player["name"]))
|
|
self.assertFalse(self.db.add_player(player["id"], player["name"]))
|
|
self.assertEqual(self.db.get_player(0), None)
|
|
self.assertEqual(self.db.get_player(player["id"]), player)
|
|
|
|
self.assertFalse(self.db.update_player(0, "Error"))
|
|
player["name"] = "New name"
|
|
self.assertTrue(self.db.update_player(player["id"], player["name"]))
|
|
self.assertEqual(self.db.get_player(player["id"]), player)
|
|
|
|
def test_epic(self):
|
|
self.assertFalse(self.db.get_epic(123456))
|
|
self.assertTrue(self.db.add_epic(123456))
|
|
self.assertFalse(self.db.add_epic(123456))
|
|
self.assertTrue(self.db.get_epic(123456))
|
|
|
|
def test_rss_feed(self):
|
|
self.assertEqual(self.db.get_rss_feed_timestamp(71), 0.0)
|
|
self.db.set_rss_feed_timestamp(71, 16000000)
|
|
self.assertEqual(self.db.get_rss_feed_timestamp(71), 16000000.0)
|
|
|
|
def test_channels(self):
|
|
self.assertTrue(self.db.add_notification_channel(13, 16, "epic"))
|
|
self.assertFalse(self.db.add_notification_channel(13, 16, "epic"))
|
|
self.assertListEqual(self.db.get_kind_notification_channel_ids("epic"), [16])
|
|
self.assertFalse(self.db.add_role_mapping_entry(16, 5, 160003))
|
|
self.assertTrue(self.db.add_role_mapping_entry(16, 3, 160003))
|
|
self.assertTrue(self.db.add_role_mapping_entry(16, 4, 160003))
|
|
self.assertTrue(self.db.add_role_mapping_entry(16, 4, 160004))
|
|
self.assertEqual(self.db.get_role_id_for_channel_division(16, 3), 160003)
|
|
self.assertEqual(self.db.get_role_id_for_channel_division(16, 4), 160004)
|
|
self.assertTrue(self.db.remove_kind_notification_channel("epic", 16))
|
|
self.assertFalse(self.db.remove_kind_notification_channel("epic", 16))
|
|
self.assertFalse(self.db.get_role_id_for_channel_division(16, 3))
|
|
self.assertFalse(self.db.get_role_id_for_channel_division(16, 4))
|
|
self.assertFalse(self.db.get_role_id_for_channel_division(16, 5))
|
|
|
|
|
|
class TestRegexes(unittest.TestCase):
|
|
def test_events(self):
|
|
for event in constants.events:
|
|
self.assertTrue(isinstance(event, constants.EventKind))
|
|
self.assertTrue(event.slug)
|
|
self.assertTrue(event.name)
|
|
self.assertTrue(isinstance(event.regex, re.Pattern))
|
|
self.assertTrue(event.format)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main()
|