mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-18 07:32:49 +01:00
565 lines
22 KiB
Python
565 lines
22 KiB
Python
|
###
|
||
|
# 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 testsupport import *
|
||
|
|
||
|
import os
|
||
|
import unittest
|
||
|
|
||
|
import supybot.conf as conf
|
||
|
import supybot.world as world
|
||
|
import supybot.ircdb as ircdb
|
||
|
import supybot.ircutils as ircutils
|
||
|
|
||
|
class IrcdbTestCase(SupyTestCase):
|
||
|
def setUp(self):
|
||
|
world.testing = False
|
||
|
SupyTestCase.setUp(self)
|
||
|
|
||
|
def tearDown(self):
|
||
|
world.testing = True
|
||
|
SupyTestCase.tearDown(self)
|
||
|
|
||
|
class FunctionsTestCase(IrcdbTestCase):
|
||
|
def testIsAntiCapability(self):
|
||
|
self.failIf(ircdb.isAntiCapability('foo'))
|
||
|
self.failIf(ircdb.isAntiCapability('#foo,bar'))
|
||
|
self.failUnless(ircdb.isAntiCapability('-foo'))
|
||
|
self.failUnless(ircdb.isAntiCapability('#foo,-bar'))
|
||
|
self.failUnless(ircdb.isAntiCapability('#foo.bar,-baz'))
|
||
|
|
||
|
def testIsChannelCapability(self):
|
||
|
self.failIf(ircdb.isChannelCapability('foo'))
|
||
|
self.failUnless(ircdb.isChannelCapability('#foo,bar'))
|
||
|
self.failUnless(ircdb.isChannelCapability('#foo.bar,baz'))
|
||
|
self.failUnless(ircdb.isChannelCapability('#foo,bar.baz'))
|
||
|
|
||
|
def testMakeAntiCapability(self):
|
||
|
self.assertEqual(ircdb.makeAntiCapability('foo'), '-foo')
|
||
|
self.assertEqual(ircdb.makeAntiCapability('#foo,bar'), '#foo,-bar')
|
||
|
|
||
|
def testMakeChannelCapability(self):
|
||
|
self.assertEqual(ircdb.makeChannelCapability('#f', 'b'), '#f,b')
|
||
|
self.assertEqual(ircdb.makeChannelCapability('#f', '-b'), '#f,-b')
|
||
|
|
||
|
def testFromChannelCapability(self):
|
||
|
self.assertEqual(ircdb.fromChannelCapability('#foo,bar'),
|
||
|
['#foo', 'bar'])
|
||
|
self.assertEqual(ircdb.fromChannelCapability('#foo.bar,baz'),
|
||
|
['#foo.bar', 'baz'])
|
||
|
self.assertEqual(ircdb.fromChannelCapability('#foo,bar.baz'),
|
||
|
['#foo', 'bar.baz'])
|
||
|
|
||
|
def testUnAntiCapability(self):
|
||
|
self.assertEqual(ircdb.unAntiCapability('-bar'), 'bar')
|
||
|
self.assertEqual(ircdb.unAntiCapability('#foo,-bar'), '#foo,bar')
|
||
|
self.assertEqual(ircdb.unAntiCapability('#foo.bar,-baz'),
|
||
|
'#foo.bar,baz')
|
||
|
|
||
|
def testInvertCapability(self):
|
||
|
self.assertEqual(ircdb.invertCapability('bar'), '-bar')
|
||
|
self.assertEqual(ircdb.invertCapability('-bar'), 'bar')
|
||
|
self.assertEqual(ircdb.invertCapability('#foo,bar'), '#foo,-bar')
|
||
|
self.assertEqual(ircdb.invertCapability('#foo,-bar'), '#foo,bar')
|
||
|
|
||
|
|
||
|
class CapabilitySetTestCase(SupyTestCase):
|
||
|
def testGeneral(self):
|
||
|
d = ircdb.CapabilitySet()
|
||
|
self.assertRaises(KeyError, d.check, 'foo')
|
||
|
d = ircdb.CapabilitySet(('foo',))
|
||
|
self.failUnless(d.check('foo'))
|
||
|
self.failIf(d.check('-foo'))
|
||
|
d.add('bar')
|
||
|
self.failUnless(d.check('bar'))
|
||
|
self.failIf(d.check('-bar'))
|
||
|
d.add('-baz')
|
||
|
self.failIf(d.check('baz'))
|
||
|
self.failUnless(d.check('-baz'))
|
||
|
d.add('-bar')
|
||
|
self.failIf(d.check('bar'))
|
||
|
self.failUnless(d.check('-bar'))
|
||
|
d.remove('-bar')
|
||
|
self.assertRaises(KeyError, d.check, '-bar')
|
||
|
self.assertRaises(KeyError, d.check, 'bar')
|
||
|
|
||
|
def testReprEval(self):
|
||
|
s = ircdb.UserCapabilitySet()
|
||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||
|
s.add('foo')
|
||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||
|
s.add('bar')
|
||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||
|
|
||
|
def testContains(self):
|
||
|
s = ircdb.CapabilitySet()
|
||
|
self.failIf('foo' in s)
|
||
|
self.failIf('-foo' in s)
|
||
|
s.add('foo')
|
||
|
self.failUnless('foo' in s)
|
||
|
self.failUnless('-foo' in s)
|
||
|
s.remove('foo')
|
||
|
self.failIf('foo' in s)
|
||
|
self.failIf('-foo' in s)
|
||
|
s.add('-foo')
|
||
|
self.failUnless('foo' in s)
|
||
|
self.failUnless('-foo' in s)
|
||
|
|
||
|
def testCheck(self):
|
||
|
s = ircdb.CapabilitySet()
|
||
|
self.assertRaises(KeyError, s.check, 'foo')
|
||
|
self.assertRaises(KeyError, s.check, '-foo')
|
||
|
s.add('foo')
|
||
|
self.failUnless(s.check('foo'))
|
||
|
self.failIf(s.check('-foo'))
|
||
|
s.remove('foo')
|
||
|
self.assertRaises(KeyError, s.check, 'foo')
|
||
|
self.assertRaises(KeyError, s.check, '-foo')
|
||
|
s.add('-foo')
|
||
|
self.failIf(s.check('foo'))
|
||
|
self.failUnless(s.check('-foo'))
|
||
|
s.remove('-foo')
|
||
|
self.assertRaises(KeyError, s.check, 'foo')
|
||
|
self.assertRaises(KeyError, s.check, '-foo')
|
||
|
|
||
|
def testAdd(self):
|
||
|
s = ircdb.CapabilitySet()
|
||
|
s.add('foo')
|
||
|
s.add('-foo')
|
||
|
self.failIf(s.check('foo'))
|
||
|
self.failUnless(s.check('-foo'))
|
||
|
s.add('foo')
|
||
|
self.failUnless(s.check('foo'))
|
||
|
self.failIf(s.check('-foo'))
|
||
|
|
||
|
|
||
|
class UserCapabilitySetTestCase(SupyTestCase):
|
||
|
def testOwnerHasAll(self):
|
||
|
d = ircdb.UserCapabilitySet(('owner',))
|
||
|
self.failIf(d.check('-foo'))
|
||
|
self.failUnless(d.check('foo'))
|
||
|
|
||
|
def testOwnerIsAlwaysPresent(self):
|
||
|
d = ircdb.UserCapabilitySet()
|
||
|
self.failUnless('owner' in d)
|
||
|
self.failUnless('-owner' in d)
|
||
|
self.failIf(d.check('owner'))
|
||
|
d.add('owner')
|
||
|
self.failUnless(d.check('owner'))
|
||
|
|
||
|
def testReprEval(self):
|
||
|
s = ircdb.UserCapabilitySet()
|
||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||
|
s.add('foo')
|
||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||
|
s.add('bar')
|
||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||
|
|
||
|
def testOwner(self):
|
||
|
s = ircdb.UserCapabilitySet()
|
||
|
s.add('owner')
|
||
|
self.failUnless('foo' in s)
|
||
|
self.failUnless('-foo' in s)
|
||
|
self.failUnless(s.check('owner'))
|
||
|
self.failIf(s.check('-owner'))
|
||
|
self.failIf(s.check('-foo'))
|
||
|
self.failUnless(s.check('foo'))
|
||
|
|
||
|
## def testWorksAfterReload(self):
|
||
|
## s = ircdb.UserCapabilitySet(['owner'])
|
||
|
## self.failUnless(s.check('owner'))
|
||
|
## import sets
|
||
|
## reload(sets)
|
||
|
## self.failUnless(s.check('owner'))
|
||
|
|
||
|
|
||
|
class IrcUserTestCase(IrcdbTestCase):
|
||
|
def testCapabilities(self):
|
||
|
u = ircdb.IrcUser()
|
||
|
u.addCapability('foo')
|
||
|
self.failUnless(u._checkCapability('foo'))
|
||
|
self.failIf(u._checkCapability('-foo'))
|
||
|
u.addCapability('-bar')
|
||
|
self.failUnless(u._checkCapability('-bar'))
|
||
|
self.failIf(u._checkCapability('bar'))
|
||
|
u.removeCapability('foo')
|
||
|
u.removeCapability('-bar')
|
||
|
self.assertRaises(KeyError, u._checkCapability, 'foo')
|
||
|
self.assertRaises(KeyError, u._checkCapability, '-bar')
|
||
|
|
||
|
def testAddhostmask(self):
|
||
|
u = ircdb.IrcUser()
|
||
|
self.assertRaises(ValueError, u.addHostmask, '*!*@*')
|
||
|
|
||
|
def testRemoveHostmask(self):
|
||
|
u = ircdb.IrcUser()
|
||
|
u.addHostmask('foo!bar@baz')
|
||
|
self.failUnless(u.checkHostmask('foo!bar@baz'))
|
||
|
u.addHostmask('foo!bar@baz')
|
||
|
u.removeHostmask('foo!bar@baz')
|
||
|
self.failIf(u.checkHostmask('foo!bar@baz'))
|
||
|
|
||
|
def testOwner(self):
|
||
|
u = ircdb.IrcUser()
|
||
|
u.addCapability('owner')
|
||
|
self.failUnless(u._checkCapability('foo'))
|
||
|
self.failIf(u._checkCapability('-foo'))
|
||
|
|
||
|
def testInitCapabilities(self):
|
||
|
u = ircdb.IrcUser(capabilities=['foo'])
|
||
|
self.failUnless(u._checkCapability('foo'))
|
||
|
|
||
|
def testPassword(self):
|
||
|
u = ircdb.IrcUser()
|
||
|
u.setPassword('foobar')
|
||
|
self.failUnless(u.checkPassword('foobar'))
|
||
|
self.failIf(u.checkPassword('somethingelse'))
|
||
|
|
||
|
def testTimeoutAuth(self):
|
||
|
orig = conf.supybot.databases.users.timeoutIdentification()
|
||
|
try:
|
||
|
conf.supybot.databases.users.timeoutIdentification.setValue(2)
|
||
|
u = ircdb.IrcUser()
|
||
|
u.addAuth('foo!bar@baz')
|
||
|
self.failUnless(u.checkHostmask('foo!bar@baz'))
|
||
|
time.sleep(2.1)
|
||
|
self.failIf(u.checkHostmask('foo!bar@baz'))
|
||
|
finally:
|
||
|
conf.supybot.databases.users.timeoutIdentification.setValue(orig)
|
||
|
|
||
|
def testMultipleAuth(self):
|
||
|
orig = conf.supybot.databases.users.timeoutIdentification()
|
||
|
try:
|
||
|
conf.supybot.databases.users.timeoutIdentification.setValue(2)
|
||
|
u = ircdb.IrcUser()
|
||
|
u.addAuth('foo!bar@baz')
|
||
|
self.failUnless(u.checkHostmask('foo!bar@baz'))
|
||
|
u.addAuth('boo!far@fizz')
|
||
|
self.failUnless(u.checkHostmask('boo!far@fizz'))
|
||
|
time.sleep(2.1)
|
||
|
self.failIf(u.checkHostmask('foo!bar@baz'))
|
||
|
self.failIf(u.checkHostmask('boo!far@fizz'))
|
||
|
finally:
|
||
|
conf.supybot.databases.users.timeoutIdentification.setValue(orig)
|
||
|
|
||
|
def testHashedPassword(self):
|
||
|
u = ircdb.IrcUser()
|
||
|
u.setPassword('foobar', hashed=True)
|
||
|
self.failUnless(u.checkPassword('foobar'))
|
||
|
self.failIf(u.checkPassword('somethingelse'))
|
||
|
self.assertNotEqual(u.password, 'foobar')
|
||
|
|
||
|
def testHostmasks(self):
|
||
|
prefix = 'foo12341234!bar@baz.domain.tld'
|
||
|
hostmasks = ['*!bar@baz.domain.tld', 'foo12341234!*@*']
|
||
|
u = ircdb.IrcUser()
|
||
|
self.failIf(u.checkHostmask(prefix))
|
||
|
for hostmask in hostmasks:
|
||
|
u.addHostmask(hostmask)
|
||
|
self.failUnless(u.checkHostmask(prefix))
|
||
|
|
||
|
def testAuth(self):
|
||
|
prefix = 'foo!bar@baz'
|
||
|
u = ircdb.IrcUser()
|
||
|
u.addAuth(prefix)
|
||
|
self.failUnless(u.auth)
|
||
|
u.clearAuth()
|
||
|
self.failIf(u.auth)
|
||
|
|
||
|
def testIgnore(self):
|
||
|
u = ircdb.IrcUser(ignore=True)
|
||
|
self.failIf(u._checkCapability('foo'))
|
||
|
self.failUnless(u._checkCapability('-foo'))
|
||
|
|
||
|
def testRemoveCapability(self):
|
||
|
u = ircdb.IrcUser(capabilities=('foo',))
|
||
|
self.assertRaises(KeyError, u.removeCapability, 'bar')
|
||
|
|
||
|
class IrcChannelTestCase(IrcdbTestCase):
|
||
|
def testInit(self):
|
||
|
c = ircdb.IrcChannel()
|
||
|
self.failIf(c._checkCapability('op'))
|
||
|
self.failIf(c._checkCapability('voice'))
|
||
|
self.failIf(c._checkCapability('halfop'))
|
||
|
self.failIf(c._checkCapability('protected'))
|
||
|
|
||
|
def testCapabilities(self):
|
||
|
c = ircdb.IrcChannel(defaultAllow=False)
|
||
|
self.failIf(c._checkCapability('foo'))
|
||
|
c.addCapability('foo')
|
||
|
self.failUnless(c._checkCapability('foo'))
|
||
|
c.removeCapability('foo')
|
||
|
self.failIf(c._checkCapability('foo'))
|
||
|
|
||
|
def testDefaultCapability(self):
|
||
|
c = ircdb.IrcChannel()
|
||
|
c.setDefaultCapability(False)
|
||
|
self.failIf(c._checkCapability('foo'))
|
||
|
self.failUnless(c._checkCapability('-foo'))
|
||
|
c.setDefaultCapability(True)
|
||
|
self.failUnless(c._checkCapability('foo'))
|
||
|
self.failIf(c._checkCapability('-foo'))
|
||
|
|
||
|
def testLobotomized(self):
|
||
|
c = ircdb.IrcChannel(lobotomized=True)
|
||
|
self.failUnless(c.checkIgnored('foo!bar@baz'))
|
||
|
|
||
|
def testIgnored(self):
|
||
|
prefix = 'foo!bar@baz'
|
||
|
banmask = ircutils.banmask(prefix)
|
||
|
c = ircdb.IrcChannel()
|
||
|
self.failIf(c.checkIgnored(prefix))
|
||
|
c.addIgnore(banmask)
|
||
|
self.failUnless(c.checkIgnored(prefix))
|
||
|
c.removeIgnore(banmask)
|
||
|
self.failIf(c.checkIgnored(prefix))
|
||
|
c.addBan(banmask)
|
||
|
self.failUnless(c.checkIgnored(prefix))
|
||
|
c.removeBan(banmask)
|
||
|
self.failIf(c.checkIgnored(prefix))
|
||
|
|
||
|
class UsersDictionaryTestCase(IrcdbTestCase):
|
||
|
filename = os.path.join(conf.supybot.directories.conf(),
|
||
|
'UsersDictionaryTestCase.conf')
|
||
|
def setUp(self):
|
||
|
try:
|
||
|
os.remove(self.filename)
|
||
|
except:
|
||
|
pass
|
||
|
self.users = ircdb.UsersDictionary()
|
||
|
IrcdbTestCase.setUp(self)
|
||
|
|
||
|
def testIterAndNumUsers(self):
|
||
|
self.assertEqual(self.users.numUsers(), 0)
|
||
|
u = self.users.newUser()
|
||
|
hostmask = 'foo!xyzzy@baz.domain.com'
|
||
|
banmask = ircutils.banmask(hostmask)
|
||
|
u.addHostmask(banmask)
|
||
|
u.name = 'foo'
|
||
|
self.users.setUser(u)
|
||
|
self.assertEqual(self.users.numUsers(), 1)
|
||
|
u = self.users.newUser()
|
||
|
hostmask = 'biff!fladksfj@blakjdsf'
|
||
|
banmask = ircutils.banmask(hostmask)
|
||
|
u.addHostmask(banmask)
|
||
|
u.name = 'biff'
|
||
|
self.users.setUser(u)
|
||
|
self.assertEqual(self.users.numUsers(), 2)
|
||
|
self.users.delUser(2)
|
||
|
self.assertEqual(self.users.numUsers(), 1)
|
||
|
self.users.delUser(1)
|
||
|
self.assertEqual(self.users.numUsers(), 0)
|
||
|
|
||
|
def testGetSetDelUser(self):
|
||
|
self.assertRaises(KeyError, self.users.getUser, 'foo')
|
||
|
self.assertRaises(KeyError,
|
||
|
self.users.getUser, 'foo!xyzzy@baz.domain.com')
|
||
|
u = self.users.newUser()
|
||
|
hostmask = 'foo!xyzzy@baz.domain.com'
|
||
|
banmask = ircutils.banmask(hostmask)
|
||
|
u.addHostmask(banmask)
|
||
|
u.addHostmask(hostmask)
|
||
|
u.name = 'foo'
|
||
|
self.users.setUser(u)
|
||
|
self.assertEqual(self.users.getUser('foo'), u)
|
||
|
self.assertEqual(self.users.getUser('FOO'), u)
|
||
|
self.assertEqual(self.users.getUser(hostmask), u)
|
||
|
self.assertEqual(self.users.getUser(banmask), u)
|
||
|
# The UsersDictionary shouldn't allow users to be added whose hostmasks
|
||
|
# match another user's already in the database.
|
||
|
u2 = self.users.newUser()
|
||
|
u2.addHostmask('*!xyzzy@baz.domain.c?m')
|
||
|
self.assertRaises(ValueError, self.users.setUser, u2)
|
||
|
|
||
|
|
||
|
class CheckCapabilityTestCase(IrcdbTestCase):
|
||
|
filename = os.path.join(conf.supybot.directories.conf(),
|
||
|
'CheckCapabilityTestCase.conf')
|
||
|
owner = 'owner!owner@owner'
|
||
|
nothing = 'nothing!nothing@nothing'
|
||
|
justfoo = 'justfoo!justfoo@justfoo'
|
||
|
antifoo = 'antifoo!antifoo@antifoo'
|
||
|
justchanfoo = 'justchanfoo!justchanfoo@justchanfoo'
|
||
|
antichanfoo = 'antichanfoo!antichanfoo@antichanfoo'
|
||
|
securefoo = 'securefoo!securefoo@securefoo'
|
||
|
channel = '#channel'
|
||
|
cap = 'foo'
|
||
|
anticap = ircdb.makeAntiCapability(cap)
|
||
|
chancap = ircdb.makeChannelCapability(channel, cap)
|
||
|
antichancap = ircdb.makeAntiCapability(chancap)
|
||
|
chanop = ircdb.makeChannelCapability(channel, 'op')
|
||
|
channelnothing = ircdb.IrcChannel()
|
||
|
channelcap = ircdb.IrcChannel()
|
||
|
channelcap.addCapability(cap)
|
||
|
channelanticap = ircdb.IrcChannel()
|
||
|
channelanticap.addCapability(anticap)
|
||
|
def setUp(self):
|
||
|
IrcdbTestCase.setUp(self)
|
||
|
try:
|
||
|
os.remove(self.filename)
|
||
|
except:
|
||
|
pass
|
||
|
self.users = ircdb.UsersDictionary()
|
||
|
#self.users.open(self.filename)
|
||
|
self.channels = ircdb.ChannelsDictionary()
|
||
|
#self.channels.open(self.filename)
|
||
|
|
||
|
owner = self.users.newUser()
|
||
|
owner.name = 'owner'
|
||
|
owner.addCapability('owner')
|
||
|
owner.addHostmask(self.owner)
|
||
|
self.users.setUser(owner)
|
||
|
|
||
|
nothing = self.users.newUser()
|
||
|
nothing.name = 'nothing'
|
||
|
nothing.addHostmask(self.nothing)
|
||
|
self.users.setUser(nothing)
|
||
|
|
||
|
justfoo = self.users.newUser()
|
||
|
justfoo.name = 'justfoo'
|
||
|
justfoo.addCapability(self.cap)
|
||
|
justfoo.addHostmask(self.justfoo)
|
||
|
self.users.setUser(justfoo)
|
||
|
|
||
|
antifoo = self.users.newUser()
|
||
|
antifoo.name = 'antifoo'
|
||
|
antifoo.addCapability(self.anticap)
|
||
|
antifoo.addHostmask(self.antifoo)
|
||
|
self.users.setUser(antifoo)
|
||
|
|
||
|
justchanfoo = self.users.newUser()
|
||
|
justchanfoo.name = 'justchanfoo'
|
||
|
justchanfoo.addCapability(self.chancap)
|
||
|
justchanfoo.addHostmask(self.justchanfoo)
|
||
|
self.users.setUser(justchanfoo)
|
||
|
|
||
|
antichanfoo = self.users.newUser()
|
||
|
antichanfoo.name = 'antichanfoo'
|
||
|
antichanfoo.addCapability(self.antichancap)
|
||
|
antichanfoo.addHostmask(self.antichanfoo)
|
||
|
self.users.setUser(antichanfoo)
|
||
|
|
||
|
securefoo = self.users.newUser()
|
||
|
securefoo.name = 'securefoo'
|
||
|
securefoo.addCapability(self.cap)
|
||
|
securefoo.secure = True
|
||
|
securefoo.addHostmask(self.securefoo)
|
||
|
self.users.setUser(securefoo)
|
||
|
|
||
|
channel = ircdb.IrcChannel()
|
||
|
self.channels.setChannel(self.channel, channel)
|
||
|
|
||
|
def checkCapability(self, hostmask, capability):
|
||
|
return ircdb.checkCapability(hostmask, capability,
|
||
|
self.users, self.channels)
|
||
|
|
||
|
def testOwner(self):
|
||
|
self.failUnless(self.checkCapability(self.owner, self.cap))
|
||
|
self.failIf(self.checkCapability(self.owner, self.anticap))
|
||
|
self.failUnless(self.checkCapability(self.owner, self.chancap))
|
||
|
self.failIf(self.checkCapability(self.owner, self.antichancap))
|
||
|
self.channels.setChannel(self.channel, self.channelanticap)
|
||
|
self.failUnless(self.checkCapability(self.owner, self.cap))
|
||
|
self.failIf(self.checkCapability(self.owner, self.anticap))
|
||
|
|
||
|
def testNothingAgainstChannel(self):
|
||
|
self.channels.setChannel(self.channel, self.channelnothing)
|
||
|
self.assertEqual(self.checkCapability(self.nothing, self.chancap),
|
||
|
self.channelnothing.defaultAllow)
|
||
|
self.channelnothing.defaultAllow = not self.channelnothing.defaultAllow
|
||
|
self.channels.setChannel(self.channel, self.channelnothing)
|
||
|
self.assertEqual(self.checkCapability(self.nothing, self.chancap),
|
||
|
self.channelnothing.defaultAllow)
|
||
|
self.channels.setChannel(self.channel, self.channelcap)
|
||
|
self.failUnless(self.checkCapability(self.nothing, self.chancap))
|
||
|
self.failIf(self.checkCapability(self.nothing, self.antichancap))
|
||
|
self.channels.setChannel(self.channel, self.channelanticap)
|
||
|
self.failIf(self.checkCapability(self.nothing, self.chancap))
|
||
|
self.failUnless(self.checkCapability(self.nothing, self.antichancap))
|
||
|
|
||
|
def testNothing(self):
|
||
|
self.assertEqual(self.checkCapability(self.nothing, self.cap),
|
||
|
conf.supybot.capabilities.default())
|
||
|
self.assertEqual(self.checkCapability(self.nothing, self.anticap),
|
||
|
not conf.supybot.capabilities.default())
|
||
|
|
||
|
def testJustFoo(self):
|
||
|
self.failUnless(self.checkCapability(self.justfoo, self.cap))
|
||
|
self.failIf(self.checkCapability(self.justfoo, self.anticap))
|
||
|
|
||
|
def testAntiFoo(self):
|
||
|
self.failUnless(self.checkCapability(self.antifoo, self.anticap))
|
||
|
self.failIf(self.checkCapability(self.antifoo, self.cap))
|
||
|
|
||
|
def testJustChanFoo(self):
|
||
|
self.channels.setChannel(self.channel, self.channelnothing)
|
||
|
self.failUnless(self.checkCapability(self.justchanfoo, self.chancap))
|
||
|
self.failIf(self.checkCapability(self.justchanfoo, self.antichancap))
|
||
|
self.channelnothing.defaultAllow = not self.channelnothing.defaultAllow
|
||
|
self.failUnless(self.checkCapability(self.justchanfoo, self.chancap))
|
||
|
self.failIf(self.checkCapability(self.justchanfoo, self.antichancap))
|
||
|
self.channels.setChannel(self.channel, self.channelanticap)
|
||
|
self.failUnless(self.checkCapability(self.justchanfoo, self.chancap))
|
||
|
self.failIf(self.checkCapability(self.justchanfoo, self.antichancap))
|
||
|
|
||
|
def testChanOpCountsAsEverything(self):
|
||
|
self.channels.setChannel(self.channel, self.channelanticap)
|
||
|
id = self.users.getUserId('nothing')
|
||
|
u = self.users.getUser(id)
|
||
|
u.addCapability(self.chanop)
|
||
|
self.users.setUser(u)
|
||
|
self.failUnless(self.checkCapability(self.nothing, self.chancap))
|
||
|
self.channels.setChannel(self.channel, self.channelnothing)
|
||
|
self.failUnless(self.checkCapability(self.nothing, self.chancap))
|
||
|
self.channelnothing.defaultAllow = not self.channelnothing.defaultAllow
|
||
|
self.failUnless(self.checkCapability(self.nothing, self.chancap))
|
||
|
|
||
|
def testAntiChanFoo(self):
|
||
|
self.channels.setChannel(self.channel, self.channelnothing)
|
||
|
self.failIf(self.checkCapability(self.antichanfoo, self.chancap))
|
||
|
self.failUnless(self.checkCapability(self.antichanfoo,
|
||
|
self.antichancap))
|
||
|
|
||
|
def testSecurefoo(self):
|
||
|
self.failUnless(self.checkCapability(self.securefoo, self.cap))
|
||
|
id = self.users.getUserId(self.securefoo)
|
||
|
u = self.users.getUser(id)
|
||
|
u.addAuth(self.securefoo)
|
||
|
self.users.setUser(u)
|
||
|
try:
|
||
|
originalConfDefaultAllow = conf.supybot.capabilities.default()
|
||
|
conf.supybot.capabilities.default.set('False')
|
||
|
self.failIf(self.checkCapability('a' + self.securefoo, self.cap))
|
||
|
finally:
|
||
|
conf.supybot.capabilities.default.set(str(originalConfDefaultAllow))
|
||
|
|
||
|
|
||
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|
||
|
|