2005-02-02 05:39:30 +01:00
|
|
|
###
|
|
|
|
# Copyright (c) 2002-2004, 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 supybot.test import *
|
|
|
|
|
|
|
|
class TopicTestCase(ChannelPluginTestCase):
|
|
|
|
plugins = ('Topic',)
|
|
|
|
def testRemove(self):
|
|
|
|
self.assertError('topic remove 1')
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
_ = self.getMsg('topic add bar')
|
|
|
|
_ = self.getMsg('topic add baz')
|
|
|
|
self.assertError('topic remove 0')
|
|
|
|
self.assertNotError('topic remove 3')
|
|
|
|
self.assertNotError('topic remove 2')
|
|
|
|
self.assertNotError('topic remove 1')
|
|
|
|
self.assertError('topic remove 1')
|
|
|
|
|
|
|
|
def testReplace(self):
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
_ = self.getMsg('topic add bar')
|
|
|
|
_ = self.getMsg('topic add baz')
|
|
|
|
self.assertRegexp('topic replace 1 oof', 'oof.*bar.*baz')
|
|
|
|
self.assertRegexp('topic replace -1 zab', 'oof.*bar.*zab')
|
|
|
|
self.assertRegexp('topic replace 2 lorem ipsum',
|
|
|
|
'oof.*lorem ipsum.*zab')
|
|
|
|
self.assertRegexp('topic replace 2 rab', 'oof.*rab.*zab')
|
2005-02-04 06:04:40 +01:00
|
|
|
|
2005-02-02 05:39:30 +01:00
|
|
|
def testGet(self):
|
|
|
|
self.assertError('topic get 1')
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
_ = self.getMsg('topic add bar')
|
|
|
|
_ = self.getMsg('topic add baz')
|
|
|
|
self.assertRegexp('topic get 1', '^foo')
|
|
|
|
self.assertError('topic get 0')
|
|
|
|
|
|
|
|
def testAdd(self):
|
|
|
|
self.assertError('topic add #floorgle')
|
|
|
|
m = self.getMsg('topic add foo')
|
|
|
|
self.assertEqual(m.command, 'TOPIC')
|
|
|
|
self.assertEqual(m.args[0], self.channel)
|
|
|
|
self.assertEqual(m.args[1], 'foo (test)')
|
|
|
|
m = self.getMsg('topic add bar')
|
|
|
|
self.assertEqual(m.command, 'TOPIC')
|
|
|
|
self.assertEqual(m.args[0], self.channel)
|
|
|
|
self.assertEqual(m.args[1], 'foo (test) || bar (test)')
|
|
|
|
|
|
|
|
def testInsert(self):
|
|
|
|
m = self.getMsg('topic add foo')
|
|
|
|
self.assertEqual(m.args[1], 'foo (test)')
|
|
|
|
m = self.getMsg('topic insert bar')
|
|
|
|
self.assertEqual(m.args[1], 'bar (test) || foo (test)')
|
|
|
|
|
|
|
|
def testChange(self):
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
_ = self.getMsg('topic add bar')
|
|
|
|
_ = self.getMsg('topic add baz')
|
|
|
|
self.assertRegexp('topic change -1 s/baz/biff/',
|
|
|
|
r'foo.*bar.*biff')
|
|
|
|
self.assertRegexp('topic change 2 s/bar/baz/',
|
|
|
|
r'foo.*baz.*biff')
|
|
|
|
self.assertRegexp('topic change 1 s/foo/bar/',
|
|
|
|
r'bar.*baz.*biff')
|
|
|
|
self.assertRegexp('topic change -2 s/baz/bazz/',
|
|
|
|
r'bar.*bazz.*biff')
|
|
|
|
self.assertError('topic change 0 s/baz/biff/')
|
|
|
|
|
|
|
|
def testConfig(self):
|
|
|
|
try:
|
|
|
|
original = conf.supybot.plugins.Topic.separator()
|
|
|
|
conf.supybot.plugins.Topic.separator.setValue(' <==> ')
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
m = self.getMsg('topic add bar')
|
|
|
|
self.failUnless('<==>' in m.args[1])
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.separator.setValue(original)
|
|
|
|
|
|
|
|
def testReorder(self):
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
_ = self.getMsg('topic add bar')
|
|
|
|
_ = self.getMsg('topic add baz')
|
|
|
|
self.assertRegexp('topic reorder 2 1 3', r'bar.*foo.*baz')
|
|
|
|
self.assertRegexp('topic reorder 3 -2 1', r'baz.*foo.*bar')
|
|
|
|
self.assertError('topic reorder 0 1 2')
|
|
|
|
self.assertError('topic reorder 1 -2 2')
|
|
|
|
self.assertError('topic reorder 1 2')
|
|
|
|
self.assertError('topic reorder 2 3 4')
|
|
|
|
self.assertError('topic reorder 1 2 2')
|
|
|
|
self.assertError('topic reorder 1 1 2 3')
|
|
|
|
_ = self.getMsg('topic remove 1')
|
|
|
|
_ = self.getMsg('topic remove 1')
|
|
|
|
self.assertError('topic reorder 1')
|
|
|
|
_ = self.getMsg('topic remove 1')
|
|
|
|
self.assertError('topic reorder 0')
|
|
|
|
|
|
|
|
def testList(self):
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
self.assertRegexp('topic list', '1: foo')
|
|
|
|
_ = self.getMsg('topic add bar')
|
|
|
|
self.assertRegexp('topic list', '1: foo .*2: bar')
|
|
|
|
_ = self.getMsg('topic add baz')
|
|
|
|
self.assertRegexp('topic list', '1: foo .* 2: bar .* and 3: baz')
|
|
|
|
|
|
|
|
def testSet(self):
|
|
|
|
_ = self.getMsg('topic add foo')
|
|
|
|
self.assertRegexp('topic set -1 bar', 'bar')
|
|
|
|
self.assertNotRegexp('topic set -1 baz', 'bar')
|
|
|
|
self.assertResponse('topic set foo bar baz', 'foo bar baz')
|
2005-05-19 19:23:31 +02:00
|
|
|
# Catch a bug we had where setting topic 1 would reset the whole topic
|
|
|
|
self.assertNotResponse('topic set 1 bar', 'bar')
|
2005-02-02 05:39:30 +01:00
|
|
|
|
|
|
|
def testUndo(self):
|
|
|
|
try:
|
|
|
|
original = conf.supybot.plugins.Topic.format()
|
|
|
|
conf.supybot.plugins.Topic.format.setValue('$topic')
|
|
|
|
self.assertResponse('topic set ""', '')
|
|
|
|
self.assertResponse('topic add foo', 'foo')
|
|
|
|
self.assertResponse('topic add bar', 'foo || bar')
|
|
|
|
self.assertResponse('topic add baz', 'foo || bar || baz')
|
|
|
|
self.assertResponse('topic undo', 'foo || bar')
|
|
|
|
self.assertResponse('topic undo', 'foo')
|
|
|
|
self.assertResponse('topic undo', '')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue(original)
|
|
|
|
|
|
|
|
def testUndoRedo(self):
|
|
|
|
try:
|
|
|
|
original = conf.supybot.plugins.Topic.format()
|
|
|
|
conf.supybot.plugins.Topic.format.setValue('$topic')
|
|
|
|
self.assertResponse('topic set ""', '')
|
|
|
|
self.assertResponse('topic add foo', 'foo')
|
|
|
|
self.assertResponse('topic add bar', 'foo || bar')
|
|
|
|
self.assertResponse('topic add baz', 'foo || bar || baz')
|
|
|
|
self.assertResponse('topic undo', 'foo || bar')
|
|
|
|
self.assertResponse('topic undo', 'foo')
|
|
|
|
self.assertResponse('topic undo', '')
|
|
|
|
self.assertResponse('topic redo', 'foo')
|
|
|
|
self.assertResponse('topic redo', 'foo || bar')
|
|
|
|
self.assertResponse('topic redo', 'foo || bar || baz')
|
|
|
|
self.assertResponse('topic undo', 'foo || bar')
|
|
|
|
self.assertResponse('topic undo', 'foo')
|
|
|
|
self.assertResponse('topic redo', 'foo || bar')
|
|
|
|
self.assertResponse('topic undo', 'foo')
|
|
|
|
self.assertResponse('topic redo', 'foo || bar')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue(original)
|
|
|
|
|
|
|
|
def testSwap(self):
|
|
|
|
original = conf.supybot.plugins.Topic.format()
|
|
|
|
try:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue('$topic')
|
|
|
|
self.assertResponse('topic set ""', '')
|
|
|
|
self.assertResponse('topic add foo', 'foo')
|
|
|
|
self.assertResponse('topic add bar', 'foo || bar')
|
|
|
|
self.assertResponse('topic add baz', 'foo || bar || baz')
|
|
|
|
self.assertResponse('topic swap 1 2', 'bar || foo || baz')
|
|
|
|
self.assertResponse('topic swap 1 -1', 'baz || foo || bar')
|
|
|
|
self.assertError('topic swap -1 -1')
|
|
|
|
self.assertError('topic swap 2 -2')
|
|
|
|
self.assertError('topic swap 1 -3')
|
|
|
|
self.assertError('topic swap -2 2')
|
|
|
|
self.assertError('topic swap -3 1')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue(original)
|
2005-02-04 06:04:40 +01:00
|
|
|
|
2005-02-02 05:39:30 +01:00
|
|
|
def testDefault(self):
|
|
|
|
self.assertError('topic default')
|
|
|
|
try:
|
|
|
|
original = conf.supybot.plugins.Topic.default()
|
|
|
|
conf.supybot.plugins.Topic.default.setValue('foo bar baz')
|
|
|
|
self.assertResponse('topic default', 'foo bar baz')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.default.setValue(original)
|
|
|
|
|
|
|
|
def testTopic(self):
|
|
|
|
original = conf.supybot.plugins.Topic.format()
|
|
|
|
try:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue('$topic')
|
|
|
|
self.assertError('topic addd') # Error to send too many args.
|
|
|
|
self.assertResponse('topic add foo', 'foo')
|
|
|
|
self.assertResponse('topic add bar', 'foo || bar')
|
|
|
|
self.assertResponse('topic', 'foo || bar')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue(original)
|
|
|
|
|
|
|
|
def testSeparator(self):
|
|
|
|
original = conf.supybot.plugins.Topic.format()
|
|
|
|
try:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue('$topic')
|
|
|
|
self.assertResponse('topic add foo', 'foo')
|
|
|
|
self.assertResponse('topic add bar', 'foo || bar')
|
|
|
|
self.assertResponse('topic add baz', 'foo || bar || baz')
|
|
|
|
self.assertResponse('topic separator |', 'foo | bar | baz')
|
|
|
|
self.assertResponse('topic separator ::', 'foo :: bar :: baz')
|
|
|
|
self.assertResponse('topic separator ||', 'foo || bar || baz')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue(original)
|
2005-02-04 06:04:40 +01:00
|
|
|
|
|
|
|
def testFit(self):
|
|
|
|
original = conf.supybot.plugins.Topic.format()
|
|
|
|
try:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue('$topic')
|
|
|
|
self.irc.state.supported['TOPICLEN'] = 20
|
|
|
|
self.assertResponse('topic fit foo', 'foo')
|
|
|
|
self.assertResponse('topic fit bar', 'foo || bar')
|
|
|
|
self.assertResponse('topic fit baz', 'foo || bar || baz')
|
|
|
|
self.assertResponse('topic fit qux', 'bar || baz || qux')
|
|
|
|
finally:
|
|
|
|
conf.supybot.plugins.Topic.format.setValue(original)
|
|
|
|
self.irc.state.supported.pop('TOPICLEN', None)
|
|
|
|
|
2005-02-02 05:39:30 +01:00
|
|
|
|
2005-03-23 21:07:45 +01:00
|
|
|
# vim:set shiftwidth=4 tabstop=4 expandtab textwidth=79:
|
2005-02-02 05:39:30 +01:00
|
|
|
|