From 6c7e648a289898893bd203315a3cda9c8a1114fc Mon Sep 17 00:00:00 2001 From: OwenKephart Date: Tue, 31 Dec 2024 14:25:00 -0500 Subject: [PATCH] [core-api][experimental] exclude_subruns (#26687) ## Summary & Motivation decision: experimental -> public reason: we rely on this functionality fairly heavily internally, making it unlikely that we could change it even if we wanted to (beyond a name change, which is easy enough to do in a non-breaking way in the future) docs exist: yes (api only, which is ok) ## How I Tested These Changes ## Changelog > Insert changelog entry or delete this section. --- .../freshness_checks/last_update.py | 4 ++-- .../asset_check_factories/freshness_checks/sensor.py | 4 ++-- .../freshness_checks/time_partition.py | 4 ++-- .../asset_check_factories/metadata_bounds_checks.py | 4 ++-- .../asset_check_factories/schema_change_checks.py | 4 ++-- .../dagster/dagster/_core/definitions/asset_out.py | 9 +-------- .../dagster/dagster/_core/definitions/asset_spec.py | 2 -- .../dagster/dagster/_core/definitions/assets.py | 1 - .../_core/definitions/decorators/asset_decorator.py | 2 -- .../dagster/dagster/_core/definitions/external_asset.py | 3 +-- .../dagster/dagster/_core/definitions/input.py | 5 ++--- .../dagster/dagster/_core/definitions/run_request.py | 5 +---- .../dagster/dagster/_core/instance/__init__.py | 3 +-- .../dagster/dagster/_core/storage/dagster_run.py | 3 +-- 14 files changed, 17 insertions(+), 36 deletions(-) diff --git a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/last_update.py b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/last_update.py index f562c82b482c0..879dbee86ac91 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/last_update.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/last_update.py @@ -2,7 +2,7 @@ from typing import Any, Dict, Iterable, Optional, Sequence, Union, cast from dagster import _check as check -from dagster._annotations import experimental +from dagster._annotations import beta from dagster._core.definitions.asset_check_factories.utils import ( DEADLINE_CRON_PARAM_KEY, DEFAULT_FRESHNESS_SEVERITY, @@ -40,7 +40,7 @@ ) -@experimental +@beta def build_last_update_freshness_checks( *, assets: Sequence[Union[CoercibleToAssetKey, AssetsDefinition, SourceAsset]], diff --git a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/sensor.py b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/sensor.py index 34bb66266296f..252faef737784 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/sensor.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/sensor.py @@ -2,7 +2,7 @@ from typing import Iterator, Optional, Sequence, Tuple, Union, cast from dagster import _check as check -from dagster._annotations import experimental +from dagster._annotations import beta from dagster._core.definitions.asset_check_factories.utils import ( FRESH_UNTIL_METADATA_KEY, ensure_no_duplicate_asset_checks, @@ -33,7 +33,7 @@ """ -@experimental +@beta def build_sensor_for_freshness_checks( *, freshness_checks: Sequence[AssetChecksDefinition], diff --git a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/time_partition.py b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/time_partition.py index db751418f09c0..3058294f203dc 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/time_partition.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/freshness_checks/time_partition.py @@ -1,7 +1,7 @@ from typing import Any, Dict, Iterable, Sequence, Union from dagster import _check as check -from dagster._annotations import experimental +from dagster._annotations import beta from dagster._core.definitions.asset_check_factories.utils import ( DEADLINE_CRON_PARAM_KEY, DEFAULT_FRESHNESS_SEVERITY, @@ -37,7 +37,7 @@ ) -@experimental +@beta def build_time_partition_freshness_checks( *, assets: Sequence[Union[SourceAsset, CoercibleToAssetKey, AssetsDefinition]], diff --git a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/metadata_bounds_checks.py b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/metadata_bounds_checks.py index 8db5e3a737a4d..2af23a6192784 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/metadata_bounds_checks.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/metadata_bounds_checks.py @@ -2,7 +2,7 @@ from typing import Optional, Sequence, Tuple, Union, cast import dagster._check as check -from dagster._annotations import experimental +from dagster._annotations import beta from dagster._core.definitions.asset_check_factories.utils import ( assets_to_keys, build_multi_asset_check, @@ -21,7 +21,7 @@ from dagster._core.instance import DagsterInstance -@experimental +@beta def build_metadata_bounds_checks( *, assets: Sequence[Union[CoercibleToAssetKey, AssetsDefinition, SourceAsset]], diff --git a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/schema_change_checks.py b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/schema_change_checks.py index 23a88cb655818..0ab24d822e765 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_check_factories/schema_change_checks.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_check_factories/schema_change_checks.py @@ -2,7 +2,7 @@ from pydantic import BaseModel -from dagster._annotations import experimental +from dagster._annotations import beta from dagster._core.definitions.asset_check_factories.utils import build_multi_asset_check from dagster._core.definitions.asset_check_spec import ( AssetCheckKey, @@ -17,7 +17,7 @@ from dagster._core.instance import DagsterInstance -@experimental +@beta def build_column_schema_change_checks( *, assets: Sequence[Union[CoercibleToAssetKey, AssetsDefinition, SourceAsset]], diff --git a/python_modules/dagster/dagster/_core/definitions/asset_out.py b/python_modules/dagster/dagster/_core/definitions/asset_out.py index f563344e073eb..dc61ff89c289c 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_out.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_out.py @@ -1,12 +1,7 @@ from typing import Any, Mapping, Optional, Sequence, Type, Union import dagster._check as check -from dagster._annotations import ( - experimental_param, - hidden_param, - only_allow_hidden_params_in_kwargs, - public, -) +from dagster._annotations import hidden_param, only_allow_hidden_params_in_kwargs, public from dagster._core.definitions.asset_dep import AssetDep from dagster._core.definitions.asset_spec import AssetSpec from dagster._core.definitions.auto_materialize_policy import AutoMaterializePolicy @@ -35,8 +30,6 @@ EMPTY_ASSET_KEY_SENTINEL = AssetKey([]) -@experimental_param(param="owners") -@experimental_param(param="tags") @hidden_param( param="freshness_policy", breaking_version="1.10.0", diff --git a/python_modules/dagster/dagster/_core/definitions/asset_spec.py b/python_modules/dagster/dagster/_core/definitions/asset_spec.py index b2e52fe8bf5d9..8ad7411945ce1 100644 --- a/python_modules/dagster/dagster/_core/definitions/asset_spec.py +++ b/python_modules/dagster/dagster/_core/definitions/asset_spec.py @@ -18,7 +18,6 @@ import dagster._check as check from dagster._annotations import ( PublicAttr, - experimental_param, hidden_param, only_allow_hidden_params_in_kwargs, public, @@ -96,7 +95,6 @@ def validate_kind_tags(kinds: Optional[AbstractSet[str]]) -> None: raise DagsterInvalidDefinitionError("Assets can have at most three kinds currently.") -@experimental_param(param="owners") @hidden_param( param="freshness_policy", breaking_version="1.10.0", diff --git a/python_modules/dagster/dagster/_core/definitions/assets.py b/python_modules/dagster/dagster/_core/definitions/assets.py index d2c7aec174c21..11893a684f360 100644 --- a/python_modules/dagster/dagster/_core/definitions/assets.py +++ b/python_modules/dagster/dagster/_core/definitions/assets.py @@ -119,7 +119,6 @@ class AssetsDefinition(ResourceAddable, IHasInternalInit): _specs_by_key: Mapping[AssetKey, AssetSpec] _computation: Optional[AssetGraphComputation] - @experimental_param(param="specs") @experimental_param(param="execution_type") def __init__( self, diff --git a/python_modules/dagster/dagster/_core/definitions/decorators/asset_decorator.py b/python_modules/dagster/dagster/_core/definitions/decorators/asset_decorator.py index 4f53f0668b03b..8bee72971b227 100644 --- a/python_modules/dagster/dagster/_core/definitions/decorators/asset_decorator.py +++ b/python_modules/dagster/dagster/_core/definitions/decorators/asset_decorator.py @@ -134,7 +134,6 @@ def _validate_hidden_non_argument_dep_param( @experimental_param(param="resource_defs") @experimental_param(param="io_manager_def") @experimental_param(param="backfill_policy") -@experimental_param(param="owners") @hidden_param( param="non_argument_deps", breaking_version="2.0.0", @@ -736,7 +735,6 @@ def graph_asset( ) -> Callable[[Callable[..., Any]], AssetsDefinition]: ... -@experimental_param(param="owners") @hidden_param( param="freshness_policy", breaking_version="1.10.0", diff --git a/python_modules/dagster/dagster/_core/definitions/external_asset.py b/python_modules/dagster/dagster/_core/definitions/external_asset.py index ef42bee63e384..702c65db16207 100644 --- a/python_modules/dagster/dagster/_core/definitions/external_asset.py +++ b/python_modules/dagster/dagster/_core/definitions/external_asset.py @@ -1,7 +1,7 @@ from typing import List, Sequence from dagster import _check as check -from dagster._annotations import deprecated, experimental +from dagster._annotations import deprecated from dagster._core.definitions.asset_spec import ( SYSTEM_METADATA_KEY_AUTO_OBSERVE_INTERVAL_MINUTES, SYSTEM_METADATA_KEY_IO_MANAGER_KEY, @@ -23,7 +23,6 @@ def external_asset_from_spec(spec: AssetSpec) -> AssetsDefinition: @deprecated(breaking_version="1.9.0", additional_warn_text="Directly use the AssetSpecs instead.") -@experimental def external_assets_from_specs(specs: Sequence[AssetSpec]) -> List[AssetsDefinition]: """Create an external assets definition from a sequence of asset specs. diff --git a/python_modules/dagster/dagster/_core/definitions/input.py b/python_modules/dagster/dagster/_core/definitions/input.py index 72c22ce2b7cc9..a6e21f3d2e93a 100644 --- a/python_modules/dagster/dagster/_core/definitions/input.py +++ b/python_modules/dagster/dagster/_core/definitions/input.py @@ -14,7 +14,7 @@ ) import dagster._check as check -from dagster._annotations import PublicAttr, deprecated_param, experimental_param +from dagster._annotations import PublicAttr, deprecated_param, superseded from dagster._core.definitions.events import AssetKey from dagster._core.definitions.inference import InferredInputProps from dagster._core.definitions.metadata import ( @@ -59,8 +59,7 @@ def _check_default_value(input_name: str, dagster_type: DagsterType, default_val return default_value # type: ignore # (pyright bug) -@experimental_param(param="asset_key") -@experimental_param(param="asset_partitions") +@superseded(additional_warn_text="Use `In` instead", emit_runtime_warning=False) class InputDefinition: """Defines an argument to an op's compute function. diff --git a/python_modules/dagster/dagster/_core/definitions/run_request.py b/python_modules/dagster/dagster/_core/definitions/run_request.py index 6ddfc75def35c..41d88efc53604 100644 --- a/python_modules/dagster/dagster/_core/definitions/run_request.py +++ b/python_modules/dagster/dagster/_core/definitions/run_request.py @@ -16,7 +16,7 @@ ) import dagster._check as check -from dagster._annotations import PublicAttr, experimental_param +from dagster._annotations import PublicAttr from dagster._core.definitions.asset_check_evaluation import AssetCheckEvaluation from dagster._core.definitions.asset_check_spec import AssetCheckKey from dagster._core.definitions.asset_graph_subset import AssetGraphSubset @@ -354,9 +354,6 @@ def __new__( ) -@experimental_param( - param="asset_events", additional_warn_text="Runless asset events are experimental" -) class SensorResult( NamedTuple( "_SensorResult", diff --git a/python_modules/dagster/dagster/_core/instance/__init__.py b/python_modules/dagster/dagster/_core/instance/__init__.py index 92c177d1d97ce..0f2b4e457b986 100644 --- a/python_modules/dagster/dagster/_core/instance/__init__.py +++ b/python_modules/dagster/dagster/_core/instance/__init__.py @@ -32,7 +32,7 @@ from typing_extensions import Protocol, Self, TypeAlias, TypeVar, runtime_checkable import dagster._check as check -from dagster._annotations import deprecated, experimental, public +from dagster._annotations import deprecated, public from dagster._core.definitions.asset_check_evaluation import ( AssetCheckEvaluation, AssetCheckEvaluationPlanned, @@ -3261,7 +3261,6 @@ def get_latest_materialization_code_versions( return result - @experimental @public def report_runless_asset_event( self, diff --git a/python_modules/dagster/dagster/_core/storage/dagster_run.py b/python_modules/dagster/dagster/_core/storage/dagster_run.py index 44a9217b75d46..7878fc51c2337 100644 --- a/python_modules/dagster/dagster/_core/storage/dagster_run.py +++ b/python_modules/dagster/dagster/_core/storage/dagster_run.py @@ -19,7 +19,7 @@ from typing_extensions import Self import dagster._check as check -from dagster._annotations import PublicAttr, experimental_param, public +from dagster._annotations import PublicAttr, public from dagster._core.definitions.asset_check_spec import AssetCheckKey from dagster._core.definitions.events import AssetKey from dagster._core.loader import LoadableBy, LoadingContext @@ -615,7 +615,6 @@ class RunsFilter(IHaveNew): created_before: Optional[datetime] exclude_subruns: Optional[bool] - @experimental_param(param="exclude_subruns") def __new__( cls, run_ids: Optional[Sequence[str]] = None,