Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[components] Refactor component load behavior #27181

Open
wants to merge 1 commit into
base: 01-16-_components_explicitly_pass_params
Choose a base branch
from

Conversation

OwenKephart
Copy link
Contributor

Summary & Motivation

This moves the load method onto the individual DeclNode classes, which simplifies the logic a bit and just generally is a bit better organized.

The impetus for this is cleaning up the house a bit in preparation for adding a PythonDeclNode

How I Tested These Changes

Changelog

NOCHANGELOG

Copy link
Contributor Author

OwenKephart commented Jan 16, 2025

@OwenKephart OwenKephart force-pushed the 01-16-_components_refactor_component_load_behavior branch from 977ee0c to 3c6e30f Compare January 16, 2025 23:16
Copy link
Member

@benpankow benpankow left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems reasonable to me

component_file_model=obj,
source_position_tree=parsed.source_position_tree,
)

def get_component_type(self, registry: ComponentTypeRegistry) -> type[Component]:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: get_ belies that this is doing some real work (parsing python files), maybe resolve_component_type?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

might be worth a brief docstr to explain that this does local lookup in addition to the expected registry lookup

@OwenKephart OwenKephart force-pushed the 01-16-_components_explicitly_pass_params branch from b402c39 to 339fe7a Compare January 22, 2025 23:04
@OwenKephart OwenKephart force-pushed the 01-16-_components_refactor_component_load_behavior branch from 3c6e30f to 8e92e27 Compare January 22, 2025 23:04
Copy link

github-actions bot commented Jan 22, 2025

Deploy preview for dagster-docs-beta ready!

Preview available at https://dagster-docs-beta-fnam8n3jl-elementl.vercel.app

Direct link to changed pages:

@OwenKephart OwenKephart force-pushed the 01-16-_components_refactor_component_load_behavior branch from 8e92e27 to 82497f2 Compare January 22, 2025 23:43
return MyNestedComponentSchema

@classmethod
def load(cls, params: MyComponentSchema, context: ComponentLoadContext) -> Self:
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The type hint for params should be MyNestedComponentSchema to match the schema type returned by get_schema(). This appears to be a copy/paste error from the class above.

Spotted by Graphite Reviewer

Is this helpful? React 👍 or 👎 to let us know.

@OwenKephart OwenKephart force-pushed the 01-16-_components_explicitly_pass_params branch from 339fe7a to 145aa32 Compare January 23, 2025 00:22
@OwenKephart OwenKephart force-pushed the 01-16-_components_refactor_component_load_behavior branch from 82497f2 to 5ee4d47 Compare January 23, 2025 00:22
@OwenKephart OwenKephart force-pushed the 01-16-_components_refactor_component_load_behavior branch from 5ee4d47 to fcca097 Compare January 23, 2025 01:06
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants