Pure-only all, faulty peek check, update persist init
This commit is contained in:
parent
8ccc89b4a5
commit
2356ebc08f
@ -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 = {}
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -27,6 +27,9 @@ class SimpleFileStore:
|
|||||||
"""
|
"""
|
||||||
fp = os.path.join(self.__path, k)
|
fp = os.path.join(self.__path, k)
|
||||||
if contents == None:
|
if contents == None:
|
||||||
|
if self.__m[1] == 'wb':
|
||||||
|
contents = b''
|
||||||
|
else:
|
||||||
contents = ''
|
contents = ''
|
||||||
|
|
||||||
f = open(fp, self.__m[1])
|
f = open(fp, self.__m[1])
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
|
||||||
|
@ -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')
|
||||||
with self.assertRaises(OverflowError):
|
|
||||||
states.add('baz')
|
states.add('baz')
|
||||||
|
with self.assertRaises(OverflowError):
|
||||||
|
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):
|
||||||
|
Loading…
Reference in New Issue
Block a user