Skip to main content

Python Finite State Machines made easy.

Project description

https://img.shields.io/pypi/v/python-statemachine.svg Build status Coverage report Documentation Status Updates

Python finite-state machines made easy.

Getting started

To install Python State Machine, run this command in your terminal:

$ pip install python-statemachine

Define your state machine:

from statemachine import StateMachine, State

class TrafficLightMachine(StateMachine):
    green = State('Green', initial=True)
    yellow = State('Yellow')
    red = State('Red')

    slowdown = green.to(yellow)
    stop = yellow.to(red)
    go = red.to(green)

You can now create an instance:

>>> traffic_light = TrafficLightMachine()

And inspect about the current state:

>>> traffic_light.current_state
State('Green', identifier='green', value='green', initial=True)
>>> traffic_light.current_state == TrafficLightMachine.green == traffic_light.green
True

For each state, there’s a dinamically created property in the form is_<state.identifier>, that returns True if the current status matches the query:

>>> traffic_light.is_green
True
>>> traffic_light.is_yellow
False
>>> traffic_light.is_red
False

Query about metadata:

>>> [s.identifier for s in m.states]
['green', 'red', 'yellow']
>>> [t.identifier for t in m.transitions]
['go', 'slowdown', 'stop']

Call a transition:

>>> traffic_light.slowdown()

And check for the current status:

>>> traffic_light.current_state
State('Yellow', identifier='yellow', value='yellow', initial=False)
>>> traffic_light.is_yellow
True

You can’t run a transition from an invalid state:

>>> traffic_light.is_yellow
True
>>> traffic_light.slowdown()
Traceback (most recent call last):
...
LookupError: Can't slowdown when in Yellow.

You can also trigger events in an alternative way, calling the run(<transition.identificer>) method:

>>> traffic_light.is_yellow
True
>>> traffic_light.run('stop')
>>> traffic_light.is_red
True

A state machine can be instantiated with an initial value:

>>> machine = TrafficLightMachine(start_value='red')
>>> traffic_light.is_red
True

Models

If you need to persist the current state on another object, or you’re using the state machine to control the flow of another object, you can pass this object to the StateMachine constructor:

>>> class MyModel(object):
...     def __init__(self, state):
...         self.state = state
...
>>> obj = MyModel(state='red')
>>> traffic_light = TrafficLightMachine(obj)
>>> traffic_light.is_red
True
>>> obj.state
'red'
>>> obj.state = 'green'
>>> traffic_light.is_green
True
>>> traffic_light.slowdown()
>>> obj.state
'yellow'
>>> traffic_light.is_yellow
True

Events

Docs needed.

Mixins

Docs needed.

History

0.5.1 (2017-07-24)

  • Fix bug on CombinedTransition._can_run not allowing transitions to run if there are more than two transitions combined.

0.5.0 (2017-07-13)

  • Custom exceptions.

  • Duplicated definition of on_execute callback is not allowed.

  • Fix bug on StateMachine.on_<transition.identifier> being called with extra self param.

0.4.2 (2017-07-10)

  • Python 3.6 support.

  • Drop official support for Python 3.3.

  • Transition can be used as decorator for on_execute callback definition.

  • Transition can point to multiple destination states.

0.3.0 (2017-03-22)

  • README getting started section.

  • Tests to state machine without model.

0.2.0 (2017-03-22)

  • State can hold a value that will be assigned to the model as the state value.

  • Travis-CI integration.

  • RTD integration.

0.1.0 (2017-03-21)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python-statemachine-0.5.1.tar.gz (21.4 kB view details)

Uploaded Source

Built Distribution

python_statemachine-0.5.1-py2.py3-none-any.whl (10.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file python-statemachine-0.5.1.tar.gz.

File metadata

File hashes

Hashes for python-statemachine-0.5.1.tar.gz
Algorithm Hash digest
SHA256 673cef9c9751491a9f9d573ddba49ac93268ce075c83833684b4b762ec9e6d93
MD5 b64874ae9c23fb3e3af63d7bd66ceee2
BLAKE2b-256 d502779dcce4b9891477d453c1e37fc047da4a9abf36b0d7429b5b8ca4959115

See more details on using hashes here.

File details

Details for the file python_statemachine-0.5.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for python_statemachine-0.5.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 d592d8d2e25ee962ae606a2e71461cfec8464f385d9051799518b506c9c1b81d
MD5 f337d5556704ce277510c0414197f679
BLAKE2b-256 b2edbdc2850da1f3914a980a641455d2bb94713203c35d52b57443186328e78e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page