mirror of
https://github.com/Mikaela/Limnoria.git
synced 2024-11-23 19:19:32 +01:00
266 lines
10 KiB
Python
266 lines
10 KiB
Python
#!/usr/bin/env python
|
|
|
|
###
|
|
# Copyright (c) 2002, Jeremiah Fincher
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
#
|
|
# * Redistributions of source code must retain the above copyright notice,
|
|
# this list of conditions, and the following disclaimer.
|
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
# this list of conditions, and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
# * Neither the name of the author of this software nor the name of
|
|
# contributors to this software may be used to endorse or promote products
|
|
# derived from this software without specific prior written consent.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
###
|
|
|
|
|
|
from test import *
|
|
|
|
import copy
|
|
import random
|
|
|
|
import ircmsgs
|
|
import ircutils
|
|
|
|
class FunctionsTestCase(unittest.TestCase):
|
|
hostmask = 'foo!bar@baz'
|
|
def testIsUserHostmask(self):
|
|
self.failUnless(ircutils.isUserHostmask(self.hostmask))
|
|
self.failUnless(ircutils.isUserHostmask('a!b@c'))
|
|
self.failIf(ircutils.isUserHostmask('!bar@baz'))
|
|
self.failIf(ircutils.isUserHostmask('!@baz'))
|
|
self.failIf(ircutils.isUserHostmask('!bar@'))
|
|
self.failIf(ircutils.isUserHostmask('!@'))
|
|
self.failIf(ircutils.isUserHostmask('foo!@baz'))
|
|
self.failIf(ircutils.isUserHostmask('foo!bar@'))
|
|
self.failIf(ircutils.isUserHostmask(''))
|
|
self.failIf(ircutils.isUserHostmask('!'))
|
|
self.failIf(ircutils.isUserHostmask('@'))
|
|
self.failIf(ircutils.isUserHostmask('!bar@baz'))
|
|
|
|
def testIsChannel(self):
|
|
self.failUnless(ircutils.isChannel('#'))
|
|
self.failUnless(ircutils.isChannel('&'))
|
|
self.failUnless(ircutils.isChannel('+'))
|
|
self.failUnless(ircutils.isChannel('!'))
|
|
self.failUnless(ircutils.isChannel('#foo'))
|
|
self.failUnless(ircutils.isChannel('&foo'))
|
|
self.failUnless(ircutils.isChannel('+foo'))
|
|
self.failUnless(ircutils.isChannel('!foo'))
|
|
self.failIf(ircutils.isChannel('#foo bar'))
|
|
self.failIf(ircutils.isChannel('#foo,bar'))
|
|
self.failIf(ircutils.isChannel('#foobar\x07'))
|
|
self.failIf(ircutils.isChannel('foo'))
|
|
self.failIf(ircutils.isChannel(''))
|
|
|
|
def testBold(self):
|
|
s = ircutils.bold('foo')
|
|
self.assertEqual(s[0], '\x02')
|
|
self.assertEqual(s[-1], '\x0F')
|
|
|
|
def testMircColor(self):
|
|
# No colors provided should return the same string
|
|
s = 'foo'
|
|
self.assertEqual(s, ircutils.mircColor(s))
|
|
# Test positional args
|
|
self.assertEqual('\x030foo\x0F', ircutils.mircColor(s, 'white'))
|
|
self.assertEqual('\x031,2foo\x0F',ircutils.mircColor(s,'black','blue'))
|
|
self.assertEqual('\x03,3foo\x0F', ircutils.mircColor(s, None, 'green'))
|
|
# Test keyword args
|
|
self.assertEqual('\x034foo\x0F', ircutils.mircColor(s, fg='red'))
|
|
self.assertEqual('\x03,5foo\x0F', ircutils.mircColor(s, bg='brown'))
|
|
self.assertEqual('\x036,7foo\x0F',
|
|
ircutils.mircColor(s, bg='orange', fg='purple'))
|
|
|
|
def testMircColors(self):
|
|
# Make sure all (k, v) pairs are also (v, k) pairs.
|
|
for (k, v) in ircutils.mircColors.items():
|
|
if k:
|
|
self.assertEqual(ircutils.mircColors[v], k)
|
|
|
|
|
|
def testSafeArgument(self):
|
|
s = 'I have been running for 9 seconds'
|
|
bolds = ircutils.bold(s)
|
|
colors = ircutils.mircColor(s, 'pink', 'orange')
|
|
self.assertEqual(s, ircutils.safeArgument(s))
|
|
self.assertEqual(bolds, ircutils.safeArgument(bolds))
|
|
self.assertEqual(colors, ircutils.safeArgument(colors))
|
|
|
|
def testIsIP(self):
|
|
self.failIf(ircutils.isIP('a.b.c'))
|
|
self.failIf(ircutils.isIP('256.0.0.0'))
|
|
self.failUnless(ircutils.isIP('127.1'))
|
|
self.failUnless(ircutils.isIP('0.0.0.0'))
|
|
self.failUnless(ircutils.isIP('100.100.100.100'))
|
|
self.failUnless(ircutils.isIP('255.255.255.255'))
|
|
|
|
def testIsNick(self):
|
|
self.failUnless(ircutils.isNick('jemfinch'))
|
|
self.failUnless(ircutils.isNick('jemfinch0'))
|
|
self.failUnless(ircutils.isNick('[0]'))
|
|
self.failUnless(ircutils.isNick('{jemfinch}'))
|
|
self.failUnless(ircutils.isNick('[jemfinch]'))
|
|
self.failUnless(ircutils.isNick('jem|finch'))
|
|
self.failUnless(ircutils.isNick('\\```'))
|
|
self.failUnless(ircutils.isNick('`'))
|
|
self.failUnless(ircutils.isNick('A'))
|
|
self.failIf(ircutils.isNick(''))
|
|
self.failIf(ircutils.isNick('8foo'))
|
|
self.failIf(ircutils.isNick('10'))
|
|
|
|
def testBanmask(self):
|
|
for msg in msgs:
|
|
if ircutils.isUserHostmask(msg.prefix):
|
|
self.failUnless(ircutils.hostmaskPatternEqual
|
|
(ircutils.banmask(msg.prefix),
|
|
msg.prefix))
|
|
self.assertEqual(ircutils.banmask('foobar!user@host'), '*!*@host')
|
|
|
|
def testSeparateModes(self):
|
|
self.assertEqual(ircutils.separateModes(['+ooo', 'x', 'y', 'z']),
|
|
[('+o', 'x'), ('+o', 'y'), ('+o', 'z')])
|
|
self.assertEqual(ircutils.separateModes(['+o-o', 'x', 'y']),
|
|
[('+o', 'x'), ('-o', 'y')])
|
|
self.assertEqual(ircutils.separateModes(['+s-o', 'x']),
|
|
[('+s', None), ('-o', 'x')])
|
|
self.assertEqual(ircutils.separateModes(['+sntl', '100']),
|
|
[('+s', None),('+n', None),('+t', None),('+l', '100')])
|
|
|
|
def testToLower(self):
|
|
self.assertEqual('jemfinch', ircutils.toLower('jemfinch'))
|
|
self.assertEqual('{}|^', ircutils.toLower('[]\\~'))
|
|
|
|
def testReplyTo(self):
|
|
prefix = 'foo!bar@baz'
|
|
channel = ircmsgs.privmsg('#foo', 'bar baz', prefix=prefix)
|
|
private = ircmsgs.privmsg('jemfinch', 'bar baz', prefix=prefix)
|
|
self.assertEqual(ircutils.replyTo(channel), channel.args[0])
|
|
self.assertEqual(ircutils.replyTo(private), private.nick)
|
|
|
|
def testJoinModes(self):
|
|
plusE = ('+e', '*!*@*ohio-state.edu')
|
|
plusB = ('+b', '*!*@*umich.edu')
|
|
minusL = ('-l', None)
|
|
modes = [plusB, plusE, minusL]
|
|
self.assertEqual(ircutils.joinModes(modes),
|
|
['+be-l', plusB[1], plusE[1]])
|
|
|
|
def testUnColor(self):
|
|
self.assertEqual(ircutils.unColor('\x03foo\x03'), 'foo')
|
|
self.assertEqual(ircutils.unColor('\x03foo\x0F'), 'foo')
|
|
self.assertEqual(ircutils.unColor('\x0312foo\x03'), 'foo')
|
|
self.assertEqual(ircutils.unColor('\x0312,14foo\x03'), 'foo')
|
|
self.assertEqual(ircutils.unColor('\x0312foo\x0F'), 'foo')
|
|
self.assertEqual(ircutils.unColor('\x0312,14foo\x0F'), 'foo')
|
|
|
|
def testDccIpStuff(self):
|
|
def randomIP():
|
|
def rand():
|
|
return random.randrange(0, 256)
|
|
return '.'.join(map(str, [rand(), rand(), rand(), rand()]))
|
|
for _ in range(100): # 100 should be good :)
|
|
ip = randomIP()
|
|
self.assertEqual(ip, ircutils.unDccIP(ircutils.dccIP(ip)))
|
|
|
|
|
|
class IrcDictTestCase(unittest.TestCase):
|
|
def test(self):
|
|
d = ircutils.IrcDict()
|
|
d['#FOO'] = 'bar'
|
|
self.assertEqual(d['#FOO'], 'bar')
|
|
self.assertEqual(d['#Foo'], 'bar')
|
|
self.assertEqual(d['#foo'], 'bar')
|
|
del d['#fOO']
|
|
d['jemfinch{}'] = 'bar'
|
|
self.assertEqual(d['jemfinch{}'], 'bar')
|
|
self.assertEqual(d['jemfinch[]'], 'bar')
|
|
self.assertEqual(d['JEMFINCH[]'], 'bar')
|
|
|
|
def testContains(self):
|
|
d = ircutils.IrcDict()
|
|
d['#FOO'] = None
|
|
self.failUnless('#foo' in d)
|
|
d['#fOOBAR[]'] = None
|
|
self.failUnless('#foobar{}' in d)
|
|
|
|
def testGetSetItem(self):
|
|
d = ircutils.IrcDict()
|
|
d['#FOO'] = 12
|
|
self.assertEqual(12, d['#foo'])
|
|
d['#fOOBAR[]'] = 'blah'
|
|
self.assertEqual('blah', d['#foobar{}'])
|
|
|
|
def testCopyable(self):
|
|
d = ircutils.IrcDict()
|
|
d['foo'] = 'bar'
|
|
self.failUnless(d == copy.copy(d))
|
|
self.failUnless(d == copy.deepcopy(d))
|
|
|
|
class IrcSetTestCase(unittest.TestCase):
|
|
def test(self):
|
|
s = ircutils.IrcSet()
|
|
s.add('foo')
|
|
s.add('bar')
|
|
self.failUnless('foo' in s)
|
|
self.failUnless('FOO' in s)
|
|
s.discard('alfkj')
|
|
s.remove('FOo')
|
|
self.failIf('foo' in s)
|
|
self.failIf('FOo' in s)
|
|
|
|
def testCopy(self):
|
|
s = ircutils.IrcSet()
|
|
s.add('foo')
|
|
s.add('bar')
|
|
s1 = copy.deepcopy(s)
|
|
self.failUnless('foo' in s)
|
|
self.failUnless('FOO' in s)
|
|
s.discard('alfkj')
|
|
s.remove('FOo')
|
|
self.failIf('foo' in s)
|
|
self.failIf('FOo' in s)
|
|
self.failUnless('foo' in s1)
|
|
self.failUnless('FOO' in s1)
|
|
s1.discard('alfkj')
|
|
s1.remove('FOo')
|
|
self.failIf('foo' in s1)
|
|
self.failIf('FOo' in s1)
|
|
|
|
|
|
|
|
class IrcStringTestCase(unittest.TestCase):
|
|
def testEquality(self):
|
|
self.assertEqual('#foo', ircutils.IrcString('#foo'))
|
|
self.assertEqual('#foo', ircutils.IrcString('#FOO'))
|
|
self.assertEqual('#FOO', ircutils.IrcString('#foo'))
|
|
self.assertEqual('#FOO', ircutils.IrcString('#FOO'))
|
|
self.assertEqual(hash(ircutils.IrcString('#FOO')),
|
|
hash(ircutils.IrcString('#foo')))
|
|
|
|
def testInequality(self):
|
|
s1 = 'supybot'
|
|
s2 = ircutils.IrcString('Supybot')
|
|
self.failUnless(s1 == s2)
|
|
self.failIf(s1 != s2)
|
|
|
|
|
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|
|
|