2003-04-03 00:30:34 +02:00
|
|
|
#!/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.
|
|
|
|
###
|
|
|
|
|
2003-04-03 08:59:00 +02:00
|
|
|
import sys
|
|
|
|
sys.path.insert(0, 'src')
|
|
|
|
sys.path.insert(0, 'test')
|
2003-04-08 09:25:16 +02:00
|
|
|
sys.path.insert(0, 'plugins')
|
2003-04-03 08:59:00 +02:00
|
|
|
|
|
|
|
from fix import *
|
|
|
|
|
2003-08-17 04:02:53 +02:00
|
|
|
import re
|
2003-04-03 08:59:00 +02:00
|
|
|
import sys
|
|
|
|
import glob
|
2003-08-11 07:09:59 +02:00
|
|
|
import time
|
2003-04-03 08:59:00 +02:00
|
|
|
import os.path
|
2003-04-03 00:30:34 +02:00
|
|
|
import unittest
|
2003-04-03 08:59:00 +02:00
|
|
|
|
2003-04-08 09:25:16 +02:00
|
|
|
import world
|
2003-08-10 13:22:18 +02:00
|
|
|
import irclib
|
2003-04-05 12:32:14 +02:00
|
|
|
import ircmsgs
|
2003-08-10 13:22:18 +02:00
|
|
|
import ircutils
|
2003-04-05 12:32:14 +02:00
|
|
|
|
|
|
|
fd = file(os.path.join('test', 'rfc2812.msgs'), 'r')
|
|
|
|
rawmsgs = [line.strip() for line in fd]
|
|
|
|
fd.close()
|
|
|
|
|
2003-08-11 19:06:42 +02:00
|
|
|
msgs = []
|
|
|
|
for s in rawmsgs:
|
2003-08-17 04:02:53 +02:00
|
|
|
try:
|
|
|
|
msgs.append(ircmsgs.IrcMsg(s))
|
|
|
|
except:
|
|
|
|
print 'IrcMsg constructor failed: %r' % s
|
2003-04-05 12:32:14 +02:00
|
|
|
|
2003-04-14 09:21:27 +02:00
|
|
|
nicks = ['fatjim','scn','moshez','LordVan','MetaCosm','pythong','fishfart',
|
|
|
|
'alb','d0rt','jemfinch','StyxAlso','fors','deltab','gd',
|
|
|
|
'hellz_hunter','are_j|pub_comp','jason_','dreid','sayke_','winjer',
|
|
|
|
'TenOfTen','GoNoVas','queuetue','the|zzz','Hellfried','Therion',
|
|
|
|
'shro','DaCa','rexec','polin8','r0ky','aaron_','ironfroggy','eugene',
|
|
|
|
'faassen','tirloni','mackstann','Yhg1s','ElBarono','vegai','shang',
|
|
|
|
'typo_','kikoforgetme','asqui','TazyTiggy','fab','nixman','liiwi',
|
|
|
|
'AdamV','paolo','red_one','_AleX_','lament','jamessan','supybot',
|
|
|
|
'macr0_zzz','plaisthos','redghost','disco','mphardy','gt3','mathie',
|
|
|
|
'jonez','r0ky-office','tic','d33p','ES3merge','talin','af','flippo',
|
|
|
|
'sholden','ameoba','shepherg','j2','Acapnotic','dash','merlin262',
|
|
|
|
'Taaus','_moshez','rik','jafo__','blk-majik','JT__','itamar',
|
|
|
|
'kermit-','davidmccabe','glyph','jojo','dave_p','goo','hyjinx',
|
|
|
|
'SamB','exarkun','drewp','Ragica','skylan','redgore','k3','Ra1stlin',
|
|
|
|
'StevenK','carball','h3x','carljm','_jacob','teratorn','frangen',
|
|
|
|
'phed','datazone','Yaggo','acct_','nowhere','pyn','ThomasWaldmann',
|
|
|
|
'dunker','pilotLight','brainless','LoganH_','jmpnz','steinn',
|
|
|
|
'EliasREC','lowks__','OldSmrf','Mad77','snibril','delta','psy',
|
|
|
|
'skimpIzu','Kengur','MoonFallen','kotkis','Hyperi']
|
|
|
|
|
|
|
|
nicks += [msg.nick for msg in msgs if msg.nick]
|
|
|
|
|
2003-04-05 12:32:14 +02:00
|
|
|
def getMsgs(command):
|
|
|
|
return [msg for msg in msgs if msg.command == command]
|
|
|
|
|
2003-04-24 09:58:16 +02:00
|
|
|
class PluginTestCase(unittest.TestCase):
|
2003-08-10 13:22:18 +02:00
|
|
|
"""Subclass this to write a test case for a plugin. See test_FunCommands
|
|
|
|
for an example.
|
|
|
|
"""
|
2003-08-11 07:09:59 +02:00
|
|
|
timeout = 10
|
2003-08-11 07:15:16 +02:00
|
|
|
plugins = ()
|
2003-08-10 13:22:18 +02:00
|
|
|
def setUp(self, nick='test'):
|
|
|
|
self.nick = nick
|
|
|
|
self.prefix = ircutils.joinHostmask(nick, 'user', 'host.domain.tld')
|
|
|
|
self.irc = irclib.Irc(nick)
|
|
|
|
while self.irc.takeMsg():
|
|
|
|
pass
|
2003-08-11 07:15:16 +02:00
|
|
|
for name in self.plugins:
|
|
|
|
module = __import__(name)
|
|
|
|
plugin = module.Class()
|
|
|
|
self.irc.addCallback(plugin)
|
2003-08-15 04:28:51 +02:00
|
|
|
|
|
|
|
def _feedMsg(self, query):
|
2003-08-10 13:22:18 +02:00
|
|
|
self.irc.feedMsg(ircmsgs.privmsg(self.nick, query, prefix=self.prefix))
|
2003-08-11 07:09:59 +02:00
|
|
|
fed = time.time()
|
2003-08-10 13:22:18 +02:00
|
|
|
response = self.irc.takeMsg()
|
2003-08-11 07:09:59 +02:00
|
|
|
while response is None and time.time() - fed < self.timeout:
|
|
|
|
response = self.irc.takeMsg()
|
2003-08-15 04:28:51 +02:00
|
|
|
return response
|
2003-08-15 08:24:44 +02:00
|
|
|
|
2003-08-17 04:02:53 +02:00
|
|
|
def feedMsg(self, query):
|
|
|
|
"""Just feeds it a message, that's all."""
|
|
|
|
self.irc.feedMsg(ircmsgs.privmsg(self.nick, query, prefix=self.prefix))
|
|
|
|
|
2003-08-15 08:24:44 +02:00
|
|
|
# These assertError/assertNoError are somewhat fragile. The proper way to
|
|
|
|
# do them would be to use a proxy for the irc object and intercept .error.
|
|
|
|
# But that would be hard, so I don't bother. When this breaks, it'll get
|
|
|
|
# fixed, but not until then.
|
|
|
|
def assertError(self, query):
|
2003-08-17 04:02:53 +02:00
|
|
|
m = self._feedMsg(query)
|
2003-08-17 04:07:40 +02:00
|
|
|
self.failUnless(m)
|
2003-08-17 04:02:53 +02:00
|
|
|
self.failUnless(m.args[1].startswith('Error:'), '%r errored' % query)
|
2003-08-15 08:24:44 +02:00
|
|
|
|
|
|
|
def assertNotError(self, query):
|
2003-08-17 04:02:53 +02:00
|
|
|
m = self._feedMsg(query)
|
2003-08-17 04:07:40 +02:00
|
|
|
self.failUnless(m)
|
2003-08-17 04:02:53 +02:00
|
|
|
self.failIf(m.args[1].startswith('Error:'), '%r errored' % query)
|
2003-08-15 04:28:51 +02:00
|
|
|
|
|
|
|
def assertResponse(self, query, expectedResponse):
|
2003-08-17 04:02:53 +02:00
|
|
|
m = self._feedMsg(query)
|
2003-08-17 04:07:40 +02:00
|
|
|
self.failUnless(m)
|
2003-08-17 04:02:53 +02:00
|
|
|
self.assertEqual(m.args[1], expectedResponse,
|
|
|
|
'%r != %r' % (expectedResponse, m.args[1]))
|
2003-08-10 13:22:18 +02:00
|
|
|
|
2003-08-15 08:24:44 +02:00
|
|
|
def assertRegexp(self, query, regexp):
|
2003-08-17 04:02:53 +02:00
|
|
|
m = self._feedMsg(query)
|
2003-08-17 04:07:40 +02:00
|
|
|
self.failUnless(m)
|
2003-08-17 04:02:53 +02:00
|
|
|
self.failUnless(re.search(regexp, m.args[1]),
|
|
|
|
'%r does not match %r' % (m.args[1], regexp))
|
2003-08-15 08:24:44 +02:00
|
|
|
|
|
|
|
def assertRegexps(self, query, regexps):
|
|
|
|
started = time.time()
|
|
|
|
total = len(expectedResponses)*self.timeout
|
|
|
|
while expectedResponses and time.time() - started < total:
|
2003-08-17 04:02:53 +02:00
|
|
|
m = self._feedMsg(query)
|
|
|
|
self.failUnless(m, msg)
|
|
|
|
regepx = expectedResponses.pop(0)
|
|
|
|
self.failUnless(re.search(regexp, m.args[1]),
|
|
|
|
'%r does not match %r' % (m.args[1], regexp))
|
2003-08-15 08:24:44 +02:00
|
|
|
self.failIf(time.time() - started > total)
|
|
|
|
|
2003-08-10 13:22:18 +02:00
|
|
|
def assertResponses(self, query, expectedResponses):
|
|
|
|
responses = []
|
2003-08-15 08:24:44 +02:00
|
|
|
started = time.time()
|
|
|
|
while len(responses) < len(expectedResponses) and \
|
|
|
|
time.time() - started > len(expectedResponses)*self.timeout:
|
2003-08-17 04:02:53 +02:00
|
|
|
m = self._feedMsg(query)
|
|
|
|
self.failUnless(m, 'query %r timed out' % query)
|
|
|
|
responses.append(m)
|
2003-08-10 13:22:18 +02:00
|
|
|
self.assertEqual(len(expectedResponses), len(responses))
|
2003-08-17 04:02:53 +02:00
|
|
|
for (m, expected) in zip(responses, expectedResponses):
|
|
|
|
self.assertEqual(m.args[1], expected)
|
2003-08-10 13:22:18 +02:00
|
|
|
|
2003-04-24 09:58:16 +02:00
|
|
|
|
2003-04-03 08:59:00 +02:00
|
|
|
if __name__ == '__main__':
|
2003-04-08 09:25:16 +02:00
|
|
|
world.testing = True
|
2003-04-03 08:59:00 +02:00
|
|
|
if len(sys.argv) > 1:
|
2003-04-03 09:11:39 +02:00
|
|
|
files = sys.argv[1:]
|
2003-04-03 08:59:00 +02:00
|
|
|
else:
|
2003-04-20 19:16:43 +02:00
|
|
|
files = glob.glob(os.path.join('test', 'test_*.py'))
|
2003-04-03 09:11:39 +02:00
|
|
|
names = [os.path.splitext(os.path.basename(file))[0] for file in files]
|
2003-04-03 08:59:00 +02:00
|
|
|
suite = unittest.defaultTestLoader.loadTestsFromNames(names)
|
2003-04-03 10:17:00 +02:00
|
|
|
runner = unittest.TextTestRunner(verbosity=2)
|
2003-04-03 08:59:00 +02:00
|
|
|
runner.run(suite)
|
2003-08-11 07:09:59 +02:00
|
|
|
## print 'Total asserts: %s' % unittest.asserts
|
|
|
|
## world.testing = False
|