| # Copyright 2016 Twitter. All rights reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| '''mock_generator for instance/network''' |
| # pylint : disable=missing-docstring |
| from heron.instance.src.python.network import EventLooper |
| import heron.instance.src.python.utils.system_constants as constants |
| from heron.instance.src.python.utils.misc import HeronCommunicator |
| from heron.instance.src.python.network import SingleThreadStmgrClient, MetricsManagerClient |
| from heron.instance.src.python.network import SocketOptions |
| import heron.instance.tests.python.mock_protobuf as mock_protobuf |
| from mock import Mock |
| |
| from mock import patch |
| |
| class MockSTStmgrClient(SingleThreadStmgrClient): |
| HOST = '127.0.0.1' |
| PORT = 9000 |
| |
| def __init__(self): |
| socket_options = SocketOptions(32768, 16, 32768, 16, 1024000, 1024000) |
| with patch("heron.instance.src.python.utils.system_config.get_sys_config", |
| side_effect=lambda: {constants.INSTANCE_RECONNECT_STREAMMGR_INTERVAL_SEC: 10}): |
| SingleThreadStmgrClient.__init__(self, EventLooper(), None, self.HOST, self.PORT, |
| "topology_name", "topology_id", |
| mock_protobuf.get_mock_instance(), {}, |
| None, socket_options) |
| self.register_msg_called = False |
| self.handle_register_response_called = False |
| |
| def _register_msg_to_handle(self): |
| self.register_msg_called = True |
| |
| # pylint: disable=unused-argument |
| def _handle_register_response(self, response): |
| self.handle_register_response_called = True |
| |
| class MockMetricsManagerClient(MetricsManagerClient): |
| HOST = '127.0.0.1' |
| PORT = 9000 |
| def __init__(self): |
| socket_options = SocketOptions(32768, 16, 32768, 16, 1024000, 1024000) |
| with patch("heron.instance.src.python.utils.system_config.get_sys_config", |
| side_effect=lambda: {constants.INSTANCE_RECONNECT_METRICSMGR_INTERVAL_SEC: 10, |
| constants.INSTANCE_METRICS_SYSTEM_SAMPLE_INTERVAL_SEC: 10}): |
| stream = HeronCommunicator(producer_cb=None, consumer_cb=None) |
| MetricsManagerClient.__init__(self, EventLooper(), self.HOST, self.PORT, |
| mock_protobuf.get_mock_instance(), HeronCommunicator(), |
| stream, stream, {}, socket_options, Mock(), Mock()) |
| self.register_req_called = False |
| |
| def _send_register_req(self): |
| self.register_req_called = True |