| #!/usr/bin/env python3 |
| # -*- encoding: utf-8 -*- |
| |
| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you 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 |