bigchaindb/tests/test_events.py

75 lines
2.0 KiB
Python
Raw Normal View History

# Copyright BigchainDB GmbH and BigchainDB contributors
# SPDX-License-Identifier: (Apache-2.0 AND CC-BY-4.0)
# Code is Apache-2.0 and docs are CC-BY-4.0
import pytest
2017-07-31 01:58:58 +02:00
def test_event_handler():
2017-08-09 09:28:28 +02:00
from bigchaindb.events import EventTypes, Event, Exchange
2017-04-07 15:02:49 +02:00
# create and event
event_data = {'msg': 'some data'}
event = Event(EventTypes.BLOCK_VALID, event_data)
2017-07-31 01:58:58 +02:00
# create the events pub sub
2017-08-09 09:28:28 +02:00
exchange = Exchange()
2017-07-31 01:58:58 +02:00
2017-08-09 09:28:28 +02:00
sub0 = exchange.get_subscriber_queue(EventTypes.BLOCK_VALID)
sub1 = exchange.get_subscriber_queue(EventTypes.BLOCK_VALID |
EventTypes.BLOCK_INVALID)
# Subscribe to all events
2017-08-09 09:28:28 +02:00
sub2 = exchange.get_subscriber_queue()
sub3 = exchange.get_subscriber_queue(EventTypes.BLOCK_INVALID)
2017-04-07 15:02:49 +02:00
# push and event to the queue
2017-08-09 09:28:28 +02:00
exchange.dispatch(event)
2017-04-07 15:02:49 +02:00
# get the event from the queue
2017-07-31 01:58:58 +02:00
event_sub0 = sub0.get()
event_sub1 = sub1.get()
event_sub2 = sub2.get()
2017-07-31 01:58:58 +02:00
assert event_sub0.type == event.type
assert event_sub0.data == event.data
2017-04-07 15:02:49 +02:00
2017-07-31 01:58:58 +02:00
assert event_sub1.type == event.type
assert event_sub1.data == event.data
assert event_sub2.type == event.type
assert event_sub2.data == event.data
assert sub3.qsize() == 0
2017-08-09 16:23:03 +02:00
def test_event_handler_raises_when_called_after_start():
from bigchaindb.events import Exchange, POISON_PILL
exchange = Exchange()
publisher_queue = exchange.get_publisher_queue()
publisher_queue.put(POISON_PILL)
exchange.run()
with pytest.raises(RuntimeError):
exchange.get_subscriber_queue()
2017-08-09 16:23:03 +02:00
def test_exchange_stops_with_poison_pill():
from bigchaindb.events import EventTypes, Event, Exchange, POISON_PILL
# create and event
event_data = {'msg': 'some data'}
event = Event(EventTypes.BLOCK_VALID, event_data)
# create the events pub sub
exchange = Exchange()
publisher_queue = exchange.get_publisher_queue()
# push and event to the queue
publisher_queue.put(event)
publisher_queue.put(POISON_PILL)
exchange.run()
assert publisher_queue.qsize() == 0