-
Notifications
You must be signed in to change notification settings - Fork 77
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
Custom enumerators #944
Custom enumerators #944
Conversation
def enumerator_builder(cursor:) | ||
collection = self.collection | ||
|
||
job_iteration_builder = JobIteration::EnumeratorBuilder.new(nil) |
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.
It's a bit icky to pass in nil
here - it's for the job argument.
@job
is only referenced by EnumeratorBuilder#build_throttle_enumerator
, which isn't called here, so there's no immediate issue with it being nil
.
Alternatively, job
could be provided as an additional argument to enumerator_builder
, but leaking the job
instance into the Task
interface feels worse than passing in nil
.
I have signed the CLA! |
3a9a44c
to
fb0033e
Compare
fb0033e
to
f1ba5f5
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.
This makes sense to me. The API seems straightforward and the example in the README is clear 👍 Could we add @sambostock as a co-author since some of his original contributions were ported over to this PR?
cc @Shopify/rails for review on this please.
Please squash your commits and let's give Sam co-author please. Thank you! |
Co-authored-by: Sam Bostock <[email protected]> Co-authored-by: Gannon McGibbon <[email protected]>
4127af5
to
c0f8220
Compare
Done! Thanks for the feedback and reviews everyone. |
This is based on the work in #326 and the design suggested by @adrianna-chang-shopify in this comment.
It allows tasks to define their own custom enumerators, in order to support use cases like iteration over external API resources, or alternative database querying strategies.
It does this by exposing an overridable
enumerator_builder
method onTask
, whose default implementation is the existingcollection
type inspection logic.Fixes #207