Best Python code snippet using localstack_python
test_dispatchers.py
Source:test_dispatchers.py
...25 self.listener_port = self.listener.getHost().port26 # NOTE: setting the clock before the setup_dispatcher stuff is called27 PortiaDispatcher.clock = Clock()28 self.disp_helper = self.add_helper(DispatcherHelper(PortiaDispatcher))29 def get_dispatcher(self, **config_extras):30 config = {31 "receive_inbound_connectors": ["transport1", "transport2"],32 "receive_outbound_connectors": ["app1"],33 "portia_endpoint": "tcp:%s:%s" % (self.listener_host,34 self.listener_port),35 "mapping": {36 "transport1": {37 "default": "mno1"38 },39 "transport2": {40 "default": "mno2"41 },42 }43 }44 config.update(config_extras)45 return self.disp_helper.get_dispatcher(config)46 def ch(self, connector_name):47 return self.disp_helper.get_connector_helper(connector_name)48 def assert_rkeys_used(self, *rkeys):49 broker = self.disp_helper.worker_helper.broker50 self.assertEqual(set(rkeys), set(broker.dispatched['vumi'].keys()))51 def assert_dispatched_endpoint(self, msg, endpoint, dispatched_msgs):52 msg.set_routing_endpoint(endpoint)53 self.assertEqual([msg], dispatched_msgs)54 def test_unique_mno_config(self):55 failure = self.assertRaises(56 DispatcherError,57 self.get_dispatcher,58 mapping={59 'transport1': {60 "default": 'mno1',61 },62 'transport2': {63 "default": 'mno1',64 "ep1": 'mno2',65 },66 })67 self.assertEqual(68 str(failure),69 'PortiaDispatcher mappings are not unique.')70 def test_single_receive_outbound_connector(self):71 failure = self.assertRaises(72 DispatcherError, self.get_dispatcher,73 receive_outbound_connectors=['app1', 'app2'])74 self.assertEqual(75 str(failure),76 ('PortiaRouter is only able to work with 1 receive outbound '77 'connector, there are 2 configured.'))78 def test_single_receive_inbound_connector_mapping(self):79 failure = self.assertRaises(80 DispatcherError, self.get_dispatcher,81 receive_inbound_connectors=[82 'transport1', 'transport2', 'transport3'])83 self.assertEqual(84 str(failure),85 ('Not all receive_inbound_connectors mapped to MNOs.'))86 @inlineCallbacks87 def test_inbound_message_routing(self):88 from_addr = '+27123456789'89 resolve_response = yield self.portia.resolve(90 portia_normalize_msisdn(from_addr))91 self.assertEqual(resolve_response['network'], None)92 yield self.get_dispatcher()93 msg = yield self.ch("transport1").make_dispatch_inbound(94 "inbound", from_addr=from_addr)95 self.assert_rkeys_used('transport1.inbound', 'app1.inbound')96 self.assert_dispatched_endpoint(97 msg, 'default', self.ch('app1').get_dispatched_inbound())98 resolve_response = yield self.portia.resolve(99 portia_normalize_msisdn(from_addr))100 self.assertEqual(resolve_response['network'], 'mno1')101 @inlineCallbacks102 def test_inbound_event_routing(self):103 yield self.get_dispatcher()104 msg = yield self.ch('transport1').make_dispatch_ack()105 self.assert_rkeys_used('transport1.event', 'app1.event')106 self.assert_dispatched_endpoint(107 msg, 'default', self.ch('app1').get_dispatched_events())108 @inlineCallbacks109 def test_outbound_message_routing(self):110 to_addr = '+27123456789'111 yield self.portia.annotate(112 portia_normalize_msisdn(to_addr),113 key='observed-network', value='mno1',114 timestamp=self.portia.now())115 yield self.get_dispatcher()116 msg = yield self.ch('app1').make_dispatch_outbound(117 "outbound", to_addr=to_addr)118 self.assert_rkeys_used('app1.outbound', 'transport1.outbound')119 self.assert_dispatched_endpoint(120 msg, 'default', self.ch('transport1').get_dispatched_outbound())121 @inlineCallbacks122 def test_outbound_message_unresolvable(self):123 to_addr = '+27123456789'124 yield self.get_dispatcher()125 yield self.ch('app1').make_dispatch_outbound(126 "outbound", to_addr=to_addr)127 [failure] = self.flushLoggedErrors()128 self.assertTrue(129 "Portia was unable to resolve:" in failure.getErrorMessage())130 @inlineCallbacks131 def test_outbound_message_unroutable(self):132 to_addr = '+27123456789'133 yield self.portia.annotate(134 portia_normalize_msisdn(to_addr),135 key='observed-network',136 # NOTE: this is an MNO that is not configured and137 # vxportia can not route138 value='XXX',139 timestamp=self.portia.now())140 yield self.get_dispatcher()141 yield self.ch('app1').make_dispatch_outbound(142 "outbound", to_addr=to_addr)143 [failure] = self.flushLoggedErrors()144 self.assertTrue(145 "Unable to route outbound message to:"...
__init__.py
Source:__init__.py
...13# limitations under the License.14# Import all backends so that they register themselves to the Dispatcher15from .backends import *16from .backend import get_dispatcher, set_data_dir, get_data_dir17save = get_dispatcher().save18load = get_dispatcher().load19get_backend = get_dispatcher().get_backend20get_backends = get_dispatcher().get_backends21get_backend_by_name = get_dispatcher().get_backend_by_name22from .decorator import Marshaller23# External code shouldn't care about the Dispatcher instance24del get_dispatcher25from kale.common import logutils26logutils.get_or_create_logger(module=__name__, name="marshalling")...
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!