-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
[pythonic resources] Improve nested resource evaluation logic #14807
Conversation
ddceb2c
to
68ad4e6
Compare
Deploy preview for dagit-storybook ready! ✅ Preview Built with commit 68ad4e6. |
Deploy preview for dagit-core-storybook ready! ✅ Preview Built with commit 929c237. |
It would be helpful if you included examples in the PR summary that illustrate the behavior change, especially since you are moving around the tests (instead of doing it in place in which case one could see behavior change as a diff itself) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mostly about documentation. Would love to see tests changed in place so that we can see behavior changes in action, and put in example in the PR summary.
return ( | ||
{ | ||
resource_key: wrap_resource_for_execution(resource) | ||
for resource_key, resource in resources.items() | ||
} | ||
if resources | ||
else {} | ||
) | ||
|
||
|
||
def wrap_resource_for_execution(resource: Any) -> ResourceDefinition: | ||
from dagster._config.pythonic_config import ConfigurableResourceFactory, PartialResource | ||
|
||
resources = check.opt_mapping_param(resources, "resources", key_type=str) | ||
resource_defs = {} | ||
# Wrap instantiated resource values in a resource definition. | ||
# If an instantiated IO manager is provided, wrap it in an IO manager definition. | ||
for resource_key, resource in resources.items(): | ||
# Wrap instantiated resource values in a resource definition. | ||
# If an instantiated IO manager is provided, wrap it in an IO manager definition. | ||
if isinstance(resource, (ConfigurableResourceFactory, PartialResource)): | ||
resource_defs[resource_key] = resource.get_resource_definition() | ||
elif isinstance(resource, ResourceDefinition): | ||
resource_defs[resource_key] = resource | ||
elif isinstance(resource, IOManager): | ||
resource_defs[resource_key] = IOManagerDefinition.hardcoded_io_manager(resource) | ||
else: | ||
resource_defs[resource_key] = ResourceDefinition.hardcoded_resource(resource) | ||
|
||
return resource_defs | ||
if isinstance(resource, (ConfigurableResourceFactory, PartialResource)): | ||
return resource.get_resource_definition() | ||
elif isinstance(resource, ResourceDefinition): | ||
return resource | ||
elif isinstance(resource, IOManager): | ||
return IOManagerDefinition.hardcoded_io_manager(resource) | ||
else: | ||
return ResourceDefinition.hardcoded_resource(resource) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is this a behavior change or a refactor?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Refactor, so that we're able to wrap just a single resource in some cases.
The existing unit tests weren't modified, just moved to the new file - the main behavior changes are highlighted in new tests in the Updated the PR description with an example - this is the case that #14751 ran into, since it was relying on |
68ad4e6
to
929c237
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great thanks
Summary
This PR attempts to address a couple shortcomings with the Pythonic resource system which are exposed in #14751.
First, the logic to determine whether a field on a resource represents a nested resource or a config field is not a good heuristic currently. Right now, the check only assesses whether the value is a resource type - but this fails in the case that a user wants to provide a raw value (ie an instance of
IOManager
). This PR updates this check to inspect the annotation on the field, and treat it as a resource only if the annotation indicates as much.Second, the initialization logic for nested resources (
coerce_to_resource
) doesn't properly handle raw values such as a plainIOManager
. This PR updates the logic incoerce_to_resource
to call out towrap_resources_for_execution
, which can successfully deal with these cases.Example
The following resource previously would not accept a raw
IOManager
as input, only a resource which produces one:The new code will coerce
MyIOManager
to a resource by wrapping it, since it is annotated as aResourceDependency
. This gives the user more flexibility when specifying resource-resource dependencies to input raw values or mocks.Test Plan
Existing unit tests succeed. New unit tests of nesting behavior with raw values (such as an IOManager).