mirror of
https://github.com/jlu5/PyLink.git
synced 2025-01-12 13:12:36 +01:00
unittests! wow!
This commit is contained in:
parent
072cc72602
commit
991e86a8cb
62
tests/test_utils.py
Normal file
62
tests/test_utils.py
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
import sys
|
||||||
|
import os
|
||||||
|
sys.path.append(os.getcwd())
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
import utils
|
||||||
|
|
||||||
|
def dummyf():
|
||||||
|
pass
|
||||||
|
|
||||||
|
class TestUtils(unittest.TestCase):
|
||||||
|
def testTS6UIDGenerator(self):
|
||||||
|
uidgen = utils.TS6UIDGenerator('9PY')
|
||||||
|
self.assertEqual(uidgen.next_uid(), '9PYAAAAAA')
|
||||||
|
self.assertEqual(uidgen.next_uid(), '9PYAAAAAB')
|
||||||
|
|
||||||
|
def test_add_cmd(self):
|
||||||
|
# Without name specified, add_cmd adds a command with the same name
|
||||||
|
# as the function
|
||||||
|
utils.add_cmd(dummyf)
|
||||||
|
utils.add_cmd(dummyf, 'TEST')
|
||||||
|
# All command names should be automatically lowercased.
|
||||||
|
self.assertIn('dummyf', utils.bot_commands)
|
||||||
|
self.assertIn('test', utils.bot_commands)
|
||||||
|
self.assertNotIn('TEST', utils.bot_commands)
|
||||||
|
|
||||||
|
def test_add_hook(self):
|
||||||
|
utils.add_hook(dummyf, 'JOIN')
|
||||||
|
self.assertIn('join', utils.command_hooks)
|
||||||
|
# Again, automatically lowercased.
|
||||||
|
self.assertNotIn('Join', utils.command_hooks)
|
||||||
|
self.assertIn(dummyf, utils.command_hooks['join'])
|
||||||
|
|
||||||
|
def testIsNick(self):
|
||||||
|
self.assertFalse(utils.isNick('abcdefgh', nicklen=3))
|
||||||
|
self.assertTrue(utils.isNick('aBcdefgh', nicklen=30))
|
||||||
|
self.assertTrue(utils.isNick('abcdefgh1'))
|
||||||
|
self.assertTrue(utils.isNick('ABC-def'))
|
||||||
|
self.assertFalse(utils.isNick('-_-'))
|
||||||
|
self.assertFalse(utils.isNick(''))
|
||||||
|
self.assertFalse(utils.isNick(' i lost the game'))
|
||||||
|
self.assertFalse(utils.isNick(':aw4t*9e4t84a3t90$&*6'))
|
||||||
|
self.assertFalse(utils.isNick('9PYAAAAAB'))
|
||||||
|
self.assertTrue(utils.isNick('_9PYAAAAAB\\'))
|
||||||
|
|
||||||
|
def testIsChannel(self):
|
||||||
|
self.assertFalse(utils.isChannel(''))
|
||||||
|
self.assertFalse(utils.isChannel('lol'))
|
||||||
|
self.assertTrue(utils.isChannel('#channel'))
|
||||||
|
self.assertTrue(utils.isChannel('##ABCD'))
|
||||||
|
|
||||||
|
def testIsServerName(self):
|
||||||
|
self.assertFalse(utils.isServerName('s'))
|
||||||
|
self.assertFalse(utils.isServerName('s.'))
|
||||||
|
self.assertFalse(utils.isServerName('.s.s.s'))
|
||||||
|
self.assertTrue(utils.isServerName('Hello.world'))
|
||||||
|
self.assertFalse(utils.isServerName(''))
|
||||||
|
self.assertTrue(utils.isServerName('pylink.overdrive.pw'))
|
||||||
|
self.assertFalse(utils.isServerName(' i lost the game'))
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
7
utils.py
7
utils.py
@ -75,11 +75,12 @@ def isNick(s, nicklen=None):
|
|||||||
def isChannel(s):
|
def isChannel(s):
|
||||||
return s.startswith('#')
|
return s.startswith('#')
|
||||||
|
|
||||||
def _isASCIIPrintable(s):
|
def _isASCII(s):
|
||||||
return all(char in string.printable for char in s)
|
chars = string.ascii_letters + string.digits + string.punctuation
|
||||||
|
return all(char in chars for char in s)
|
||||||
|
|
||||||
def isServerName(s):
|
def isServerName(s):
|
||||||
return _isASCIIPrintable(s) and '.' in s and not s.startswith('.') \
|
return _isASCII(s) and '.' in s and not s.startswith('.') \
|
||||||
and not s.endswith('.')
|
and not s.endswith('.')
|
||||||
|
|
||||||
def parseModes(args):
|
def parseModes(args):
|
||||||
|
Loading…
Reference in New Issue
Block a user