mirror of
https://github.com/Mikaela/Limnoria.git
synced 2024-12-27 05:03:07 +01:00
df6ebc78a0
This is a safe command for admins to allow as it's limited to text reminders, unlike the equivalent scheduler.add (+ misc.echo) which usually needs to be restricted to prevent abuse
193 lines
7.2 KiB
Python
193 lines
7.2 KiB
Python
###
|
|
# Copyright (c) 2002-2004, Jeremiah Fincher
|
|
# Copyright (c) 2008, James McCoy
|
|
# 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 *
|
|
|
|
import supybot.schedule as schedule
|
|
|
|
class SchedulerTestCase(ChannelPluginTestCase):
|
|
plugins = ('Scheduler', 'Utilities')
|
|
def tearDown(self):
|
|
schedule.schedule.reset()
|
|
ChannelPluginTestCase.tearDown(self)
|
|
|
|
def testAddRemove(self):
|
|
self.assertRegexp('scheduler list', 'no.*commands')
|
|
m = self.assertNotError('scheduler add 5 echo testAddRemove')
|
|
self.assertResponse(
|
|
'scheduler list',
|
|
'1 (in 4 seconds): "echo testAddRemove"')
|
|
timeFastForward(2)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
timeFastForward(2)
|
|
self.assertResponse(' ', 'testAddRemove')
|
|
m = self.assertNotError('scheduler add 5 echo testAddRemove2')
|
|
# Get id.
|
|
id = None
|
|
for s in m.args[1].split():
|
|
s = s.lstrip('#')
|
|
if s.isdigit():
|
|
id = s
|
|
break
|
|
self.assertTrue(id, 'Couldn\'t find id in reply.')
|
|
self.assertNotError('scheduler remove %s' % id)
|
|
timeFastForward(5)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
# Need this test to run first so it has id 0 for its event
|
|
def test00RemoveZero(self):
|
|
id = None
|
|
m = self.assertNotError('scheduler add 5 echo testRemoveZero')
|
|
for s in m.args[1].split():
|
|
s = s.lstrip('#')
|
|
if s.isdigit():
|
|
id = s
|
|
break
|
|
self.assertNotError('scheduler remove %s' % id)
|
|
timeFastForward(5)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
def testRemind(self):
|
|
self.assertNotError('scheduler remind 5 testRemind')
|
|
self.assertResponse(
|
|
'scheduler list',
|
|
'3 (in 4 seconds): "testRemind"')
|
|
timeFastForward(3)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
timeFastForward(3)
|
|
self.assertResponse(' ', 'Reminder: testRemind')
|
|
timeFastForward(5)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
self.assertResponse(
|
|
'scheduler list', 'There are currently no scheduled commands.')
|
|
|
|
|
|
def testRepeat(self):
|
|
self.assertRegexp('scheduler repeat repeater 5 echo testRepeat',
|
|
'testRepeat')
|
|
timeFastForward(5)
|
|
self.assertResponse(' ', 'testRepeat')
|
|
self.assertResponse(
|
|
'scheduler list',
|
|
'repeater (every 5 seconds, next run in 4 seconds): '
|
|
'"echo testRepeat"')
|
|
timeFastForward(3)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
timeFastForward(2)
|
|
self.assertResponse(' ', 'testRepeat')
|
|
self.assertNotError('scheduler remove repeater')
|
|
self.assertRegexp('scheduler list', 'no.*commands')
|
|
timeFastForward(5)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
def testRepeatDelay(self):
|
|
self.assertNoResponse(
|
|
'scheduler repeat --delay 5 repeater 20 echo testRepeat',
|
|
timeout=1)
|
|
timeFastForward(5)
|
|
self.assertResponse(' ', 'testRepeat', timeout=1)
|
|
timeFastForward(17)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
timeFastForward(5)
|
|
self.assertResponse(' ', 'testRepeat', timeout=1)
|
|
|
|
def testRepeatWorksWithNestedCommands(self):
|
|
self.assertRegexp('scheduler repeat foo 5 "echo foo [echo nested]"',
|
|
'foo nested')
|
|
timeFastForward(5)
|
|
self.assertResponse(' ', 'foo nested')
|
|
timeFastForward(3)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
timeFastForward(2)
|
|
self.assertResponse(' ', 'foo nested')
|
|
self.assertNotError('scheduler remove foo')
|
|
timeFastForward(5)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
def testRepeatDisallowsIntegerNames(self):
|
|
self.assertError('scheduler repeat 1234 1234 "echo NoIntegerNames"')
|
|
|
|
def testRepeatDisallowsDuplicateNames(self):
|
|
self.assertNotError('scheduler repeat foo 5 "echo foo"')
|
|
self.assertError('scheduler repeat foo 5 "echo another foo fails"')
|
|
|
|
def testSinglePersistence(self):
|
|
self.assertRegexp(
|
|
'scheduler add 10 echo testSingle',
|
|
'^The operation succeeded')
|
|
|
|
self.assertNotError('unload Scheduler')
|
|
schedule.schedule.reset()
|
|
timeFastForward(20)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
self.assertNotError('load Scheduler')
|
|
self.assertResponse(' ', 'testSingle')
|
|
|
|
def testRepeatPersistence(self):
|
|
self.assertRegexp(
|
|
'scheduler repeat repeater 20 echo testRepeat',
|
|
'testRepeat')
|
|
|
|
self.assertNotError('unload Scheduler')
|
|
schedule.schedule.reset()
|
|
timeFastForward(30)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
self.assertNotError('load Scheduler')
|
|
self.assertNoResponse(' ', timeout=1) # T+30 to T+31
|
|
timeFastForward(5)
|
|
self.assertNoResponse(' ', timeout=1) # T+36 to T+37
|
|
timeFastForward(5)
|
|
self.assertResponse(' ', 'testRepeat', timeout=1) # T+42
|
|
|
|
timeFastForward(15)
|
|
self.assertNoResponse(' ', timeout=1) # T+57 to T+58
|
|
timeFastForward(5)
|
|
self.assertResponse(' ', 'testRepeat', timeout=1) # T+64
|
|
|
|
self.assertNotError('unload Scheduler')
|
|
schedule.schedule.reset()
|
|
timeFastForward(20)
|
|
self.assertNoResponse(' ', timeout=1)
|
|
|
|
self.assertNotError('load Scheduler')
|
|
self.assertNoResponse(' ', timeout=1) # T+85 to T+86
|
|
timeFastForward(10)
|
|
self.assertNoResponse(' ', timeout=1) # T+95 to T+96
|
|
timeFastForward(10)
|
|
self.assertResponse(' ', 'testRepeat', timeout=1) # T+106
|
|
|
|
|
|
|
|
|
|
# vim:set shiftwidth=4 softtabstop=4 expandtab textwidth=79:
|
|
|