mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-26 03:54:08 +01:00
Some bugs were being shadowed for some reason, and there were bugs in the handling of the owner privilege that hadn't been found because those tests had been shadowed.
This commit is contained in:
parent
d5c4b15632
commit
8ef808a039
16
src/ircdb.py
16
src/ircdb.py
@ -141,13 +141,17 @@ class CapabilitySet(sets.Set):
|
|||||||
raise KeyError, capability
|
raise KeyError, capability
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return '%s([%r])' % (self.__class__.__name__, ', '.join(self))
|
return '%s([%s])' % (self.__class__.__name__,
|
||||||
|
', '.join(map(repr, self)))
|
||||||
|
|
||||||
|
antiOwner = makeAntiCapability('owner')
|
||||||
class UserCapabilitySet(CapabilitySet):
|
class UserCapabilitySet(CapabilitySet):
|
||||||
"""A subclass of CapabilitySet to handle the owner capability correctly."""
|
"""A subclass of CapabilitySet to handle the owner capability correctly."""
|
||||||
def __contains__(self, capability):
|
def __contains__(self, capability):
|
||||||
capability = ircutils.toLower(capability)
|
capability = ircutils.toLower(capability)
|
||||||
if CapabilitySet.__contains__(self, 'owner'):
|
if capability == 'owner' or capability == antiOwner:
|
||||||
|
return True
|
||||||
|
elif CapabilitySet.__contains__(self, 'owner'):
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
return CapabilitySet.__contains__(self, capability)
|
return CapabilitySet.__contains__(self, capability)
|
||||||
@ -159,12 +163,12 @@ class UserCapabilitySet(CapabilitySet):
|
|||||||
appropriately.
|
appropriately.
|
||||||
"""
|
"""
|
||||||
capability = ircutils.toLower(capability)
|
capability = ircutils.toLower(capability)
|
||||||
if capability == 'owner':
|
if capability == 'owner' or capability == antiOwner:
|
||||||
if CapabilitySet.__contains__(self, 'owner'):
|
if CapabilitySet.__contains__(self, 'owner'):
|
||||||
return True
|
return not isAntiCapability(capability)
|
||||||
else:
|
else:
|
||||||
return False
|
return isAntiCapability(capability)
|
||||||
if 'owner' in self:
|
elif CapabilitySet.__contains__(self, 'owner'):
|
||||||
if isAntiCapability(capability):
|
if isAntiCapability(capability):
|
||||||
return False
|
return False
|
||||||
else:
|
else:
|
||||||
|
@ -80,7 +80,7 @@ class FunctionsTestCase(unittest.TestCase):
|
|||||||
|
|
||||||
|
|
||||||
class CapabilitySetTestCase(unittest.TestCase):
|
class CapabilitySetTestCase(unittest.TestCase):
|
||||||
def test(self):
|
def testGeneral(self):
|
||||||
d = ircdb.CapabilitySet()
|
d = ircdb.CapabilitySet()
|
||||||
self.assertRaises(KeyError, d.check, 'foo')
|
self.assertRaises(KeyError, d.check, 'foo')
|
||||||
d = ircdb.CapabilitySet(('foo',))
|
d = ircdb.CapabilitySet(('foo',))
|
||||||
@ -99,24 +99,12 @@ class CapabilitySetTestCase(unittest.TestCase):
|
|||||||
self.assertRaises(KeyError, d.check, '-bar')
|
self.assertRaises(KeyError, d.check, '-bar')
|
||||||
self.assertRaises(KeyError, d.check, 'bar')
|
self.assertRaises(KeyError, d.check, 'bar')
|
||||||
|
|
||||||
|
def testReprEval(self):
|
||||||
|
s = ircdb.UserCapabilitySet()
|
||||||
|
s.add('foo')
|
||||||
|
s.add('bar')
|
||||||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||||||
|
|
||||||
class UserCapabilitySetTestCase(unittest.TestCase):
|
|
||||||
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'))
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class CapabilitySetTestCase(unittest.TestCase):
|
|
||||||
def testContains(self):
|
def testContains(self):
|
||||||
s = ircdb.CapabilitySet()
|
s = ircdb.CapabilitySet()
|
||||||
self.failIf('foo' in s)
|
self.failIf('foo' in s)
|
||||||
@ -160,6 +148,25 @@ class CapabilitySetTestCase(unittest.TestCase):
|
|||||||
|
|
||||||
|
|
||||||
class UserCapabilitySetTestCase(unittest.TestCase):
|
class UserCapabilitySetTestCase(unittest.TestCase):
|
||||||
|
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()
|
||||||
|
s.add('foo')
|
||||||
|
s.add('bar')
|
||||||
|
self.assertEqual(s, eval(repr(s), ircdb.__dict__, ircdb.__dict__))
|
||||||
|
|
||||||
def testOwner(self):
|
def testOwner(self):
|
||||||
s = ircdb.UserCapabilitySet()
|
s = ircdb.UserCapabilitySet()
|
||||||
s.add('owner')
|
s.add('owner')
|
||||||
|
Loading…
Reference in New Issue
Block a user