2005-01-19 14:14:38 +01:00
|
|
|
###
|
2005-01-19 14:33:05 +01:00
|
|
|
# Copyright (c) 2002-2005, Jeremiah Fincher
|
2012-09-01 16:16:48 +02:00
|
|
|
# Copyright (c) 2009, James McCoy
|
2021-10-17 09:54:06 +02:00
|
|
|
# Copyright (c) 2010-2021, Valentin Lorentz
|
2005-01-19 14:14:38 +01:00
|
|
|
# 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.
|
|
|
|
###
|
|
|
|
|
2013-01-05 20:51:36 +01:00
|
|
|
import sys
|
2022-01-01 18:11:36 +01:00
|
|
|
from unittest import skip
|
2013-01-05 20:51:36 +01:00
|
|
|
|
2005-01-19 14:14:38 +01:00
|
|
|
from supybot.test import *
|
|
|
|
|
|
|
|
import supybot.conf as conf
|
2005-01-20 00:22:35 +01:00
|
|
|
import supybot.plugin as plugin
|
2005-01-19 14:14:38 +01:00
|
|
|
|
2005-01-19 19:05:53 +01:00
|
|
|
class OwnerTestCase(PluginTestCase):
|
2005-01-31 17:01:25 +01:00
|
|
|
plugins = ('Owner', 'Config', 'Misc', 'Admin')
|
2005-01-19 14:14:38 +01:00
|
|
|
def testHelpLog(self):
|
2009-10-31 23:22:14 +01:00
|
|
|
self.assertHelp('help logmark')
|
2005-01-19 14:14:38 +01:00
|
|
|
|
|
|
|
def testSrcAmbiguity(self):
|
2005-05-11 03:00:01 +02:00
|
|
|
self.assertError('capability add foo bar')
|
2005-01-19 14:14:38 +01:00
|
|
|
|
|
|
|
def testIrcquote(self):
|
|
|
|
self.assertResponse('ircquote PRIVMSG %s :foo' % self.irc.nick, 'foo')
|
|
|
|
|
2023-06-04 22:47:46 +02:00
|
|
|
self.feedMsg('ircquote PING foo')
|
|
|
|
self.assertEqual(self.irc.takeMsg(), ircmsgs.IrcMsg(
|
|
|
|
command='PING', args=('foo',)))
|
|
|
|
|
|
|
|
def testIrcquoteLabeledResponse(self):
|
|
|
|
self.irc.state.capabilities_ack.update({'labeled-response', 'batch'})
|
|
|
|
self.feedMsg('ircquote @label=abc PING foo')
|
|
|
|
self.assertEqual(self.irc.takeMsg(), ircmsgs.IrcMsg(
|
|
|
|
server_tags={'label': 'abc'}, command='PING', args=('foo',)))
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'label': 'abc'}, prefix='server.',
|
|
|
|
command='PONG', args=('foo',)))
|
|
|
|
self.assertResponse(' ', '@label=abc :server. PONG :foo')
|
|
|
|
|
|
|
|
def testIrcquoteLabeledResponseBatch(self):
|
|
|
|
self.irc.state.capabilities_ack.update({'labeled-response', 'batch'})
|
|
|
|
self.feedMsg('ircquote @label=abc WHO val')
|
|
|
|
self.assertEqual(self.irc.takeMsg(), ircmsgs.IrcMsg(
|
|
|
|
server_tags={'label': 'abc'}, command='WHO', args=('val',)))
|
|
|
|
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'label': 'abc'}, prefix='server.',
|
|
|
|
command='BATCH', args=('+4', 'labeled-response')))
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '4'}, prefix='server.',
|
|
|
|
command='311', args=('test', 'val', '~u', 'host', '*', 'Val L')))
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '4'}, prefix='server.',
|
|
|
|
command='311', args=('test', 'val', '#limnoria-bots')))
|
|
|
|
|
|
|
|
# Batch not complete yet -> no response
|
|
|
|
self.assertIsNone(self.irc.takeMsg())
|
|
|
|
|
|
|
|
# end of batch
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
prefix='server.', command='BATCH', args=('-4',)))
|
|
|
|
|
|
|
|
self.assertResponse(
|
|
|
|
' ', '@label=abc :server. BATCH +4 :labeled-response')
|
|
|
|
self.assertResponse(
|
|
|
|
' ', '@batch=4 :server. 311 test val ~u host * :Val L')
|
|
|
|
self.assertResponse(
|
|
|
|
' ', '@batch=4 :server. 311 test val :#limnoria-bots')
|
|
|
|
self.assertResponse(
|
|
|
|
' ', ':server. BATCH :-4')
|
|
|
|
|
|
|
|
|
2005-01-19 14:14:38 +01:00
|
|
|
def testFlush(self):
|
|
|
|
self.assertNotError('flush')
|
|
|
|
|
|
|
|
def testUpkeep(self):
|
|
|
|
self.assertNotError('upkeep')
|
|
|
|
|
|
|
|
def testLoad(self):
|
|
|
|
self.assertError('load Owner')
|
|
|
|
self.assertError('load owner')
|
2005-01-20 00:23:47 +01:00
|
|
|
self.assertNotError('load Channel')
|
2005-01-19 14:14:38 +01:00
|
|
|
self.assertNotError('list Owner')
|
|
|
|
|
|
|
|
def testReload(self):
|
2005-01-20 00:23:47 +01:00
|
|
|
self.assertError('reload Channel')
|
|
|
|
self.assertNotError('load Channel')
|
|
|
|
self.assertNotError('reload Channel')
|
|
|
|
self.assertNotError('reload Channel')
|
2005-01-19 14:14:38 +01:00
|
|
|
|
|
|
|
def testUnload(self):
|
|
|
|
self.assertError('unload Foobar')
|
2005-01-20 00:23:47 +01:00
|
|
|
self.assertNotError('load Channel')
|
|
|
|
self.assertNotError('unload Channel')
|
|
|
|
self.assertError('unload Channel')
|
2005-01-29 22:24:17 +01:00
|
|
|
self.assertNotError('load Channel')
|
2005-01-20 00:23:47 +01:00
|
|
|
self.assertNotError('unload CHANNEL')
|
2005-01-19 14:14:38 +01:00
|
|
|
|
|
|
|
def testDisable(self):
|
|
|
|
self.assertError('disable enable')
|
|
|
|
self.assertError('disable identify')
|
|
|
|
|
|
|
|
def testEnable(self):
|
|
|
|
self.assertError('enable enable')
|
|
|
|
|
|
|
|
def testEnableIsCaseInsensitive(self):
|
|
|
|
self.assertNotError('disable Foo')
|
|
|
|
self.assertNotError('enable foo')
|
|
|
|
|
|
|
|
def testRename(self):
|
2009-11-02 01:08:34 +01:00
|
|
|
self.assertError('rename Admin join JOIN')
|
|
|
|
self.assertError('rename Admin join jo-in')
|
2013-01-05 20:32:39 +01:00
|
|
|
self.assertNotError('rename Admin join testcommand')
|
|
|
|
self.assertRegexp('list Admin', 'testcommand')
|
|
|
|
self.assertNotRegexp('list Admin', 'join')
|
|
|
|
self.assertError('help join')
|
|
|
|
self.assertRegexp('help testcommand', 'Tell the bot to join')
|
|
|
|
self.assertRegexp('join', 'not a valid command')
|
|
|
|
self.assertHelp('testcommand')
|
2014-07-18 20:55:12 +02:00
|
|
|
self.assertNotError('unrename Admin')
|
|
|
|
self.assertNotRegexp('list Admin', 'testcommand')
|
2013-01-05 20:32:39 +01:00
|
|
|
|
|
|
|
@skip('Nested commands cannot be renamed yet.')
|
|
|
|
def testRenameNested(self):
|
2005-05-11 03:00:01 +02:00
|
|
|
self.assertNotError('rename Admin "capability remove" rmcap')
|
|
|
|
self.assertNotRegexp('list Admin', 'capability remove')
|
2005-01-31 17:01:25 +01:00
|
|
|
self.assertRegexp('list Admin', 'rmcap')
|
|
|
|
self.assertNotError('reload Admin')
|
2005-05-11 03:00:01 +02:00
|
|
|
self.assertNotRegexp('list Admin', 'capability remove')
|
2005-01-31 17:01:25 +01:00
|
|
|
self.assertRegexp('list Admin', 'rmcap')
|
|
|
|
self.assertNotError('unrename Admin')
|
2005-05-11 03:00:01 +02:00
|
|
|
self.assertRegexp('list Admin', 'capability remove')
|
2005-01-31 17:01:25 +01:00
|
|
|
self.assertNotRegexp('list Admin', 'rmcap')
|
2005-01-19 14:14:38 +01:00
|
|
|
|
|
|
|
def testDefaultPluginErrorsWhenCommandNotInPlugin(self):
|
|
|
|
self.assertError('defaultplugin foobar owner')
|
2005-01-31 16:24:36 +01:00
|
|
|
|
2005-01-19 14:14:38 +01:00
|
|
|
|
2021-03-04 21:30:48 +01:00
|
|
|
class CommandsTestCase(PluginTestCase):
|
|
|
|
plugins = ('Owner', 'Utilities')
|
|
|
|
|
|
|
|
def testSimpleCommand(self):
|
|
|
|
self.irc.feedMsg(
|
|
|
|
ircmsgs.privmsg(self.irc.nick, 'echo foo $nick!$user@$host', self.prefix))
|
|
|
|
response = self.irc.takeMsg()
|
|
|
|
self.assertEqual(response.args, (self.nick, 'foo ' + self.prefix))
|
|
|
|
|
|
|
|
def testMultilineCommandDisabled(self):
|
|
|
|
self._sendBatch()
|
|
|
|
|
|
|
|
# response to 'echo '
|
|
|
|
self.assertRegexp('', '(echo <text>)')
|
|
|
|
|
|
|
|
# response to 'foo '
|
|
|
|
self.assertResponse('', 'Error: "foo" is not a valid command.')
|
|
|
|
|
|
|
|
# response to '$prefix'
|
|
|
|
self.assertResponse(
|
|
|
|
'', 'Error: "$nick!$user@$host" is not a valid command.')
|
|
|
|
|
|
|
|
# response to 'echo nope'
|
|
|
|
self.assertResponse('', 'nope')
|
|
|
|
|
|
|
|
def testMultilineCommand(self):
|
|
|
|
with conf.supybot.protocols.irc.experimentalExtensions.context(True):
|
|
|
|
self._sendBatch()
|
|
|
|
response = self.irc.takeMsg()
|
|
|
|
self.assertEqual(response.args, (self.nick, 'foo ' + self.prefix))
|
|
|
|
|
|
|
|
response = self.irc.takeMsg()
|
|
|
|
self.assertIsNone(response, 'Should not respond to second line')
|
|
|
|
|
|
|
|
def _sendBatch(self):
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
command='BATCH',
|
|
|
|
args=('+123', 'draft/multiline', self.irc.nick)))
|
|
|
|
|
|
|
|
# one line
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '123'},
|
|
|
|
prefix=self.prefix,
|
|
|
|
command='PRIVMSG',
|
|
|
|
args=(self.irc.nick, 'echo ')))
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '123', 'draft/multiline-concat': None},
|
|
|
|
prefix=self.prefix,
|
|
|
|
command='PRIVMSG',
|
|
|
|
args=(self.irc.nick, 'foo ')))
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '123', 'draft/multiline-concat': None},
|
|
|
|
prefix=self.prefix,
|
|
|
|
command='PRIVMSG',
|
|
|
|
args=(self.irc.nick, '$nick!$user@$host')))
|
|
|
|
|
|
|
|
# an other line
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '123'},
|
|
|
|
prefix=self.prefix,
|
|
|
|
command='PRIVMSG',
|
|
|
|
args=(self.irc.nick, 'echo nope')))
|
|
|
|
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
command='BATCH',
|
|
|
|
args=('-123',)))
|
|
|
|
|
2021-11-18 13:17:39 +01:00
|
|
|
def testIgnoreChathistory(self):
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
command='BATCH',
|
|
|
|
args=('+123', 'chathistory', self.irc.nick)))
|
|
|
|
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
server_tags={'batch': '123'},
|
|
|
|
prefix=self.prefix,
|
|
|
|
command='PRIVMSG',
|
|
|
|
args=(self.irc.nick, 'echo foo')))
|
|
|
|
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
command='BATCH',
|
|
|
|
args=('-123',)))
|
|
|
|
|
|
|
|
self.irc.feedMsg(ircmsgs.IrcMsg(
|
|
|
|
prefix=self.prefix,
|
|
|
|
command='PRIVMSG',
|
|
|
|
args=(self.irc.nick, 'echo bar')))
|
|
|
|
|
|
|
|
self.assertResponse('', 'bar')
|
|
|
|
|
2021-03-04 21:30:48 +01:00
|
|
|
|
|
|
|
|
2006-02-11 16:52:51 +01:00
|
|
|
# vim:set shiftwidth=4 softtabstop=4 expandtab textwidth=79:
|