mirror of
				https://github.com/Mikaela/Limnoria.git
				synced 2025-10-31 07:37:22 +01:00 
			
		
		
		
	 df6ebc78a0
			
		
	
	
		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:
 | |
| 
 |