Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
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
Original file line number Diff line number Diff line change
Expand Up @@ -681,6 +681,7 @@ def __init__(
connector_state_manager: Optional[ConnectorStateManager] = None,
max_concurrent_async_job_count: Optional[int] = None,
configured_catalog: Optional[ConfiguredAirbyteCatalog] = None,
api_budget: Optional[APIBudget] = None,
):
self._init_mappings()
self._limit_pages_fetched_per_slice = limit_pages_fetched_per_slice
Expand All @@ -695,7 +696,7 @@ def __init__(
configured_catalog
)
self._connector_state_manager = connector_state_manager or ConnectorStateManager()
self._api_budget: Optional[Union[APIBudget, HttpAPIBudget]] = None
self._api_budget: Optional[Union[APIBudget]] = api_budget
self._job_tracker: JobTracker = JobTracker(max_concurrent_async_job_count or 1)
# placeholder for deprecation warnings
self._collected_deprecation_logs: List[ConnectorBuilderLogMessage] = []
Expand Down Expand Up @@ -3887,6 +3888,7 @@ def create_parent_stream_config_with_substream_wrapper(
self._evaluate_log_level(self._emit_connector_builder_messages),
),
),
api_budget=self._api_budget,
)

return substream_factory.create_parent_stream_config(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
from datetime import datetime, timedelta, timezone
from pathlib import Path
from typing import Any, Iterable, Mapping, Optional, Union
from unittest.mock import Mock

import freezegun
import pytest
Expand Down Expand Up @@ -170,7 +171,7 @@
)
from airbyte_cdk.sources.declarative.yaml_declarative_source import YamlDeclarativeSource
from airbyte_cdk.sources.message.repository import StateFilteringMessageRepository
from airbyte_cdk.sources.streams.call_rate import MovingWindowCallRatePolicy
from airbyte_cdk.sources.streams.call_rate import APIBudget, MovingWindowCallRatePolicy
from airbyte_cdk.sources.streams.concurrent.clamping import (
ClampingEndProvider,
DayClampingStrategy,
Expand Down Expand Up @@ -744,7 +745,26 @@ def test_create_substream_partition_router():
"", resolved_manifest["partition_router"], {}
)

partition_router = factory.create_component(
model_to_component_factory = ModelToComponentFactory()
model_to_component_factory.set_api_budget(
{
"type": "HTTPAPIBudget",
"policies": [
{
"type": "MovingWindowCallRatePolicy",
"rates": [
{
"limit": 1,
"interval": "PT60S",
}
],
"matchers": [],
}
],
},
input_config,
)
partition_router = model_to_component_factory.create_component(
model_type=SubstreamPartitionRouterModel,
component_definition=partition_router_manifest,
config=input_config,
Expand All @@ -757,7 +777,14 @@ def test_create_substream_partition_router():
assert isinstance(parent_stream_configs[0].stream, DefaultStream)
assert isinstance(parent_stream_configs[1].stream, DefaultStream)

assert partition_router.parent_stream_configs[0].parent_key.eval({}) == "id"
# ensure api budget
assert get_retriever(
parent_stream_configs[0].stream
).requester._http_client._api_budget._policies
assert get_retriever(
parent_stream_configs[1].stream
).requester._http_client._api_budget._policies

assert partition_router.parent_stream_configs[0].partition_field.eval({}) == "repository_id"
assert (
partition_router.parent_stream_configs[0].request_option.inject_into
Expand Down
Loading