From 545121b124bb5df6d3dc8f2df912e16b953b3273 Mon Sep 17 00:00:00 2001 From: Pete Hunt Date: Thu, 22 Aug 2024 15:27:44 +0000 Subject: [PATCH 01/10] Metadata docs --- docs/docs-beta/.gitignore | 2 +- docs/docs-beta/README.md | 6 + .../metadata/custom-local-references.py | 29 +++ .../metadata/definition-metadata.py | 18 ++ .../guides/data-modeling/metadata/kinds.py | 12 ++ .../data-modeling/metadata/oss-references.py | 36 ++++ .../guides/data-modeling/metadata/owners.py | 12 ++ .../data-modeling/metadata/plus-references.py | 24 +++ .../metadata/python-local-references.py | 15 ++ .../metadata/runtime-metadata.py | 11 ++ .../metadata/table-column-lineage-metadata.py | 43 +++++ .../metadata/table-schema-metadata.py | 49 +++++ .../guides/data-modeling/metadata/tags.py | 12 ++ .../adding-metadata-to-assets.md | 5 - .../docs/guides/data-modeling/metadata.md | 169 +++++++++++++++++- 15 files changed, 435 insertions(+), 8 deletions(-) create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/custom-local-references.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/definition-metadata.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/kinds.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/oss-references.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/owners.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/plus-references.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/python-local-references.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/runtime-metadata.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-column-lineage-metadata.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-schema-metadata.py create mode 100644 docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/tags.py delete mode 100644 docs/docs-beta/docs/guides/data-modeling/adding-metadata-to-assets.md diff --git a/docs/docs-beta/.gitignore b/docs/docs-beta/.gitignore index 321c4baa18e93..9f6120b630aa5 100644 --- a/docs/docs-beta/.gitignore +++ b/docs/docs-beta/.gitignore @@ -21,7 +21,7 @@ yarn-error.log* *.sqlite .pnp.* -.yarn/* +.yarn !.yarn/patches !.yarn/plugins !.yarn/releases diff --git a/docs/docs-beta/README.md b/docs/docs-beta/README.md index 19c1114c411a5..db288a7d87f77 100644 --- a/docs/docs-beta/README.md +++ b/docs/docs-beta/README.md @@ -25,6 +25,12 @@ Install Vale with: brew install vale ``` +or + +```bash +pip install vale +``` + --- ## Overview of the docs diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/custom-local-references.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/custom-local-references.py new file mode 100644 index 0000000000000..4779e977a9795 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/custom-local-references.py @@ -0,0 +1,29 @@ +from dagster import ( + CodeReferencesMetadataValue, + Definitions, + LocalFileCodeReference, + asset, + with_source_code_references, +) + + +@asset( + metadata={ + "dagster/code_references": CodeReferencesMetadataValue( + code_references=[ + LocalFileCodeReference( + file_path="/path/to/source.yaml", + # Label and line number are optional + line_number=1, + label="Model YAML", + ) + ] + ) + } +) +def my_asset_modeled_in_yaml(): ... + + +defs = Definitions( + assets=with_source_code_references([my_asset_modeled_in_yaml]) +) \ No newline at end of file diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/definition-metadata.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/definition-metadata.py new file mode 100644 index 0000000000000..d77b6d0dc16e4 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/definition-metadata.py @@ -0,0 +1,18 @@ +from dagster import asset, AssetSpec, MetadataValue + +# You can attach metadata via the `metadata` argument on the `@asset` decorator. +@asset(metadata={ + "link_to_docs": MetadataValue.url("https://..."), + "snippet": MetadataValue.md("# Embedded markdown\n...") +}) +def my_asset(): + ... + +# You can also use `metadata` with `AssetSpec` +my_external_asset = AssetSpec( + "my_external_asset", + metadata={ + "link_to_docs": MetadataValue.url("https://..."), + "snippet": MetadataValue.md("# Embedded markdown\n...") + } +) diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/kinds.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/kinds.py new file mode 100644 index 0000000000000..e0d262b1d4dfe --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/kinds.py @@ -0,0 +1,12 @@ +from dagster import asset, AssetSpec + +# You can attach kinds via the `kinds` argument on the `@asset` decorator. +@asset(kinds=["snowflake", "dbt"]) +def my_asset(): + ... + +# You can also use `kinds` with `AssetSpec` +my_external_asset = AssetSpec( + "my_external_asset", + kinds=["snowflake", "dbt"] +) diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/oss-references.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/oss-references.py new file mode 100644 index 0000000000000..95a0db158e794 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/oss-references.py @@ -0,0 +1,36 @@ +import os +from pathlib import Path + +from dagster import ( + AnchorBasedFilePathMapping, + Definitions, + asset, + link_code_references_to_git, + with_source_code_references, +) + + +@asset +def my_asset(): ... + + +@asset +def another_asset(): ... + + +assets = with_source_code_references([my_asset, another_asset]) + +defs = Definitions( + assets=link_code_references_to_git( + assets_defs=assets, + git_url="https://github.com/dagster-io/dagster", + git_branch="main", + file_path_mapping=AnchorBasedFilePathMapping( + local_file_anchor=Path(__file__), + file_anchor_path_in_repository="src/repo.py", + ), + ) + # only link to github in production. link locally otherwise + if bool(os.getenv("IS_PRODUCTION")) + else assets +) \ No newline at end of file diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/owners.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/owners.py new file mode 100644 index 0000000000000..e296c61dae280 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/owners.py @@ -0,0 +1,12 @@ +from dagster import asset, AssetSpec + +# You can attach owners via the `owners` argument on the `@asset` decorator. +@asset(owners=["richard.hendricks@hooli.com", "team:data-eng"]) +def my_asset(): + ... + +# You can also use `owners` with `AssetSpec` +my_external_asset = AssetSpec( + "my_external_asset", + owners=["bighead@hooli.com", "team:roof", "team:corpdev"] +) diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/plus-references.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/plus-references.py new file mode 100644 index 0000000000000..d41d6f3eeb1bb --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/plus-references.py @@ -0,0 +1,24 @@ +from dagster_cloud.metadata.source_code import link_code_references_to_git_if_cloud + +from dagster import ( + Definitions, + asset, + with_source_code_references, +) + + +@asset +def my_asset(): ... + + +@asset +def another_asset(): ... + + +defs = Definitions( + assets=link_code_references_to_git_if_cloud( + assets_defs=with_source_code_references([my_asset, another_asset]), + # This function also supports customizable path mapping, but usually + # the defaults are fine. + ) +) \ No newline at end of file diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/python-local-references.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/python-local-references.py new file mode 100644 index 0000000000000..5d2047cdf1aac --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/python-local-references.py @@ -0,0 +1,15 @@ +from dagster import Definitions, asset, with_source_code_references + + +@asset +def my_asset(): ... + + +@asset +def another_asset(): ... + + +defs = Definitions( + # with_source_code_references() automatically attaches the proper metadata + assets=with_source_code_references([my_asset, another_asset]) +) \ No newline at end of file diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/runtime-metadata.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/runtime-metadata.py new file mode 100644 index 0000000000000..8ef9c9ba0b519 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/runtime-metadata.py @@ -0,0 +1,11 @@ +from dagster import asset, MetadataValue, MaterializeResult + +@asset +def my_asset(): + # Asset logic goes here + return MaterializeResult( + metadata={ + # file_size_kb will be rendered as a time series + "file_size_kb": MetadataValue.int(...) + } + ) diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-column-lineage-metadata.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-column-lineage-metadata.py new file mode 100644 index 0000000000000..ac94ffba9403b --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-column-lineage-metadata.py @@ -0,0 +1,43 @@ +from dagster import ( + AssetKey, + MaterializeResult, + TableColumnDep, + TableColumnLineage, + asset, +) + + +@asset(deps=["source_bar", "source_baz"]) +def my_asset(): + # The following TableColumnLineage models 3 tables: + # source_bar, source_baz, and my_asset + # With the following column dependencies: + # - my_asset.new_column_foo depends on: + # - source_bar.column_bar + # - source_baz.column_baz + # - my_asset.new_column_qux depends on: + # - source_bar.column_quuz + return MaterializeResult( + metadata={ + "dagster/column_lineage": TableColumnLineage( + deps_by_column={ + "new_column_foo": [ + TableColumnDep( + asset_key=AssetKey("source_bar"), + column_name="column_bar", + ), + TableColumnDep( + asset_key=AssetKey("source_baz"), + column_name="column_baz", + ), + ], + "new_column_qux": [ + TableColumnDep( + asset_key=AssetKey("source_bar"), + column_name="column_quuz", + ), + ], + } + ) + } + ) \ No newline at end of file diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-schema-metadata.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-schema-metadata.py new file mode 100644 index 0000000000000..40915e56bd6c8 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-schema-metadata.py @@ -0,0 +1,49 @@ +from dagster import ( + MaterializeResult, + TableColumn, + TableSchema, + asset, +) + + +# Definition-time metadata +# Here, we know the schema of the asset, so we can attach it to the asset decorator +@asset( + deps=["source_bar", "source_baz"], + metadata={ + "dagster/column_schema": TableSchema( + columns=[ + TableColumn( + "name", + "string", + description="The name of the person", + ), + TableColumn( + "age", + "int", + description="The age of the person", + ), + ] + ) + }, +) +def my_asset(): ... + + +# Runtime metadata +# Here, the schema isn't known until the asset is materialized +@asset(deps=["source_bar", "source_baz"]) +def my_other_asset(): + column_names = ... + column_types = ... + + columns = [ + TableColumn(name, column_type) + for name, column_type in zip(column_names, column_types) + ] + + return MaterializeResult( + metadata={ + "dagster/column_schema": TableSchema(columns=columns) + } + ) \ No newline at end of file diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/tags.py b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/tags.py new file mode 100644 index 0000000000000..f245caed25885 --- /dev/null +++ b/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/tags.py @@ -0,0 +1,12 @@ +from dagster import asset, AssetSpec + +# You can attach tags via the `tags` argument on the `@asset` decorator. +@asset(tags={"domain": "marketing", "pii": "true"}) +def my_asset(): + ... + +# You can also use `tags` with `AssetSpec` +my_external_asset = AssetSpec( + "my_external_asset", + tags={"domain": "legal", "sensitive": ""} +) diff --git a/docs/docs-beta/docs/guides/data-modeling/adding-metadata-to-assets.md b/docs/docs-beta/docs/guides/data-modeling/adding-metadata-to-assets.md deleted file mode 100644 index a8a913d3f4e7e..0000000000000 --- a/docs/docs-beta/docs/guides/data-modeling/adding-metadata-to-assets.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -title: "Add metadata to assets" -sidebar_position: 40 -sidebar_label: "Add metadata" ---- diff --git a/docs/docs-beta/docs/guides/data-modeling/metadata.md b/docs/docs-beta/docs/guides/data-modeling/metadata.md index cb3db06866406..9b3c0e9f31fe2 100644 --- a/docs/docs-beta/docs/guides/data-modeling/metadata.md +++ b/docs/docs-beta/docs/guides/data-modeling/metadata.md @@ -1,6 +1,171 @@ --- -title: "Adding metadata and tags to assets" -description: "Learn how to add metadata and tags to assets to improve observability in Dagster" +title: "Adding tags and metadata to assets" +description: "Learn how to add tags and metadata to assets to improve observability in Dagster" sidebar_position: 40 sidebar_label: "Enriching assets with metadata" --- + +Assets feature prominently in the Dagster UI. It is often helpful to attach information to assets to understand where they are stored, what they contain, and how they should be organized. + +In Dagster, you can attach ownership information, organize your assets with tags, attach rich, complex information with metadata, and link your assets with their source code. + +## What you'll learn + +- How to add owners to your assets +- How to use tags to organize assets +- How to attach complex information to an asset using metadata +- How to link your assets with their source code + +--- + +
+ Prerequisites + +To follow the steps in this guide, you'll need: + +- A basic understanding of Dagster and assets. See the [Quick Start](/tutorial/quick-start) tutorial for an overview. +
+ +--- + +## Adding owners to your assets + +In a large organization, it's important to know who is responsible for a given data asset. With `owners` it's straightforward to add individuals and teams as owners for your asset: + + + +`owners` must either be an email address, or a team name prefixed by `team:`. + +> With Dagster+ Pro, you can create asset-based alerts that will automatically notify an asset's owners when triggered. Refer to the [Dagster+ alert documentation](/dagster-plus/deployment/alerts) for more information. + + + +## Choosing between tags or metadata for custom information + +In Dagster, you can attach custom information to assets in two ways: **tags** and **metadata**. + +**Tags** are a simple way to organize assets in Dagster. You can attach several tags to an asset when it is defined, and they will appear in the UI. You can also use tags to search and filter for assets in the [asset catalog](/#todo). They are structured as key-value pairs of strings. + +Here's an example of some tags one might apply to an asset: +```python +{"domain": "marketing", "pii": "true"} +``` + +**Metadata** allows you to attach rich information to the asset, like a Markdown description, a table schema, or a time series. Metadata is more flexible than tags, as it can store more complex information. Metadata can be attached to an asset at definition time (i.e. when the code is first imported) or at runtime (every time an asset is materialized). + +Here's an example of some metadata one might apply to an asset: +```python +{ + "link_to_docs": MetadataValue.url("https://..."), + "snippet": MetadataValue.md("# Embedded markdown\n..."), + "file_size_kb": MetadataValue.int(1024), +} +``` + +## Attaching tags to an asset + +Like `owners`, just pass a dictionary of tags to the `tags` argument when defining an asset: + + + +Keep in mind that tags must contain only strings as keys and values. Additionally, the Dagster UI will render tags with the empty string as a "label" rather than a key-value pair. + +## Adding custom icons using "kind" tags + +`kinds` are special tags that can be used to customize the appearance of assets in the UI by attaching a custom label and icon. + + + +The list of available icons is always growing and is available in the [Dagster UI source code](https://github.com/dagster-io/dagster/blob/master/js_modules/dagster-ui/packages/ui-core/src/graph/OpTags.tsx). + +If you add a `kind` that does not have an associated icon, it will simply be rendered as a textual label. + +## Attaching metadata to an asset at definition time + +Attaching metadata at definition time is quite similar to how you attach tags. + + + +To learn more about the different types of metadata you can attach, see the [`MetadataValue`](#/todo) API docs. + +Some metadata keys will be given special treatment in the Dagster UI. See the [Standard metadata types](#standard-metadata-types) section for more information. + +## Attaching metadata to an asset at runtime + +Metadata becomes very powerful when it is attached when an asset is materialized. This allows you to update metadata when information about an asset changes and track historical metadata such as execution time and row counts as a time series. + + + +Any numerical metadata will be treated as a time series in the Dagster UI. + +## Standard metadata types + +Some metadata keys will be given special treatment in the Dagster UI. + +| Key | Description | +|------------------------------|---------------------------------------------------------------------------------------------------------------| +| `dagster/uri` | **Type:** `str`

The URI for the asset, e.g. "s3://my_bucket/my_object" | +| `dagster/column_schema` | **Type:** [`TableSchema`](#/todo)

For an asset that's a table, the schema of the columns in the table. Refer to the [Table and column metadata](#table-and-column-metadata) secton for details. | +| `dagster/column_lineage` | **Type:** [`TableColumnLineage`](#/todo)

For an asset that's a table, the lineage of column inputs to column outputs for the table. Refer to the [Table and column metadata](#table-and-column-metadata) secton for details. | +| `dagster/row_count` | **Type:** `int`

For an asset that's a table, the number of rows in the table. Refer to the Table metadata documentation for details. | +| `dagster/partition_row_count` | **Type:** `int`

For a partition of an asset that's a table, the number of rows in the partition. | +| `dagster/relation_identifier` | **Type:** `str`

A unique identifier for the table/view, typically fully qualified. For example, my_database.my_schema.my_table | +| `dagster/code_references` | **Type:** [`CodeReferencesMetadataValue`](#/todo)

A list of code references for the asset, such as file locations or references to Github URLs. Refer to the [Linking your assets with their source code](#linking-your-assets-with-their-source-code) section for details. Should only be provided in definition-level metadata, not materialization metadata. | + + +## Table and column metadata + +Two of the most powerful metadata types are [`TableSchema`](#/todo) and [`TableColumnLineage`](#/todo). These metadata types allow stakeholders to view the schema of a table right within Dagster, and, in Dagster+, navigate the [asset catalog](/#todo) via the column lineage. + +### Table schema metadata + +Here's a quick example of how to attach this metadata at both definition time and runtime: + + + +Note that there are several data types and constraints available on [`TableColumn`](#/todo) objects. Refer to the API documentation for more information.) + +### Column lineage metadata + +> Many integrations such as [dbt](https://docs.dagster.io/integrations/dbt/reference) automatically attach this metadata out-of-the-box. + +Column lineage metadata is a powerful way to track how columns in a table are derived from other columns. Here is how you can manually attach this metadata: + + + +> Dagster+ provides rich visualization and navigation of column lineage in the asset catalog. Refer to the [Dagster+ documentation](/dagster-plus) for more information. + + +## Linking your assets with their source code + +> This feature is considered experimental and is under active development. This guide will be updated as we roll out new features. + +Attaching code reference metadata to your Dagster asset definitions allows you to easily view those assets' source code from the Dagster UI both in local development and in production. + +> Many integrations such as [dbt](https://docs.dagster.io/integrations/dbt/reference#attaching-code-reference-metadata) support this capability out of the box. Refer to the integration documentation for more information. + +### Attaching Python code references for local development + +Dagster can automatically attach code references to your assets during local development with one line of code. + + + +### Attaching custom code references for local development + +You can manually add the `dagster/code_references` metadata to your asset definitions to attach custom code references. This is useful when your asset's source code is not primarily in Python (e.g. when parsing a YAML config or integrating with another language). + + + +### Attaching code references in production (Dagster+) + +Dagster+ can automatically annotate your assets with code references to source control such as GitHub or GitLab. + + + +### Attaching code references in production (OSS) + +If you aren't using Dagster+, you can annotate your assets with code references to source control, but it requires a little more manual mapping. + + + +[`link_code_references_to_git`](#/todo) currently supports GitHub and GitLab repositories. It also supports customization of how file paths are mapped; see the [`AnchorBasedFilePathMapping`](#/todo) API docs for more information. \ No newline at end of file From b82654ea6b578ca97c6b98dc2a6fd8cfbe4ce90d Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 12:48:31 -0700 Subject: [PATCH 02/10] [docs-beta] Add snippets folder --- .../docs_beta_snippets_tests/conftest.py | 8 ++++++++ 1 file changed, 8 insertions(+) create mode 100644 examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py diff --git a/examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py b/examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py new file mode 100644 index 0000000000000..7ebf46e420c05 --- /dev/null +++ b/examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py @@ -0,0 +1,8 @@ +import pytest + +from dagster import file_relative_path + + +@pytest.fixture +def docs_snippets_folder(): + return file_relative_path(__file__, "../docs_beta_snippets/") From 8c41be4d4802dd5c1c7764f7c8508fb8ab692f87 Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 13:08:54 -0700 Subject: [PATCH 03/10] run prettier --- .../docs_beta_snippets_tests/conftest.py | 8 -------- 1 file changed, 8 deletions(-) delete mode 100644 examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py diff --git a/examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py b/examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py deleted file mode 100644 index 7ebf46e420c05..0000000000000 --- a/examples/docs_beta_snippets/docs_beta_snippets_tests/conftest.py +++ /dev/null @@ -1,8 +0,0 @@ -import pytest - -from dagster import file_relative_path - - -@pytest.fixture -def docs_snippets_folder(): - return file_relative_path(__file__, "../docs_beta_snippets/") From c24709b6a9a325f5bc9d95b1026be0df6f3aa28d Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 13:23:01 -0700 Subject: [PATCH 04/10] move snippets to correct folder --- .../guides/data-modeling/metadata/custom-local-references.py | 0 .../guides/data-modeling/metadata/definition-metadata.py | 0 .../docs_beta_snippets}/guides/data-modeling/metadata/kinds.py | 0 .../guides/data-modeling/metadata/oss-references.py | 0 .../docs_beta_snippets}/guides/data-modeling/metadata/owners.py | 0 .../guides/data-modeling/metadata/plus-references.py | 0 .../guides/data-modeling/metadata/python-local-references.py | 0 .../guides/data-modeling/metadata/runtime-metadata.py | 0 .../data-modeling/metadata/table-column-lineage-metadata.py | 0 .../guides/data-modeling/metadata/table-schema-metadata.py | 0 .../docs_beta_snippets}/guides/data-modeling/metadata/tags.py | 0 11 files changed, 0 insertions(+), 0 deletions(-) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/custom-local-references.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/definition-metadata.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/kinds.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/oss-references.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/owners.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/plus-references.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/python-local-references.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/runtime-metadata.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/table-column-lineage-metadata.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/table-schema-metadata.py (100%) rename {docs/docs-beta/docs/code_examples => examples/docs_beta_snippets/docs_beta_snippets}/guides/data-modeling/metadata/tags.py (100%) diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/custom-local-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/custom-local-references.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/custom-local-references.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/custom-local-references.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/definition-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/definition-metadata.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/definition-metadata.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/definition-metadata.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/kinds.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/kinds.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/kinds.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/kinds.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/oss-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/oss-references.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/oss-references.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/oss-references.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/owners.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/owners.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/owners.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/owners.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/plus-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/plus-references.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/plus-references.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/plus-references.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/python-local-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/python-local-references.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/python-local-references.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/python-local-references.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/runtime-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/runtime-metadata.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/runtime-metadata.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/runtime-metadata.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-column-lineage-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-column-lineage-metadata.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-column-lineage-metadata.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-column-lineage-metadata.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-schema-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-schema-metadata.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/table-schema-metadata.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-schema-metadata.py diff --git a/docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/tags.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/tags.py similarity index 100% rename from docs/docs-beta/docs/code_examples/guides/data-modeling/metadata/tags.py rename to examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/tags.py From ee3796cc09bcd5fa0a3c605ebb5e81e54df46bd7 Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 13:35:14 -0700 Subject: [PATCH 05/10] fix broken tox --- examples/docs_beta_snippets/tox.ini | 1 - 1 file changed, 1 deletion(-) diff --git a/examples/docs_beta_snippets/tox.ini b/examples/docs_beta_snippets/tox.ini index c4e1cdec1b696..38388b96e3100 100644 --- a/examples/docs_beta_snippets/tox.ini +++ b/examples/docs_beta_snippets/tox.ini @@ -12,7 +12,6 @@ install_command = uv pip install {opts} {packages} deps = source: -e ../../python_modules/dagster[test] source: -e ../../python_modules/dagster-pipes - pypi: dagster[test] -e ../../python_modules/dagster-graphql -e ../../python_modules/dagster-webserver -e ../../python_modules/libraries/dagster-duckdb-pandas From 5380a5d2d65c0d9a9ce906438c158fc141306a75 Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 14:51:02 -0700 Subject: [PATCH 06/10] [docs-beta] Add testable code snippets (#23836) This moves our beta docsite code examples into its own folder under `examples`. See instructions for how to run and test this. Local testing, buildkite. NOCHANGELOG --- examples/docs_beta_snippets/tox.ini | 1 + 1 file changed, 1 insertion(+) diff --git a/examples/docs_beta_snippets/tox.ini b/examples/docs_beta_snippets/tox.ini index 38388b96e3100..c4e1cdec1b696 100644 --- a/examples/docs_beta_snippets/tox.ini +++ b/examples/docs_beta_snippets/tox.ini @@ -12,6 +12,7 @@ install_command = uv pip install {opts} {packages} deps = source: -e ../../python_modules/dagster[test] source: -e ../../python_modules/dagster-pipes + pypi: dagster[test] -e ../../python_modules/dagster-graphql -e ../../python_modules/dagster-webserver -e ../../python_modules/libraries/dagster-duckdb-pandas From dbe46179a18fe4c8253e4c08abf75012c4c986b8 Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 15:45:25 -0700 Subject: [PATCH 07/10] ruff and remove kinds --- .../metadata/custom-local-references.py | 4 +--- .../metadata/definition-metadata.py | 21 +++++++++++-------- .../guides/data-modeling/metadata/kinds.py | 12 ----------- .../data-modeling/metadata/oss-references.py | 2 +- .../guides/data-modeling/metadata/owners.py | 10 ++++----- .../data-modeling/metadata/plus-references.py | 8 ++----- .../metadata/python-local-references.py | 2 +- .../metadata/runtime-metadata.py | 3 ++- .../metadata/table-column-lineage-metadata.py | 2 +- .../metadata/table-schema-metadata.py | 13 +++--------- .../guides/data-modeling/metadata/tags.py | 10 ++++----- 11 files changed, 33 insertions(+), 54 deletions(-) delete mode 100644 examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/kinds.py diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/custom-local-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/custom-local-references.py index 4779e977a9795..3efe88f0728e0 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/custom-local-references.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/custom-local-references.py @@ -24,6 +24,4 @@ def my_asset_modeled_in_yaml(): ... -defs = Definitions( - assets=with_source_code_references([my_asset_modeled_in_yaml]) -) \ No newline at end of file +defs = Definitions(assets=with_source_code_references([my_asset_modeled_in_yaml])) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/definition-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/definition-metadata.py index d77b6d0dc16e4..eee9e69d9684e 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/definition-metadata.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/definition-metadata.py @@ -1,18 +1,21 @@ -from dagster import asset, AssetSpec, MetadataValue +from dagster import AssetSpec, MetadataValue, asset + # You can attach metadata via the `metadata` argument on the `@asset` decorator. -@asset(metadata={ - "link_to_docs": MetadataValue.url("https://..."), - "snippet": MetadataValue.md("# Embedded markdown\n...") -}) -def my_asset(): - ... +@asset( + metadata={ + "link_to_docs": MetadataValue.url("https://..."), + "snippet": MetadataValue.md("# Embedded markdown\n..."), + } +) +def my_asset(): ... + # You can also use `metadata` with `AssetSpec` my_external_asset = AssetSpec( "my_external_asset", metadata={ "link_to_docs": MetadataValue.url("https://..."), - "snippet": MetadataValue.md("# Embedded markdown\n...") - } + "snippet": MetadataValue.md("# Embedded markdown\n..."), + }, ) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/kinds.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/kinds.py deleted file mode 100644 index e0d262b1d4dfe..0000000000000 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/kinds.py +++ /dev/null @@ -1,12 +0,0 @@ -from dagster import asset, AssetSpec - -# You can attach kinds via the `kinds` argument on the `@asset` decorator. -@asset(kinds=["snowflake", "dbt"]) -def my_asset(): - ... - -# You can also use `kinds` with `AssetSpec` -my_external_asset = AssetSpec( - "my_external_asset", - kinds=["snowflake", "dbt"] -) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/oss-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/oss-references.py index 95a0db158e794..d9ba57917da38 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/oss-references.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/oss-references.py @@ -33,4 +33,4 @@ def another_asset(): ... # only link to github in production. link locally otherwise if bool(os.getenv("IS_PRODUCTION")) else assets -) \ No newline at end of file +) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/owners.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/owners.py index e296c61dae280..0a7d5f3a4efb1 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/owners.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/owners.py @@ -1,12 +1,12 @@ -from dagster import asset, AssetSpec +from dagster import AssetSpec, asset + # You can attach owners via the `owners` argument on the `@asset` decorator. @asset(owners=["richard.hendricks@hooli.com", "team:data-eng"]) -def my_asset(): - ... +def my_asset(): ... + # You can also use `owners` with `AssetSpec` my_external_asset = AssetSpec( - "my_external_asset", - owners=["bighead@hooli.com", "team:roof", "team:corpdev"] + "my_external_asset", owners=["bighead@hooli.com", "team:roof", "team:corpdev"] ) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/plus-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/plus-references.py index d41d6f3eeb1bb..309f58e7ca0ee 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/plus-references.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/plus-references.py @@ -1,10 +1,6 @@ from dagster_cloud.metadata.source_code import link_code_references_to_git_if_cloud -from dagster import ( - Definitions, - asset, - with_source_code_references, -) +from dagster import Definitions, asset, with_source_code_references @asset @@ -21,4 +17,4 @@ def another_asset(): ... # This function also supports customizable path mapping, but usually # the defaults are fine. ) -) \ No newline at end of file +) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/python-local-references.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/python-local-references.py index 5d2047cdf1aac..a226637ddd086 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/python-local-references.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/python-local-references.py @@ -12,4 +12,4 @@ def another_asset(): ... defs = Definitions( # with_source_code_references() automatically attaches the proper metadata assets=with_source_code_references([my_asset, another_asset]) -) \ No newline at end of file +) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/runtime-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/runtime-metadata.py index 8ef9c9ba0b519..51ea34c4b8b4c 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/runtime-metadata.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/runtime-metadata.py @@ -1,4 +1,5 @@ -from dagster import asset, MetadataValue, MaterializeResult +from dagster import MaterializeResult, MetadataValue, asset + @asset def my_asset(): diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-column-lineage-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-column-lineage-metadata.py index ac94ffba9403b..97abdbbae4c03 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-column-lineage-metadata.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-column-lineage-metadata.py @@ -40,4 +40,4 @@ def my_asset(): } ) } - ) \ No newline at end of file + ) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-schema-metadata.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-schema-metadata.py index 40915e56bd6c8..b42aa49fbecaf 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-schema-metadata.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/table-schema-metadata.py @@ -1,9 +1,4 @@ -from dagster import ( - MaterializeResult, - TableColumn, - TableSchema, - asset, -) +from dagster import MaterializeResult, TableColumn, TableSchema, asset # Definition-time metadata @@ -43,7 +38,5 @@ def my_other_asset(): ] return MaterializeResult( - metadata={ - "dagster/column_schema": TableSchema(columns=columns) - } - ) \ No newline at end of file + metadata={"dagster/column_schema": TableSchema(columns=columns)} + ) diff --git a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/tags.py b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/tags.py index f245caed25885..036fe016e837e 100644 --- a/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/tags.py +++ b/examples/docs_beta_snippets/docs_beta_snippets/guides/data-modeling/metadata/tags.py @@ -1,12 +1,12 @@ -from dagster import asset, AssetSpec +from dagster import AssetSpec, asset + # You can attach tags via the `tags` argument on the `@asset` decorator. @asset(tags={"domain": "marketing", "pii": "true"}) -def my_asset(): - ... +def my_asset(): ... + # You can also use `tags` with `AssetSpec` my_external_asset = AssetSpec( - "my_external_asset", - tags={"domain": "legal", "sensitive": ""} + "my_external_asset", tags={"domain": "legal", "sensitive": ""} ) From 3a7bce4df317776174d4cedbbdceab992d49f1cd Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 15:49:04 -0700 Subject: [PATCH 08/10] remove kinds docs --- docs/docs-beta/docs/guides/data-modeling/metadata.md | 9 --------- 1 file changed, 9 deletions(-) diff --git a/docs/docs-beta/docs/guides/data-modeling/metadata.md b/docs/docs-beta/docs/guides/data-modeling/metadata.md index 9b3c0e9f31fe2..3422ad2665080 100644 --- a/docs/docs-beta/docs/guides/data-modeling/metadata.md +++ b/docs/docs-beta/docs/guides/data-modeling/metadata.md @@ -70,15 +70,6 @@ Like `owners`, just pass a dictionary of tags to the `tags` argument when defini Keep in mind that tags must contain only strings as keys and values. Additionally, the Dagster UI will render tags with the empty string as a "label" rather than a key-value pair. -## Adding custom icons using "kind" tags - -`kinds` are special tags that can be used to customize the appearance of assets in the UI by attaching a custom label and icon. - - - -The list of available icons is always growing and is available in the [Dagster UI source code](https://github.com/dagster-io/dagster/blob/master/js_modules/dagster-ui/packages/ui-core/src/graph/OpTags.tsx). - -If you add a `kind` that does not have an associated icon, it will simply be rendered as a textual label. ## Attaching metadata to an asset at definition time From 8d0809e29cc2bdf285e119e0acbf6ef44f881507 Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Thu, 22 Aug 2024 22:18:28 -0700 Subject: [PATCH 09/10] add to ignore pyright --- pyright/master/exclude.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/pyright/master/exclude.txt b/pyright/master/exclude.txt index 2b9e39f028595..3e08c585266bf 100644 --- a/pyright/master/exclude.txt +++ b/pyright/master/exclude.txt @@ -8,6 +8,7 @@ examples/project_fully_featured examples/assets_dbt_python examples/assets_modern_data_stack examples/assets_smoke_test +examples/docs_beta_snippets examples/project_analytics examples/project_dagster_university_start examples/project_du_dbt_starter From f33f51196a5779f1b1b00785993a67eb502391fd Mon Sep 17 00:00:00 2001 From: Pedram Navid <1045990+PedramNavid@users.noreply.github.com> Date: Fri, 23 Aug 2024 10:03:55 -0700 Subject: [PATCH 10/10] add todo page --- .../docs/guides/data-modeling/metadata.md | 16 ++++++++-------- docs/docs-beta/docs/todo.md | 0 2 files changed, 8 insertions(+), 8 deletions(-) create mode 100644 docs/docs-beta/docs/todo.md diff --git a/docs/docs-beta/docs/guides/data-modeling/metadata.md b/docs/docs-beta/docs/guides/data-modeling/metadata.md index 3422ad2665080..6c3d0555e38f1 100644 --- a/docs/docs-beta/docs/guides/data-modeling/metadata.md +++ b/docs/docs-beta/docs/guides/data-modeling/metadata.md @@ -44,7 +44,7 @@ In a large organization, it's important to know who is responsible for a given d In Dagster, you can attach custom information to assets in two ways: **tags** and **metadata**. -**Tags** are a simple way to organize assets in Dagster. You can attach several tags to an asset when it is defined, and they will appear in the UI. You can also use tags to search and filter for assets in the [asset catalog](/#todo). They are structured as key-value pairs of strings. +**Tags** are a simple way to organize assets in Dagster. You can attach several tags to an asset when it is defined, and they will appear in the UI. You can also use tags to search and filter for assets in the [asset catalog](/todo). They are structured as key-value pairs of strings. Here's an example of some tags one might apply to an asset: ```python @@ -77,7 +77,7 @@ Attaching metadata at definition time is quite similar to how you attach tags. -To learn more about the different types of metadata you can attach, see the [`MetadataValue`](#/todo) API docs. +To learn more about the different types of metadata you can attach, see the [`MetadataValue`](/todo) API docs. Some metadata keys will be given special treatment in the Dagster UI. See the [Standard metadata types](#standard-metadata-types) section for more information. @@ -96,17 +96,17 @@ Some metadata keys will be given special treatment in the Dagster UI. | Key | Description | |------------------------------|---------------------------------------------------------------------------------------------------------------| | `dagster/uri` | **Type:** `str`

The URI for the asset, e.g. "s3://my_bucket/my_object" | -| `dagster/column_schema` | **Type:** [`TableSchema`](#/todo)

For an asset that's a table, the schema of the columns in the table. Refer to the [Table and column metadata](#table-and-column-metadata) secton for details. | -| `dagster/column_lineage` | **Type:** [`TableColumnLineage`](#/todo)

For an asset that's a table, the lineage of column inputs to column outputs for the table. Refer to the [Table and column metadata](#table-and-column-metadata) secton for details. | +| `dagster/column_schema` | **Type:** [`TableSchema`](/todo)

For an asset that's a table, the schema of the columns in the table. Refer to the [Table and column metadata](#table-and-column-metadata) secton for details. | +| `dagster/column_lineage` | **Type:** [`TableColumnLineage`](/todo)

For an asset that's a table, the lineage of column inputs to column outputs for the table. Refer to the [Table and column metadata](#table-and-column-metadata) secton for details. | | `dagster/row_count` | **Type:** `int`

For an asset that's a table, the number of rows in the table. Refer to the Table metadata documentation for details. | | `dagster/partition_row_count` | **Type:** `int`

For a partition of an asset that's a table, the number of rows in the partition. | | `dagster/relation_identifier` | **Type:** `str`

A unique identifier for the table/view, typically fully qualified. For example, my_database.my_schema.my_table | -| `dagster/code_references` | **Type:** [`CodeReferencesMetadataValue`](#/todo)

A list of code references for the asset, such as file locations or references to Github URLs. Refer to the [Linking your assets with their source code](#linking-your-assets-with-their-source-code) section for details. Should only be provided in definition-level metadata, not materialization metadata. | +| `dagster/code_references` | **Type:** [`CodeReferencesMetadataValue`](/todo)

A list of code references for the asset, such as file locations or references to Github URLs. Refer to the [Linking your assets with their source code](#linking-your-assets-with-their-source-code) section for details. Should only be provided in definition-level metadata, not materialization metadata. | ## Table and column metadata -Two of the most powerful metadata types are [`TableSchema`](#/todo) and [`TableColumnLineage`](#/todo). These metadata types allow stakeholders to view the schema of a table right within Dagster, and, in Dagster+, navigate the [asset catalog](/#todo) via the column lineage. +Two of the most powerful metadata types are [`TableSchema`](/todo) and [`TableColumnLineage`](/todo). These metadata types allow stakeholders to view the schema of a table right within Dagster, and, in Dagster+, navigate the [asset catalog](/todo) via the column lineage. ### Table schema metadata @@ -114,7 +114,7 @@ Here's a quick example of how to attach this metadata at both definition time an -Note that there are several data types and constraints available on [`TableColumn`](#/todo) objects. Refer to the API documentation for more information.) +Note that there are several data types and constraints available on [`TableColumn`](/todo) objects. Refer to the API documentation for more information.) ### Column lineage metadata @@ -159,4 +159,4 @@ If you aren't using Dagster+, you can annotate your assets with code references -[`link_code_references_to_git`](#/todo) currently supports GitHub and GitLab repositories. It also supports customization of how file paths are mapped; see the [`AnchorBasedFilePathMapping`](#/todo) API docs for more information. \ No newline at end of file +[`link_code_references_to_git`](/todo) currently supports GitHub and GitLab repositories. It also supports customization of how file paths are mapped; see the [`AnchorBasedFilePathMapping`](/todo) API docs for more information. diff --git a/docs/docs-beta/docs/todo.md b/docs/docs-beta/docs/todo.md new file mode 100644 index 0000000000000..e69de29bb2d1d