From bc081ca65726b5cb7dfd1f691ee39f849f05731e Mon Sep 17 00:00:00 2001 From: Randall Keur Date: Mon, 25 Nov 2024 17:49:14 -0500 Subject: [PATCH] write test for de-serialization potential error --- tests/test_carrier_accounts.py | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/tests/test_carrier_accounts.py b/tests/test_carrier_accounts.py index 73c5722..3e48ba4 100644 --- a/tests/test_carrier_accounts.py +++ b/tests/test_carrier_accounts.py @@ -1,3 +1,6 @@ +import pytest +from marshmallow import ValidationError + import shippo from shippo.models.components import CarriersEnum, ConnectExistingOwnAccountRequest from shippo.models.operations import ListCarrierAccountsRequest @@ -18,3 +21,34 @@ def test_list_all_carrier_accounts(self, api: shippo.Shippo): assert carrier_account.object_id is not None assert carrier_account.object_owner is not None assert carrier_account.test is not None + + def test_parameters_deserialize_to_dict(self, api: shippo.Shippo): + parameters = { + 'api_version': 4, + 'username': '12345', + 'password': 'password', + 'pickup_no': '12345', + 'facility_code': '1234' + } + + request_data = { + 'account_id': '123456789', + 'carrier': 'dhl_ecommerce', + 'parameters': parameters, + 'metadata': 'DHLEcomTestAccount', + 'active': False, + 'test': False + } + + try: + request = ConnectExistingOwnAccountRequest.from_dict(request_data) + assert isinstance(request.parameters, dict) + for key, value in request.parameters.items(): + assert key in parameters + assert value is not None + + except ValidationError as e: + pytest.fail(f'Deserialization failed with ValidationError: {e}') + except Exception as e: + pytest.fail(f'Unexpected error occurred: {e}') +