mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-30 22:24:20 +01:00
Added a test and fixed several bugs it found.
This commit is contained in:
parent
5491d97704
commit
19a9804dee
@ -100,7 +100,7 @@ class Quotes(ChannelDBHandler, callbacks.Privmsg):
|
|||||||
channel = privmsgs.getChannel(msg, args)
|
channel = privmsgs.getChannel(msg, args)
|
||||||
db = self.getDb(channel)
|
db = self.getDb(channel)
|
||||||
cursor = db.cursor()
|
cursor = db.cursor()
|
||||||
cursor.execute("""SELECT max(id) FROM quotes""")
|
cursor.execute("""SELECT COUNT(*) FROM quotes""")
|
||||||
maxid = int(cursor.fetchone()[0])
|
maxid = int(cursor.fetchone()[0])
|
||||||
if maxid is None:
|
if maxid is None:
|
||||||
maxid = 0
|
maxid = 0
|
||||||
@ -141,23 +141,30 @@ class Quotes(ChannelDBHandler, callbacks.Privmsg):
|
|||||||
criteria.append('added_by=%s')
|
criteria.append('added_by=%s')
|
||||||
formats.append(argument)
|
formats.append(argument)
|
||||||
elif option == 'regexp':
|
elif option == 'regexp':
|
||||||
|
try:
|
||||||
|
r = utils.perlReToPythonRe(argument)
|
||||||
|
except ValueError:
|
||||||
try:
|
try:
|
||||||
r = re.compile(argument, re.I)
|
r = re.compile(argument, re.I)
|
||||||
except re.error, e:
|
except re.error, e:
|
||||||
irc.error(msg, str(e))
|
irc.error(msg, str(e))
|
||||||
return
|
return
|
||||||
def p(s):
|
def p(s):
|
||||||
return bool(r.match(s))
|
return int(bool(r.search(s)))
|
||||||
predicateName += 'p'
|
predicateName += 'p'
|
||||||
db.create_function(predicateName, 1, p)
|
db.create_function(predicateName, 1, p)
|
||||||
criteria.append('%s(quote)' % predicateName)
|
criteria.append('%s(quote)' % predicateName)
|
||||||
for s in rest:
|
for s in rest:
|
||||||
|
try:
|
||||||
|
i = int(s)
|
||||||
|
criteria.append('id=%s' % i)
|
||||||
|
except ValueError:
|
||||||
s = '%%%s%%' % s
|
s = '%%%s%%' % s
|
||||||
criteria.append('quote LIKE %s')
|
criteria.append('quote LIKE %s')
|
||||||
formats.append(s)
|
formats.append(s)
|
||||||
sql = """SELECT id, quote FROM quotes
|
sql = """SELECT id, quote FROM quotes
|
||||||
WHERE %s""" % ' AND '.join(criteria)
|
WHERE %s""" % ' AND '.join(criteria)
|
||||||
debug.printf(sql)
|
#debug.printf(sql)
|
||||||
cursor = db.cursor()
|
cursor = db.cursor()
|
||||||
cursor.execute(sql, *formats)
|
cursor.execute(sql, *formats)
|
||||||
if cursor.rowcount == 0:
|
if cursor.rowcount == 0:
|
||||||
@ -214,7 +221,7 @@ class Quotes(ChannelDBHandler, callbacks.Privmsg):
|
|||||||
irc.reply(msg, 'Quote %r added by %s at %s.' % \
|
irc.reply(msg, 'Quote %r added by %s at %s.' % \
|
||||||
(quote, added_by, timestamp))
|
(quote, added_by, timestamp))
|
||||||
else:
|
else:
|
||||||
irc.reply(msg, 'There isn\'t a quote with that id.')
|
irc.error(msg, 'There isn\'t a quote with that id.')
|
||||||
|
|
||||||
def removequote(self, irc, msg, args):
|
def removequote(self, irc, msg, args):
|
||||||
"""[<channel>] <id>
|
"""[<channel>] <id>
|
||||||
@ -229,6 +236,9 @@ class Quotes(ChannelDBHandler, callbacks.Privmsg):
|
|||||||
capability = ircdb.makeChannelCapability(channel, 'op')
|
capability = ircdb.makeChannelCapability(channel, 'op')
|
||||||
if ircdb.checkCapability(msg.prefix, capability):
|
if ircdb.checkCapability(msg.prefix, capability):
|
||||||
cursor.execute("""DELETE FROM quotes WHERE id=%s""", id)
|
cursor.execute("""DELETE FROM quotes WHERE id=%s""", id)
|
||||||
|
if cursor.rowcount == 0:
|
||||||
|
irc.error(msg, 'There was no such quote.')
|
||||||
|
else:
|
||||||
irc.reply(msg, conf.replySuccess)
|
irc.reply(msg, conf.replySuccess)
|
||||||
else:
|
else:
|
||||||
irc.error(msg, conf.replyNoCapability % capability)
|
irc.error(msg, conf.replyNoCapability % capability)
|
||||||
|
68
test/test_Quotes.py
Normal file
68
test/test_Quotes.py
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
#!/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 *
|
||||||
|
|
||||||
|
class QuotesTestCase(PluginTestCase):
|
||||||
|
plugins = ('Quotes',)
|
||||||
|
def test(self):
|
||||||
|
self.assertRegexp('numquotes #foo', '0')
|
||||||
|
self.assertNotError('addquote #foo foo')
|
||||||
|
self.assertRegexp('numquotes #foo', '1')
|
||||||
|
self.assertResponse('quote #foo --id 1', '#1: foo')
|
||||||
|
self.assertResponse('quote #foo 1', '#1: foo')
|
||||||
|
self.assertNotError('addquote #foo bar')
|
||||||
|
self.assertResponse('quote #foo 2', '#2: bar')
|
||||||
|
self.assertResponse('quote #foo --id 2', '#2: bar')
|
||||||
|
self.assertNotError('addquote #foo baz')
|
||||||
|
self.assertRegexp('numquotes #foo', '3')
|
||||||
|
self.assertResponse('quote #foo 3', '#3: baz')
|
||||||
|
self.assertRegexp('quote #foo --regexp m/ba/', 'bar.*baz')
|
||||||
|
self.assertRegexp('quote #foo --regexp ba', 'bar.*baz')
|
||||||
|
self.assertNotError('quoteinfo #foo 1')
|
||||||
|
self.assertNotError('randomquote #foo')
|
||||||
|
self.assertError('removequote #foo 4')
|
||||||
|
self.assertError('quoteinfo #foo 4')
|
||||||
|
self.assertNotError('removequote #foo 3')
|
||||||
|
self.assertRegexp('numquotes #foo', '2')
|
||||||
|
self.assertNotError('removequote #foo 1')
|
||||||
|
self.assertError('quoteinfo #foo 3')
|
||||||
|
self.assertError('quoteinfo #foo 1')
|
||||||
|
self.assertRegexp('randomquote #foo', '#2')
|
||||||
|
self.assertError('removequote #foo 3')
|
||||||
|
self.assertNotError('removequote #foo 2')
|
||||||
|
self.assertRegexp('numquotes #foo', '0')
|
||||||
|
self.assertError('randomquote #foo')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user