diff --git a/.github/workflows/python_publish.yml b/.github/workflows/python_publish.yml new file mode 100644 index 0000000..87173d1 --- /dev/null +++ b/.github/workflows/python_publish.yml @@ -0,0 +1,23 @@ +name: Swim Python Client Publish + +on: + push: + tags: + - '*' + +jobs: + pypi-publish: + name: Upload release to PyPI + runs-on: ubuntu-latest + environment: + name: pypi + url: https://pypi.org/p/ + permissions: + id-token: write + steps: + - name: Build + uses: actions/checkout@v4 + - run: python3 -m pip install --upgrade build && python3 -m build + + - name: Publish package distributions to PyPI + uses: pypa/gh-action-pypi-publish@release/v1 \ No newline at end of file diff --git a/README.md b/README.md index 45aee30..4cd9f18 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,5 @@ # Swim System Python Implementation -[![PyPI version](https://badge.fury.io/py/swimai.svg)](https://badge.fury.io/py/swimai) +[![PyPI version](https://badge.fury.io/py/swimos.svg)](https://badge.fury.io/py/swimos) [![Build Status](https://dev.azure.com/swimai-build/swim-rust/_apis/build/status/swimos.swim-system-python?branchName=main)](https://dev.azure.com/swimai-build/swim-rust/_build/latest?definitionId=6&branchName=main) [![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](LICENSE) [![Code of Conduct](https://img.shields.io/badge/code-of%20conduct-green.svg)](CODE_OF_CONDUCT.md) @@ -17,13 +17,13 @@ enabling every state of a Web API to be streamed, without interference from billions of queues.
## Installation -`pip install swimai` +`pip install swimos` ## Usage ```python # Setting the value of a value lane on a remote agent. import time -from swimai import SwimClient +from swimos import SwimClient with SwimClient() as swim_client: host_uri = 'ws://localhost:9001' @@ -57,7 +57,7 @@ with SwimClient() as swim_client: ##### With coverage: 1) Install async test package: `pip install aiounittest` 2) Install coverage package: `pip install coverage` -3) Generate report: `coverage run --source=swimai -m unittest` +3) Generate report: `coverage run --source=swimos -m unittest` 4) View report: `coverage report -m` ### Run Lint @@ -68,9 +68,9 @@ with SwimClient() as swim_client: 1) Install commit hook package: `pip install pre-commit` 2) Run hook installation: `pre-commit install` ### Build package -##### Building source distribution -1) Run: `python setup.py sdist` -##### Building wheel -1) Install wheel package: `pip install wheel` -2) Run: `python setup.py sdist` - +##### Building package distribution +1) Install build package: `pip install build` +2) Run: `python -m build` +##### Releasing a new version +1) Add version tag: `git tag VERSION (e.g. 0.1.0)` +2) Push to remote: `git push origin VERSION` \ No newline at end of file diff --git a/azure-pipelines.yml b/azure-pipelines.yml index 9e399a7..4480de2 100644 --- a/azure-pipelines.yml +++ b/azure-pipelines.yml @@ -21,7 +21,7 @@ steps: displayName: 'Run flake8' - script: | - py.test --cov-report=xml --cov=swimai test/ + py.test --cov-report=xml --cov=swimos test/ displayName: 'Run pytest' - template: azure-code-coverage.yml diff --git a/examples/client_example.py b/examples/client_example.py index 28646f6..65a9ea6 100644 --- a/examples/client_example.py +++ b/examples/client_example.py @@ -15,8 +15,8 @@ # Setting the value of a value lane on a remote agent. import time -from swimai import SwimClient -from swimai.structures import Num +from swimos import SwimClient +from swimos.structures import Num async def custom_on_event_callback(event): diff --git a/examples/cookbook/command_lanes.py b/examples/cookbook/command_lanes.py index b9e3794..4115f35 100644 --- a/examples/cookbook/command_lanes.py +++ b/examples/cookbook/command_lanes.py @@ -14,8 +14,8 @@ import time -from swimai import SwimClient -from swimai.structures import Num +from swimos import SwimClient +from swimos.structures import Num async def custom_on_event(event): diff --git a/examples/cookbook/downlinks.py b/examples/cookbook/downlinks.py index 415d49c..c02a156 100644 --- a/examples/cookbook/downlinks.py +++ b/examples/cookbook/downlinks.py @@ -14,7 +14,7 @@ import random import time -from swimai import SwimClient +from swimos import SwimClient if __name__ == '__main__': with SwimClient() as swim_client: diff --git a/examples/cookbook/join_map_lane.py b/examples/cookbook/join_map_lane.py index f4c462f..8c92e4f 100644 --- a/examples/cookbook/join_map_lane.py +++ b/examples/cookbook/join_map_lane.py @@ -13,7 +13,7 @@ # limitations under the License. import time -from swimai import SwimClient +from swimos import SwimClient THRESHOLD = 1000 diff --git a/examples/cookbook/join_value_lanes.py b/examples/cookbook/join_value_lanes.py index 7e3b591..04da2ab 100644 --- a/examples/cookbook/join_value_lanes.py +++ b/examples/cookbook/join_value_lanes.py @@ -13,8 +13,8 @@ # limitations under the License. import time -from swimai import SwimClient -from swimai.structures import Value +from swimos import SwimClient +from swimos.structures import Value async def custom_did_update(key, new_value, old_value): diff --git a/examples/cookbook/map_lanes.py b/examples/cookbook/map_lanes.py index 7286196..de246fe 100644 --- a/examples/cookbook/map_lanes.py +++ b/examples/cookbook/map_lanes.py @@ -13,7 +13,7 @@ # limitations under the License. import time -from swimai import SwimClient +from swimos import SwimClient async def custom_did_update(key, new_value, old_value): diff --git a/examples/cookbook/timers.py b/examples/cookbook/timers.py index cb3fffe..6bb5ca9 100644 --- a/examples/cookbook/timers.py +++ b/examples/cookbook/timers.py @@ -14,8 +14,8 @@ import time -from swimai import SwimClient -from swimai.structures import Value +from swimos import SwimClient +from swimos.structures import Value if __name__ == '__main__': with SwimClient() as swim_client: diff --git a/examples/cookbook/value_lanes.py b/examples/cookbook/value_lanes.py index c36a6d6..e067bf7 100644 --- a/examples/cookbook/value_lanes.py +++ b/examples/cookbook/value_lanes.py @@ -13,7 +13,7 @@ # limitations under the License. import time -from swimai import SwimClient +from swimos import SwimClient async def custom_did_set(new_value, old_value): diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 0000000..76b7319 --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,5 @@ +[build-system] +requires = ["setuptools>=45", "setuptools_scm[toml]>=6.2"] +build-backend = "setuptools.build_meta" + +[tool.setuptools_scm] \ No newline at end of file diff --git a/requirements-dev.txt b/requirements-dev.txt index 46352fe..2a93b76 100644 --- a/requirements-dev.txt +++ b/requirements-dev.txt @@ -3,4 +3,5 @@ coverage flake8 wheel setuptools -pre-commit \ No newline at end of file +pre-commit +build \ No newline at end of file diff --git a/setup.py b/setup.py index 5a76e69..df48ec9 100644 --- a/setup.py +++ b/setup.py @@ -21,8 +21,8 @@ requirements = f.read().splitlines() setuptools.setup( - name='swimai', - version='1.2.0-alpha', + name='swimos', + version='1.3.0-alpha', author='Dobromir Marinov', author_email='dobromir@swim.it', description='Standalone Python framework for building massively real-time streaming WARP clients.', diff --git a/swimai/__init__.py b/swimos/__init__.py similarity index 100% rename from swimai/__init__.py rename to swimos/__init__.py diff --git a/swimai/client/__init__.py b/swimos/client/__init__.py similarity index 100% rename from swimai/client/__init__.py rename to swimos/client/__init__.py diff --git a/swimai/client/_connections.py b/swimos/client/_connections.py similarity index 99% rename from swimai/client/_connections.py rename to swimos/client/_connections.py index 94d656c..ca82e03 100644 --- a/swimai/client/_connections.py +++ b/swimos/client/_connections.py @@ -16,7 +16,7 @@ import websockets from enum import Enum -from swimai.warp._warp import _Envelope +from swimos.warp._warp import _Envelope from typing import TYPE_CHECKING, Any if TYPE_CHECKING: diff --git a/swimai/client/_downlinks/__init__.py b/swimos/client/_downlinks/__init__.py similarity index 100% rename from swimai/client/_downlinks/__init__.py rename to swimos/client/_downlinks/__init__.py diff --git a/swimai/client/_downlinks/_downlinks.py b/swimos/client/_downlinks/_downlinks.py similarity index 99% rename from swimai/client/_downlinks/_downlinks.py rename to swimos/client/_downlinks/_downlinks.py index 135bc72..04523fe 100644 --- a/swimai/client/_downlinks/_downlinks.py +++ b/swimos/client/_downlinks/_downlinks.py @@ -18,9 +18,9 @@ from collections.abc import Callable from abc import abstractmethod, ABC from typing import TYPE_CHECKING, Any -from swimai.recon import Recon -from swimai.structures import Value, RecordConverter -from swimai.warp._warp import _SyncRequest, _CommandMessage, _Envelope, _LinkRequest +from swimos.recon import Recon +from swimos.structures import Value, RecordConverter +from swimos.warp._warp import _SyncRequest, _CommandMessage, _Envelope, _LinkRequest from .._utils import _URI from ._utils import before_open, UpdateRequest, RemoveRequest, after_open, validate_callback diff --git a/swimai/client/_downlinks/_utils.py b/swimos/client/_downlinks/_utils.py similarity index 97% rename from swimai/client/_downlinks/_utils.py rename to swimos/client/_downlinks/_utils.py index 26ae557..6dc87b8 100644 --- a/swimai/client/_downlinks/_utils.py +++ b/swimos/client/_downlinks/_utils.py @@ -16,8 +16,8 @@ import sys from abc import ABC, abstractmethod from typing import Any, Callable -from swimai.structures import RecordMap, Slot, Text, RecordConverter, Attr -from swimai.structures._structs import _Item, _Record +from swimos.structures import RecordMap, Slot, Text, RecordConverter, Attr +from swimos.structures._structs import _Item, _Record def before_open(function: 'Callable') -> 'Callable': diff --git a/swimai/client/_swim_client.py b/swimos/client/_swim_client.py similarity index 98% rename from swimai/client/_swim_client.py rename to swimos/client/_swim_client.py index 5e9b708..a941ec4 100644 --- a/swimai/client/_swim_client.py +++ b/swimos/client/_swim_client.py @@ -26,8 +26,8 @@ from ._connections import _ConnectionPool, _WSConnection from ._downlinks._downlinks import _ValueDownlinkView, _EventDownlinkView, _DownlinkView, _MapDownlinkView from ._utils import _URI, after_started -from swimai.structures import RecordConverter -from swimai.warp._warp import _CommandMessage +from swimos.structures import RecordConverter +from swimos.warp._warp import _CommandMessage class SwimClient: diff --git a/swimai/client/_utils.py b/swimos/client/_utils.py similarity index 100% rename from swimai/client/_utils.py rename to swimos/client/_utils.py diff --git a/swimai/recon/__init__.py b/swimos/recon/__init__.py similarity index 100% rename from swimai/recon/__init__.py rename to swimos/recon/__init__.py diff --git a/swimai/recon/_parsers.py b/swimos/recon/_parsers.py similarity index 98% rename from swimai/recon/_parsers.py rename to swimos/recon/_parsers.py index 5677223..65dcf8f 100644 --- a/swimai/recon/_parsers.py +++ b/swimos/recon/_parsers.py @@ -16,8 +16,8 @@ from typing import Union, Any from ._utils import _ReconUtils, _InputMessage, _OutputMessage -from swimai.structures import Text, Bool, Attr, Value, Slot, Num, RecordMap -from swimai.structures._structs import _Item, _Record, _ValueBuilder +from swimos.structures import Text, Bool, Attr, Value, Slot, Num, RecordMap +from swimos.structures._structs import _Item, _Record, _ValueBuilder class _ReconParser: diff --git a/swimai/recon/_recon.py b/swimos/recon/_recon.py similarity index 97% rename from swimai/recon/_recon.py rename to swimos/recon/_recon.py index 6e50a9f..89af568 100644 --- a/swimai/recon/_recon.py +++ b/swimos/recon/_recon.py @@ -12,7 +12,7 @@ # See the License for the specific language governing permissions and # limitations under the License. -from swimai.structures._structs import Value +from swimos.structures._structs import Value from ._parsers import _ReconParser from ._writers import _ReconWriter diff --git a/swimai/recon/_utils.py b/swimos/recon/_utils.py similarity index 100% rename from swimai/recon/_utils.py rename to swimos/recon/_utils.py diff --git a/swimai/recon/_writers.py b/swimos/recon/_writers.py similarity index 98% rename from swimai/recon/_writers.py rename to swimos/recon/_writers.py index c53d036..f3fb1d5 100644 --- a/swimai/recon/_writers.py +++ b/swimos/recon/_writers.py @@ -16,8 +16,8 @@ from typing import Union, List, Optional from ._utils import _ReconUtils, _OutputMessage -from swimai.structures import Attr, Slot, Value, Text, Num, Bool -from swimai.structures._structs import _Absent, _Item, _Extant, _Record +from swimos.structures import Attr, Slot, Value, Text, Num, Bool +from swimos.structures._structs import _Absent, _Item, _Extant, _Record class _ReconWriter: diff --git a/swimai/structures/__init__.py b/swimos/structures/__init__.py similarity index 100% rename from swimai/structures/__init__.py rename to swimos/structures/__init__.py diff --git a/swimai/structures/_structs.py b/swimos/structures/_structs.py similarity index 100% rename from swimai/structures/_structs.py rename to swimos/structures/_structs.py diff --git a/swimai/warp/__init__.py b/swimos/warp/__init__.py similarity index 100% rename from swimai/warp/__init__.py rename to swimos/warp/__init__.py diff --git a/swimai/warp/_warp.py b/swimos/warp/_warp.py similarity index 98% rename from swimai/warp/_warp.py rename to swimos/warp/_warp.py index ea7e7b8..f1e9203 100644 --- a/swimai/warp/_warp.py +++ b/swimos/warp/_warp.py @@ -15,9 +15,9 @@ import math from abc import ABC, abstractmethod from typing import Optional -from swimai.recon import Recon -from swimai.structures import Attr, Value, Num, RecordMap -from swimai.structures._structs import _Record, _Item +from swimos.recon import Recon +from swimos.structures import Attr, Value, Num, RecordMap +from swimos.structures._structs import _Record, _Item class _Envelope(ABC): diff --git a/test/client/downlinks/test_downlink_utils.py b/test/client/downlinks/test_downlink_utils.py index c9b10b4..4a68620 100644 --- a/test/client/downlinks/test_downlink_utils.py +++ b/test/client/downlinks/test_downlink_utils.py @@ -18,10 +18,10 @@ from aiounittest import async_test -from swimai import SwimClient -from swimai.client._downlinks._downlinks import _EventDownlinkView, _ValueDownlinkView -from swimai.client._downlinks._utils import UpdateRequest, RemoveRequest, convert_to_async, validate_callback -from swimai.structures import RecordMap, Slot, Num, Attr, Value +from swimos import SwimClient +from swimos.client._downlinks._downlinks import _EventDownlinkView, _ValueDownlinkView +from swimos.client._downlinks._utils import UpdateRequest, RemoveRequest, convert_to_async, validate_callback +from swimos.structures import RecordMap, Slot, Num, Attr, Value from test.utils import MockPerson, mock_func, mock_coro diff --git a/test/client/downlinks/test_downlinks.py b/test/client/downlinks/test_downlinks.py index eed100b..82e986a 100644 --- a/test/client/downlinks/test_downlinks.py +++ b/test/client/downlinks/test_downlinks.py @@ -16,15 +16,15 @@ from concurrent.futures import Future from unittest.mock import patch -from swimai import SwimClient -from swimai.client._connections import _DownlinkManager, _DownlinkManagerStatus -from swimai.client._downlinks._downlinks import _EventDownlinkModel, _DownlinkModel, _ValueDownlinkModel, \ +from swimos import SwimClient +from swimos.client._connections import _DownlinkManager, _DownlinkManagerStatus +from swimos.client._downlinks._downlinks import _EventDownlinkModel, _DownlinkModel, _ValueDownlinkModel, \ _EventDownlinkView, \ _DownlinkView, _ValueDownlinkView, _MapDownlinkModel, _MapDownlinkView -from swimai.client._downlinks._utils import UpdateRequest, RemoveRequest -from swimai.structures import Text, Attr, RecordMap, Num, Bool, Slot, Value -from swimai.structures._structs import _Absent, _Record -from swimai.warp._warp import _LinkedResponse, _SyncedResponse, _EventMessage, _UnlinkedResponse +from swimos.client._downlinks._utils import UpdateRequest, RemoveRequest +from swimos.structures import Text, Attr, RecordMap, Num, Bool, Slot, Value +from swimos.structures._structs import _Absent, _Record +from swimos.warp._warp import _LinkedResponse, _SyncedResponse, _EventMessage, _UnlinkedResponse from test.utils import MockConnection, MockExecuteOnException, MockWebsocketConnect, MockWebsocket, \ mock_did_set_confirmation, ReceiveLoop, MockPerson, MockPet, NewScope, MockNoDefaultConstructor, MockCar, \ MockModel, MockDownlinkManager, mock_on_event_callback, MockEventCallback, \ @@ -65,7 +65,7 @@ async def test_open_downlink_model(self): self.assertEqual(downlink, actual) self.assertIsInstance(actual.task, Future) - @patch('swimai.client._connections._DownlinkManager._close_views') + @patch('swimos.client._connections._DownlinkManager._close_views') async def test_close_downlink_model_with_manager(self, mock_close_views): # Given with SwimClient() as client: @@ -87,7 +87,7 @@ async def test_close_downlink_model_with_manager(self, mock_close_views): self.assertTrue(actual.task.cancelled()) self.assertTrue(mock_close_views.called) - @patch('swimai.client._connections._DownlinkManager._close_views') + @patch('swimos.client._connections._DownlinkManager._close_views') async def test_close_downlink_model_without_manager(self, mock_close_views): # Given with SwimClient() as client: @@ -1062,7 +1062,7 @@ async def test_event_downlink_view_execute_on_event_missing_callback(self): downlink_view = _EventDownlinkView(client) event = 20 # When - with patch('swimai.SwimClient._schedule_task') as mock_schedule_task: + with patch('swimos.SwimClient._schedule_task') as mock_schedule_task: await downlink_view._execute_on_event(event) # Then @@ -1503,7 +1503,7 @@ async def test_value_downlink_view_execute_did_set_no_callback(self): new_value = 'Test_new_value' old_value = 'Test_old_value' # When - with patch('swimai.SwimClient._schedule_task') as mock_schedule_task: + with patch('swimos.SwimClient._schedule_task') as mock_schedule_task: await downlink_view._execute_did_set(new_value, old_value) # Then @@ -2256,7 +2256,7 @@ async def test_map_downlink_view_execute_did_update_no_callback(self): new_value = 'Test_update_new_value' old_value = 'Test_update_old_value' # When - with patch('swimai.SwimClient._schedule_task') as mock_schedule_task: + with patch('swimos.SwimClient._schedule_task') as mock_schedule_task: await downlink_view._execute_did_update(key, new_value, old_value) # Then @@ -2285,7 +2285,7 @@ async def test_map_downlink_view_execute_did_remove_no_callback(self): key = 'Test_remove_key' value = 'Test_remove_value' # When - with patch('swimai.SwimClient._schedule_task') as mock_schedule_task: + with patch('swimos.SwimClient._schedule_task') as mock_schedule_task: await downlink_view._execute_did_remove(key, value) # Then diff --git a/test/client/test_connections.py b/test/client/test_connections.py index 1b21258..bd5fdae 100644 --- a/test/client/test_connections.py +++ b/test/client/test_connections.py @@ -14,12 +14,12 @@ import aiounittest from unittest.mock import patch -from swimai import SwimClient -from swimai.client._connections import _WSConnection, _ConnectionStatus, _ConnectionPool, _DownlinkManagerPool, \ +from swimos import SwimClient +from swimos.client._connections import _WSConnection, _ConnectionStatus, _ConnectionPool, _DownlinkManagerPool, \ _DownlinkManager, _DownlinkManagerStatus -from swimai.client._downlinks._downlinks import _ValueDownlinkModel -from swimai.structures import Text, Value -from swimai.warp._warp import _SyncedResponse, _LinkedResponse, _EventMessage +from swimos.client._downlinks._downlinks import _ValueDownlinkModel +from swimos.structures import Text, Value +from swimos.warp._warp import _SyncedResponse, _LinkedResponse, _EventMessage from test.utils import MockWebsocket, MockWebsocketConnect, MockAsyncFunction, MockReceiveMessage, MockConnection, \ MockDownlink, mock_did_set_callback, MockClass, mock_on_event_callback, mock_did_update_callback, \ mock_did_remove_callback, MockWebsocketConnectException @@ -101,7 +101,7 @@ async def test_pool_remove_connection_non_existing(self): # Then self.assertEqual(0, pool._size) - @patch('swimai.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) async def test_pool_add_downlink_view_existing_connection(self, mock_subscribe): # Given pool = _ConnectionPool() @@ -123,7 +123,7 @@ async def test_pool_add_downlink_view_existing_connection(self, mock_subscribe): self.assertEqual(_ConnectionStatus.IDLE, connection.status) mock_subscribe.assert_called_once_with(downlink_view) - @patch('swimai.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) async def test_pool_add_downlink_view_non_existing_connection(self, mock_subscribe): # Given pool = _ConnectionPool() @@ -139,8 +139,8 @@ async def test_pool_add_downlink_view_non_existing_connection(self, mock_subscri self.assertEqual(1, pool._size) mock_subscribe.assert_called_once_with(downlink_view) - @patch('swimai.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._WSConnection._unsubscribe', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._WSConnection._unsubscribe', new_callable=MockAsyncFunction) async def test_pool_remove_downlink_view_existing_connection_open(self, mock_unsubscribe, mock_subscribed): # Given pool = _ConnectionPool() @@ -160,8 +160,8 @@ async def test_pool_remove_downlink_view_existing_connection_open(self, mock_uns mock_subscribed.assert_called_with(downlink_view) mock_unsubscribe.assert_called_with(downlink_view) - @patch('swimai.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._WSConnection._unsubscribe', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._WSConnection._subscribe', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._WSConnection._unsubscribe', new_callable=MockAsyncFunction) async def test_pool_remove_downlink_view_existing_connection_closed(self, mock_unsubscribe, mock_subscribe): # Given pool = _ConnectionPool() @@ -183,7 +183,7 @@ async def test_pool_remove_downlink_view_existing_connection_closed(self, mock_u mock_subscribe.assert_called_once_with(downlink_view) mock_unsubscribe.assert_called_once_with(downlink_view) - @patch('swimai.client._connections._DownlinkManagerPool._deregister_downlink_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManagerPool._deregister_downlink_view', new_callable=MockAsyncFunction) async def test_pool_remove_downlink_view_non_existing_connection(self, mock_deregister_downlink_view): # Given pool = _ConnectionPool() @@ -212,7 +212,7 @@ async def test_ws_connection(self): self.assertEqual(_ConnectionStatus.CLOSED, actual.status) @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) async def test_ws_connection_subscribe_single(self, mock_add_view, mock_websocket): # Given host_uri = 'ws://localhost:9001' @@ -235,7 +235,7 @@ async def test_ws_connection_subscribe_single(self, mock_add_view, mock_websocke mock_add_view.assert_called_once_with(downlink_view) @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) async def test_ws_connection_subscribe_multiple(self, mock_add_view, mock_websocket): # Given host_uri = 'ws://1.1.1.1:9001' @@ -266,8 +266,8 @@ async def test_ws_connection_subscribe_multiple(self, mock_add_view, mock_websoc mock_add_view.assert_any_call(second_downlink_view) @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._remove_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._remove_view', new_callable=MockAsyncFunction) async def test_ws_connection_unsubscribe_all(self, mock_remove_view, mock_add_view, mock_websocket): # Given host_uri = 'ws://0.0.0.0:9001' @@ -294,8 +294,8 @@ async def test_ws_connection_unsubscribe_all(self, mock_remove_view, mock_add_vi mock_remove_view.assert_called_once_with(downlink_view) @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._remove_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._remove_view', new_callable=MockAsyncFunction) async def test_ws_connection_unsubscribe_one(self, mock_remove_view, mock_add_view, mock_websocket): # Given host_uri = 'ws://1.2.3.4:9001' @@ -513,8 +513,8 @@ async def test_ws_connection_wait_for_message_closed(self): self.assertEqual(_ConnectionStatus.CLOSED, connection.status) @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._receive_message', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._receive_message', new_callable=MockAsyncFunction) async def test_ws_connection_wait_for_message_receive_single(self, mock_receive_message, mock_add_view, mock_websocket): # Given @@ -544,8 +544,8 @@ async def test_ws_connection_wait_for_message_receive_single(self, mock_receive_ mock_receive_message.assert_called_once() @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._receive_message', new_callable=MockReceiveMessage) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._receive_message', new_callable=MockReceiveMessage) async def test_ws_connection_wait_for_message_receive_multiple(self, mock_receive_message, mock_add_view, mock_websocket): # Given @@ -587,8 +587,8 @@ async def test_ws_connection_wait_for_message_receive_multiple(self, mock_receiv self.assertEqual(3, mock_receive_message.call_count) @patch('websockets.connect', new_callable=MockWebsocketConnect) - @patch('swimai.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._receive_message', new_callable=MockReceiveMessage) + @patch('swimos.client._connections._DownlinkManager._add_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._receive_message', new_callable=MockReceiveMessage) async def test_ws_connection_wait_for_message_receive_exception(self, mock_receive_message, mock_add_view, mock_websocket): # Given @@ -622,7 +622,7 @@ async def test_downlink_manager_pool(self): self.assertIsInstance(actual, _DownlinkManagerPool) self.assertEqual(0, actual._size) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_register_downlink_view_single(self, mock_open): # Given client = SwimClient() @@ -637,7 +637,7 @@ async def test_downlink_manager_pool_register_downlink_view_single(self, mock_op self.assertEqual(1, actual._size) mock_open.assert_called_once() - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_register_downlink_view_multiple_different_routes(self, mock_open): # Given client = SwimClient() @@ -656,7 +656,7 @@ async def test_downlink_manager_pool_register_downlink_view_multiple_different_r self.assertEqual(2, actual._size) self.assertEqual(2, mock_open.call_count) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_register_downlink_view_multiple_same_route(self, mock_open): # Given client = SwimClient() @@ -675,8 +675,8 @@ async def test_downlink_manager_pool_register_downlink_view_multiple_same_route( self.assertEqual(1, actual._size) mock_open.assert_called_once() - @patch('swimai.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_deregister_downlink_view_single_existing(self, mock_open, mock_close): # Given client = SwimClient() @@ -693,7 +693,7 @@ async def test_downlink_manager_pool_deregister_downlink_view_single_existing(se mock_open.assert_called_once() mock_close.assert_called_once() - @patch('swimai.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_deregister_downlink_view_single_non_existing(self, mock_close): # Given client = SwimClient() @@ -708,8 +708,8 @@ async def test_downlink_manager_pool_deregister_downlink_view_single_non_existin self.assertEqual(0, actual._size) mock_close.assert_not_called() - @patch('swimai.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_deregister_downlink_view_multiple_same_route(self, mock_open, mock_close): # Given client = SwimClient() @@ -731,8 +731,8 @@ async def test_downlink_manager_pool_deregister_downlink_view_multiple_same_rout self.assertEqual(1, mock_open.call_count) self.assertEqual(1, mock_close.call_count) - @patch('swimai.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._close', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_deregister_downlink_view_multiple_different_routes(self, mock_open, mock_close): # Given @@ -755,8 +755,8 @@ async def test_downlink_manager_pool_deregister_downlink_view_multiple_different self.assertEqual(2, mock_open.call_count) self.assertEqual(2, mock_close.call_count) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._receive_message', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._receive_message', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_receive_message_existing_route(self, mock_receive_message, mock_open): # Given client = SwimClient() @@ -773,8 +773,8 @@ async def test_downlink_manager_pool_receive_message_existing_route(self, mock_r mock_open.assert_called_once() mock_receive_message.assert_called_once_with(message) - @patch('swimai.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._DownlinkManager._receive_message', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._open', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._DownlinkManager._receive_message', new_callable=MockAsyncFunction) async def test_downlink_manager_pool_receive_message_non_existing_route(self, mock_receive_message, mock_open): # Given client = SwimClient() @@ -805,7 +805,7 @@ async def test_downlink_manager(self): self.assertEqual(0, actual._view_count) self.assertEqual(_DownlinkManagerStatus.CLOSED, actual.status) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_open_new(self, mock_schedule_task): # Given host_uri = 'ws://5.5.5.5:9001' @@ -828,7 +828,7 @@ async def test_downlink_manager_open_new(self, mock_schedule_task): self.assertEqual(1, len(MockConnection.get_mock_connection().messages_sent)) self.assertEqual('@sync(node:foo,lane:bar)', MockConnection.get_mock_connection().messages_sent[0]) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_open_existing(self, mock_schedule_task): # Given host_uri = 'ws://5.5.5.5:9001' @@ -852,7 +852,7 @@ async def test_downlink_manager_open_existing(self, mock_schedule_task): self.assertEqual(1, len(MockConnection.get_mock_connection().messages_sent)) mock_schedule_task.assert_called_once_with(MockConnection.get_mock_connection()._wait_for_messages) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_close_running(self, mock_schedule_task): # Given host_uri = 'ws://1.2.3.4:9001' @@ -875,7 +875,7 @@ async def test_downlink_manager_close_running(self, mock_schedule_task): self.assertEqual(1, len(MockConnection.get_mock_connection().messages_sent)) self.assertEqual(2, mock_schedule_task.call_count) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_close_stopped(self, mock_schedule_task): # Given host_uri = 'ws://4.3.2.1:9001' @@ -951,8 +951,8 @@ async def test_downlink_manager_init_downlink_model_strict_classes(self): self.assertEqual(actual.downlink_model.downlink_manager, actual) client.stop() - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_add_view_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://99.99.99.99:9001' @@ -980,8 +980,8 @@ async def test_downlink_manager_add_view_single(self, mock_schedule_task, mock_s self.assertEqual(1, mock_send_message.call_count) self.assertTrue(downlink_view._initialised.is_set()) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_add_view_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://11.22.33.44:9001' @@ -1019,8 +1019,8 @@ async def test_downlink_manager_add_view_multiple(self, mock_schedule_task, mock self.assertTrue(second_downlink_view._initialised.is_set()) self.assertTrue(third_downlink_view._initialised.is_set()) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_remove_view_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://11.11.11.11:9001' @@ -1049,8 +1049,8 @@ async def test_downlink_manager_remove_view_single(self, mock_schedule_task, moc self.assertEqual(1, mock_send_message.call_count) self.assertTrue(downlink_view._initialised.is_set()) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_remove_view_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://44.33.22.11:9001' @@ -1086,8 +1086,8 @@ async def test_downlink_manager_remove_view_multiple(self, mock_schedule_task, m self.assertTrue(second_downlink_view._initialised.is_set()) self.assertTrue(third_downlink_view._initialised.is_set()) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_remove_view_non_existing(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://66.66.66.66:9001' @@ -1108,8 +1108,8 @@ async def test_downlink_manager_remove_view_non_existing(self, mock_schedule_tas mock_send_message.assert_not_called() self.assertFalse(downlink_view._initialised.is_set()) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_receive_message_linked(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://66.66.66.66:9001' @@ -1130,8 +1130,8 @@ async def test_downlink_manager_receive_message_linked(self, mock_schedule_task, self.assertEqual(1, mock_schedule_task.call_count) self.assertEqual(1, mock_send_message.call_count) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_receive_message_synced(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://11.11.11.11:9001' @@ -1152,8 +1152,8 @@ async def test_downlink_manager_receive_message_synced(self, mock_schedule_task, self.assertEqual(1, mock_schedule_task.call_count) self.assertEqual(1, mock_send_message.call_count) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_receive_message_event(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://33.33.33.33:9001' @@ -1175,8 +1175,8 @@ async def test_downlink_manager_receive_message_event(self, mock_schedule_task, self.assertEqual(1, mock_schedule_task.call_count) self.assertEqual(1, mock_send_message.call_count) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_receive_message_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://44.44.44.44:9001' @@ -1204,8 +1204,8 @@ async def test_downlink_manager_receive_message_multiple(self, mock_schedule_tas self.assertEqual(1, mock_schedule_task.call_count) self.assertEqual(1, mock_send_message.call_count) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_did_set_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://4.3.2.1:9001' @@ -1229,8 +1229,8 @@ async def test_downlink_manager_subscribers_did_set_single(self, mock_schedule_t self.assertEqual('dead', mock_schedule_task.call_args_list[1][0][1]) self.assertEqual('parrot', mock_schedule_task.call_args_list[1][0][2]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_did_set_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://10.9.8.7:9001' @@ -1281,8 +1281,8 @@ async def test_downlink_manager_subscribers_did_set_multiple(self, mock_schedule self.assertEqual('hello', mock_schedule_task.call_args_list[5][0][1]) self.assertEqual('world', mock_schedule_task.call_args_list[5][0][2]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_on_event_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://4.3.2.1:9001' @@ -1305,8 +1305,8 @@ async def test_downlink_manager_subscribers_on_event_single(self, mock_schedule_ self.assertEqual(on_event_callback, mock_schedule_task.call_args_list[1][0][0]) self.assertEqual('Hello, friend!', mock_schedule_task.call_args_list[1][0][1]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_on_event_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://10.9.8.7:9001' @@ -1346,8 +1346,8 @@ async def test_downlink_manager_subscribers_on_event_multiple(self, mock_schedul self.assertEqual(on_event_callback, mock_schedule_task.call_args_list[3][0][0]) self.assertEqual('Welcome home!', mock_schedule_task.call_args_list[3][0][1]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_did_update_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://4.3.2.1:9001' @@ -1372,8 +1372,8 @@ async def test_downlink_manager_subscribers_did_update_single(self, mock_schedul self.assertEqual('New_value', mock_schedule_task.call_args_list[1][0][2]) self.assertEqual('Old_Value', mock_schedule_task.call_args_list[1][0][3]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_did_update_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://10.9.8.7:9001' @@ -1419,8 +1419,8 @@ async def test_downlink_manager_subscribers_did_update_multiple(self, mock_sched self.assertEqual('NeW', mock_schedule_task.call_args_list[3][0][2]) self.assertEqual('OlD', mock_schedule_task.call_args_list[3][0][3]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_did_remove_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://4.3.2.1:9001' @@ -1444,8 +1444,8 @@ async def test_downlink_manager_subscribers_did_remove_single(self, mock_schedul self.assertEqual('Key', mock_schedule_task.call_args_list[1][0][1]) self.assertEqual('Old_Value', mock_schedule_task.call_args_list[1][0][2]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_subscribers_did_remove_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://10.9.8.7:9001' @@ -1488,8 +1488,8 @@ async def test_downlink_manager_subscribers_did_remove_multiple(self, mock_sched self.assertEqual('Bar', mock_schedule_task.call_args_list[3][0][1]) self.assertEqual('Baz', mock_schedule_task.call_args_list[3][0][2]) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_close_views_single(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://4.3.2.1:9001' @@ -1508,8 +1508,8 @@ async def test_downlink_manager_close_views_single(self, mock_schedule_task, moc self.assertTrue(mock_schedule_task.called) self.assertTrue(mock_send_message.called) - @patch('swimai.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) - @patch('swimai.SwimClient._schedule_task') + @patch('swimos.client._connections._WSConnection._send_message', new_callable=MockAsyncFunction) + @patch('swimos.SwimClient._schedule_task') async def test_downlink_manager_close_views_multiple(self, mock_schedule_task, mock_send_message): # Given host_uri = 'ws://4.3.2.1:9001' diff --git a/test/client/test_swim_client.py b/test/client/test_swim_client.py index 05057d1..20ff35e 100644 --- a/test/client/test_swim_client.py +++ b/test/client/test_swim_client.py @@ -17,11 +17,11 @@ from threading import Thread from unittest.mock import patch -from swimai.client._downlinks._downlinks import _ValueDownlinkView, _MapDownlinkView, _EventDownlinkView -from swimai.structures import Text +from swimos.client._downlinks._downlinks import _ValueDownlinkView, _MapDownlinkView, _EventDownlinkView +from swimos.structures import Text from test.utils import MockWebsocketConnect, MockWebsocket, MockAsyncFunction, MockScheduleTask, \ mock_exception_callback, MockRunWithExceptionOnce, MockExceptionOnce -from swimai import SwimClient +from swimos import SwimClient class TestSwimClient(aiounittest.AsyncTestCase): @@ -268,7 +268,7 @@ def test_swim_client_downlink_value_open_before_client_started(self, mock_warn): self.assertEqual('Cannot execute "_add_downlink_view" before the client has been started!', mock_warn.call_args_list[0][0][0]) - @patch('swimai.client._connections._ConnectionPool._add_downlink_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._ConnectionPool._add_downlink_view', new_callable=MockAsyncFunction) async def test_swim_client_add_downlink_view(self, mock_add_downlink): # Given host_uri = 'ws://localhost:9001' @@ -288,8 +288,8 @@ async def test_swim_client_add_downlink_view(self, mock_add_downlink): # Then mock_add_downlink.assert_called_once_with(downlink_view) - @patch('swimai.client._connections._ConnectionPool._add_downlink_view', new_callable=MockAsyncFunction) - @patch('swimai.client._connections._ConnectionPool._remove_downlink_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._ConnectionPool._add_downlink_view', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._ConnectionPool._remove_downlink_view', new_callable=MockAsyncFunction) async def test_swim_client_remove_downlink_view(self, mock_remove_downlink, mock_add_downlink): # Given host_uri = 'ws://localhost:9001' @@ -311,7 +311,7 @@ async def test_swim_client_remove_downlink_view(self, mock_remove_downlink, mock mock_add_downlink.assert_called_once_with(downlink_view) mock_remove_downlink.assert_called_once_with(downlink_view) - @patch('swimai.client._connections._ConnectionPool._get_connection', new_callable=MockAsyncFunction) + @patch('swimos.client._connections._ConnectionPool._get_connection', new_callable=MockAsyncFunction) async def test_swim_client_get_connection(self, mock_get_connection): # Given host_uri = 'ws://localhost:9001' diff --git a/test/client/test_utils.py b/test/client/test_utils.py index 5b593df..c6021c1 100644 --- a/test/client/test_utils.py +++ b/test/client/test_utils.py @@ -15,7 +15,7 @@ import unittest from urllib.parse import urlparse -from swimai.client._utils import _URI +from swimos.client._utils import _URI class TestUtils(unittest.TestCase): diff --git a/test/recon/test_parsers.py b/test/recon/test_parsers.py index 53795d2..a97f68a 100644 --- a/test/recon/test_parsers.py +++ b/test/recon/test_parsers.py @@ -14,9 +14,9 @@ import unittest -from swimai.recon._parsers import _ReconParser, _InputMessage, _OutputMessage, _DecimalParser -from swimai.structures import RecordMap, Slot, Text, Attr, Num, Bool -from swimai.structures._structs import _Absent +from swimos.recon._parsers import _ReconParser, _InputMessage, _OutputMessage, _DecimalParser +from swimos.structures import RecordMap, Slot, Text, Attr, Num, Bool +from swimos.structures._structs import _Absent class TestParsers(unittest.TestCase): diff --git a/test/recon/test_recon.py b/test/recon/test_recon.py index f7fb41d..f877ed8 100644 --- a/test/recon/test_recon.py +++ b/test/recon/test_recon.py @@ -14,10 +14,10 @@ import unittest -from swimai.structures import RecordMap, Attr, Text, Slot -from swimai.recon import Recon -from swimai.recon._parsers import _ReconParser -from swimai.recon._writers import _ReconWriter +from swimos.structures import RecordMap, Attr, Text, Slot +from swimos.recon import Recon +from swimos.recon._parsers import _ReconParser +from swimos.recon._writers import _ReconWriter class TestRecon(unittest.TestCase): diff --git a/test/recon/test_utils.py b/test/recon/test_utils.py index 6074414..a89a0af 100644 --- a/test/recon/test_utils.py +++ b/test/recon/test_utils.py @@ -14,7 +14,7 @@ import unittest -from swimai.recon._parsers import _ReconUtils, _OutputMessage, _InputMessage +from swimos.recon._parsers import _ReconUtils, _OutputMessage, _InputMessage from test.utils import CustomString diff --git a/test/recon/test_writers.py b/test/recon/test_writers.py index 7913fff..471018d 100644 --- a/test/recon/test_writers.py +++ b/test/recon/test_writers.py @@ -14,11 +14,11 @@ import unittest -from swimai.recon._parsers import _OutputMessage -from swimai.recon._writers import _BoolWriter, _IdentWriter, _NumberWriter, _StringWriter, _SlotWriter, _ReconWriter, \ +from swimos.recon._parsers import _OutputMessage +from swimos.recon._writers import _BoolWriter, _IdentWriter, _NumberWriter, _StringWriter, _SlotWriter, _ReconWriter, \ _AttrWriter, _BlockWriter -from swimai.structures import Text, Slot, Attr, Num, Bool -from swimai.structures._structs import _Extant, _Absent, _Record +from swimos.structures import Text, Slot, Attr, Num, Bool +from swimos.structures._structs import _Extant, _Absent, _Record from test.utils import CustomItem diff --git a/test/structures/test_structs.py b/test/structures/test_structs.py index c3a0be3..7f1ce4f 100644 --- a/test/structures/test_structs.py +++ b/test/structures/test_structs.py @@ -14,8 +14,8 @@ import os import unittest -from swimai.structures import Num, Attr, Slot, Text, RecordMap, Bool, Value, RecordConverter -from swimai.structures._structs import _Item, _Extant, _Absent, _RecordFlags, _Record, _RecordMapView, _ValueBuilder +from swimos.structures import Num, Attr, Slot, Text, RecordMap, Bool, Value, RecordConverter +from swimos.structures._structs import _Item, _Extant, _Absent, _RecordFlags, _Record, _RecordMapView, _ValueBuilder from test.utils import CustomString, CustomItem, MockPerson, MockPet, MockCar diff --git a/test/utils.py b/test/utils.py index d9b2d5f..f497300 100644 --- a/test/utils.py +++ b/test/utils.py @@ -15,8 +15,8 @@ import asyncio from typing import Any from unittest.mock import MagicMock -from swimai.client._connections import _ConnectionStatus -from swimai.structures._structs import _Item +from swimos.client._connections import _ConnectionStatus +from swimos.structures._structs import _Item class CustomString: diff --git a/test/warp/test_envelope_parse.py b/test/warp/test_envelope_parse.py index 2994287..635ab87 100644 --- a/test/warp/test_envelope_parse.py +++ b/test/warp/test_envelope_parse.py @@ -14,7 +14,7 @@ import unittest -from swimai.warp._warp import _Envelope +from swimos.warp._warp import _Envelope class TestParser(unittest.TestCase): diff --git a/test/warp/test_envelope_write.py b/test/warp/test_envelope_write.py index 212d98b..f4b0990 100644 --- a/test/warp/test_envelope_write.py +++ b/test/warp/test_envelope_write.py @@ -14,9 +14,9 @@ import unittest -from swimai.structures import Num, Text, RecordMap, Attr, Slot, Bool -from swimai.structures._structs import _Extant -from swimai.warp._warp import _SyncRequest, _SyncedResponse, _EventMessage, _LinkedResponse, _CommandMessage, \ +from swimos.structures import Num, Text, RecordMap, Attr, Slot, Bool +from swimos.structures._structs import _Extant +from swimos.warp._warp import _SyncRequest, _SyncedResponse, _EventMessage, _LinkedResponse, _CommandMessage, \ _LinkRequest, _UnlinkedResponse diff --git a/test/warp/test_envelopes.py b/test/warp/test_envelopes.py index 24e14cc..dfdbdbf 100644 --- a/test/warp/test_envelopes.py +++ b/test/warp/test_envelopes.py @@ -14,9 +14,9 @@ import unittest -from swimai.structures import Text -from swimai.structures._structs import _Absent -from swimai.warp._warp import _Envelope, _SyncRequestForm, _SyncedResponseForm, _LinkedResponseForm, _EventMessageForm, \ +from swimos.structures import Text +from swimos.structures._structs import _Absent +from swimos.warp._warp import _Envelope, _SyncRequestForm, _SyncedResponseForm, _LinkedResponseForm, _EventMessageForm, \ _CommandMessageForm, _SyncRequest, _SyncedResponse, _LinkedResponse, _CommandMessage, _EventMessage, _LinkRequestForm, \ _UnlinkedResponseForm, _LinkRequest, _UnlinkedResponse diff --git a/test/warp/test_forms.py b/test/warp/test_forms.py index 9b9b62e..1c3637b 100644 --- a/test/warp/test_forms.py +++ b/test/warp/test_forms.py @@ -15,8 +15,8 @@ import math import unittest -from swimai.structures import Value, Text, RecordMap, Slot, Attr, Num -from swimai.warp._warp import _SyncedResponseForm, _SyncedResponse, _SyncRequestForm, _SyncRequest, _LinkedResponseForm, \ +from swimos.structures import Value, Text, RecordMap, Slot, Attr, Num +from swimos.warp._warp import _SyncedResponseForm, _SyncedResponse, _SyncRequestForm, _SyncRequest, _LinkedResponseForm, \ _CommandMessageForm, _EventMessageForm, _LinkedResponse, _CommandMessage, _EventMessage, _LinkRequestForm, \ _LinkRequest, _UnlinkedResponseForm, _UnlinkedResponse