Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 14 additions & 0 deletions mpt_api_client/resources/billing/billing.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@
from mpt_api_client.resources.billing.invoices import AsyncInvoicesService, InvoicesService
from mpt_api_client.resources.billing.journals import AsyncJournalsService, JournalsService
from mpt_api_client.resources.billing.ledgers import AsyncLedgersService, LedgersService
from mpt_api_client.resources.billing.manual_overrides import (
AsyncManualOverridesService,
ManualOverridesService,
)
from mpt_api_client.resources.billing.statements import AsyncStatementsService, StatementsService


Expand Down Expand Up @@ -49,6 +53,11 @@ def credit_memos(self) -> CreditMemosService:
"""Credit Memos service."""
return CreditMemosService(http_client=self.http_client)

@property
def manual_overrides(self) -> ManualOverridesService:
"""Manual overrides service."""
return ManualOverridesService(http_client=self.http_client)


class AsyncBilling:
"""Billing MPT API Module."""
Expand Down Expand Up @@ -85,3 +94,8 @@ def custom_ledgers(self) -> AsyncCustomLedgersService:
def credit_memos(self) -> AsyncCreditMemosService:
"""Credit Memos service."""
return AsyncCreditMemosService(http_client=self.http_client)

@property
def manual_overrides(self) -> AsyncManualOverridesService:
"""Manual overrides service."""
return AsyncManualOverridesService(http_client=self.http_client)
38 changes: 38 additions & 0 deletions mpt_api_client/resources/billing/manual_overrides.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
from mpt_api_client.http import AsyncService, Service
from mpt_api_client.http.mixins import (
AsyncCreateMixin,
AsyncUpdateMixin,
CreateMixin,
UpdateMixin,
)
from mpt_api_client.models import Model


class ManualOverride(Model):
"""Manual Override resource."""


class ManualOverridesServiceConfig:
"""Manual Overrides service configuration."""

_endpoint = "/public/v1/billing/manual-overrides"
_model_class = ManualOverride
_collection_key = "data"


class ManualOverridesService(
CreateMixin[ManualOverride],
UpdateMixin[ManualOverride],
Service[ManualOverride],
ManualOverridesServiceConfig,
):
"""Manual Overrides service."""


class AsyncManualOverridesService(
AsyncCreateMixin[ManualOverride],
AsyncUpdateMixin[ManualOverride],
AsyncService[ManualOverride],
ManualOverridesServiceConfig,
):
"""Async Manual Overrides service."""
2 changes: 1 addition & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ extend-ignore =


per-file-ignores =
mpt_api_client/resources/billing/*.py: WPS215 WPS202
mpt_api_client/resources/billing/*.py: WPS215 WPS202 WPS214
mpt_api_client/resources/catalog/*.py: WPS110 WPS215 WPS214
mpt_api_client/resources/commerce/*.py: WPS215
mpt_api_client/rql/query_builder.py: WPS110 WPS115 WPS210 WPS214
Expand Down
6 changes: 6 additions & 0 deletions tests/resources/billing/test_billing.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@
from mpt_api_client.resources.billing.invoices import AsyncInvoicesService, InvoicesService
from mpt_api_client.resources.billing.journals import AsyncJournalsService, JournalsService
from mpt_api_client.resources.billing.ledgers import AsyncLedgersService, LedgersService
from mpt_api_client.resources.billing.manual_overrides import (
AsyncManualOverridesService,
ManualOverridesService,
)
from mpt_api_client.resources.billing.statements import AsyncStatementsService, StatementsService


Expand All @@ -34,6 +38,7 @@ def async_billing(async_http_client):
("invoices", InvoicesService),
("custom_ledgers", CustomLedgersService),
("credit_memos", CreditMemosService),
("manual_overrides", ManualOverridesService),
],
)
def test_billing_properties(billing, property_name, expected_service_class):
Expand All @@ -53,6 +58,7 @@ def test_billing_properties(billing, property_name, expected_service_class):
("invoices", AsyncInvoicesService),
("custom_ledgers", AsyncCustomLedgersService),
("credit_memos", AsyncCreditMemosService),
("manual_overrides", AsyncManualOverridesService),
],
)
def test_async_billing_properties(async_billing, property_name, expected_service_class):
Expand Down
32 changes: 32 additions & 0 deletions tests/resources/billing/test_manual_overrides.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
import pytest

from mpt_api_client.resources.billing.manual_overrides import (
AsyncManualOverridesService,
ManualOverridesService,
)


@pytest.fixture
def manual_overrides_service(http_client):
return ManualOverridesService(http_client=http_client)


@pytest.fixture
def async_manual_overrides_service(http_client):
return AsyncManualOverridesService(http_client=http_client)


@pytest.mark.parametrize(
"method",
["get", "create", "update"],
)
def test_mixins_present(manual_overrides_service, method):
assert hasattr(manual_overrides_service, method)


@pytest.mark.parametrize(
"method",
["get", "create", "update"],
)
def test_async_mixins_present(async_manual_overrides_service, method):
assert hasattr(async_manual_overrides_service, method)