Pure-only all, faulty peek check, update persist init

This commit is contained in:
lash 2022-03-17 21:36:07 +00:00
parent 8ccc89b4a5
commit 2356ebc08f
Signed by: lash
GPG Key ID: 21D2E7BB88C2A746
5 changed files with 22 additions and 11 deletions

View File

@ -17,8 +17,8 @@ class PersistedState(State):
:type logger: object :type logger: object
""" """
def __init__(self, factory, bits, logger=None, verifier=None): def __init__(self, factory, bits, logger=None, verifier=None, check_alias=True, event_callback=None):
super(PersistedState, self).__init__(bits, logger=logger, verifier=verifier) super(PersistedState, self).__init__(bits, logger=logger, verifier=verifier, check_alias=check_alias, event_callback=event_callback)
self.__store_factory = factory self.__store_factory = factory
self.__stores = {} self.__stores = {}

View File

@ -203,7 +203,7 @@ class State:
self.__set(k, v) self.__set(k, v)
def all(self): def all(self, pure=False):
"""Return list of all unique atomic and alias states. """Return list of all unique atomic and alias states.
:rtype: list of ints :rtype: list of ints
@ -215,6 +215,10 @@ class State:
continue continue
if k.upper() != k: if k.upper() != k:
continue continue
if pure:
state = self.from_name(k)
if not self.__is_pure(state):
continue
l.append(k) l.append(k)
l.sort() l.sort()
return l return l
@ -349,7 +353,7 @@ class State:
raise StateItemNotFound(key) raise StateItemNotFound(key)
new_state = self.__reverse.get(to_state) new_state = self.__reverse.get(to_state)
if new_state == None: if new_state == None and self.check_alias:
raise StateInvalid(to_state) raise StateInvalid(to_state)
return self.__move(key, current_state, to_state) return self.__move(key, current_state, to_state)
@ -549,7 +553,7 @@ class State:
state = 1 state = 1
else: else:
state <<= 1 state <<= 1
if state > self.__c: if state > self.__limit:
raise StateInvalid('unknown state {}'.format(state)) raise StateInvalid('unknown state {}'.format(state))
return state return state

View File

@ -27,7 +27,10 @@ class SimpleFileStore:
""" """
fp = os.path.join(self.__path, k) fp = os.path.join(self.__path, k)
if contents == None: if contents == None:
contents = '' if self.__m[1] == 'wb':
contents = b''
else:
contents = ''
f = open(fp, self.__m[1]) f = open(fp, self.__m[1])
f.write(contents) f.write(contents)

View File

@ -200,6 +200,9 @@ class TestStateReport(unittest.TestCase):
self.states.next('abcd') self.states.next('abcd')
self.assertEqual(self.states.state('abcd'), self.states.BAR) self.assertEqual(self.states.state('abcd'), self.states.BAR)
self.states.next('abcd')
self.assertEqual(self.states.state('abcd'), self.states.BAZ)
with self.assertRaises(StateInvalid): with self.assertRaises(StateInvalid):
self.states.next('abcd') self.states.next('abcd')
@ -207,7 +210,7 @@ class TestStateReport(unittest.TestCase):
with self.assertRaises(FileNotFoundError): with self.assertRaises(FileNotFoundError):
os.stat(fp) os.stat(fp)
fp = os.path.join(self.d, 'BAR', 'abcd') fp = os.path.join(self.d, 'BAZ', 'abcd')
os.stat(fp) os.stat(fp)

View File

@ -48,11 +48,12 @@ class TestState(unittest.TestCase):
def test_limit(self): def test_limit(self):
states = State(2) states = State(3)
states.add('foo') states.add('foo')
states.add('bar') states.add('bar')
states.add('baz')
with self.assertRaises(OverflowError): with self.assertRaises(OverflowError):
states.add('baz') states.add('gaz')
def test_dup(self): def test_dup(self):
@ -122,7 +123,7 @@ class TestState(unittest.TestCase):
def test_peek(self): def test_peek(self):
states = State(3) states = State(2)
states.add('foo') states.add('foo')
states.add('bar') states.add('bar')
@ -135,7 +136,7 @@ class TestState(unittest.TestCase):
states.move('abcd', states.BAR) states.move('abcd', states.BAR)
with self.assertRaises(StateInvalid): with self.assertRaises(StateInvalid):
self.assertEqual(states.peek('abcd')) states.peek('abcd')
def test_from_name(self): def test_from_name(self):