-
Notifications
You must be signed in to change notification settings - Fork 910
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
Hooks execution order is unclear when multiple hooks exists #2493
Comments
Do some testing to find out what's really going on here and decide if it can be fixed. If not, write it up in docs so at least users know it's expected behaviour. |
See also #2492 (the same user who raised the issue on Slack) |
Potentially useful:
|
@astrojuanlu I believe that's true - |
If I understand correctly, there are no guarantees about run order for plugin (entry points) hooks. That order can be influenced (but not forced) passing
pytest-dev/pluggy#64 (comment) (docs: https://pluggy.readthedocs.io/en/stable/index.html#call-time-order) I don't think it's properly documented upstream, but we could document it ourselves. |
https://kedro-org.slack.com/archives/C03RKP2LW64/p1685454486286959 Another question came up recently, maybe it's a strong enough signal that we should fix the docs. The thread also mention 2 issues that included some advance examples of creating stateful hooks. We should consider adding that too. |
Maybe we can close this because kedro-org/kedro-plugins#422 is merged. |
Indeed: getindata/kedro-azureml#79 Closing! Hope we can tackle #1718 soon |
Description
Short description of the problem here.
A user report this in https://kedro-org.slack.com/archives/C03RKP2LW64/p1680617722865809?thread_ts=1680605927.073699&cid=C03RKP2LW64
In this case, the user's hook is interfering with
kedro-telemetry
, we useafter_context_hook
,catalog = context.catalog
which collect some summary statistics about the project stats.Context
How has this bug affected you? What were you trying to accomplish?
It is confusing as the execution order is not linear, it's difficult to reason & debug once you have more than one hook.
We don't encourage hooks to communicate with each other, but they can via storing state in
self.xxx
, if it's not managed properly they can interfere with each other and cause obscure bug.If users need to have finer control the order of hooks, currently user can define it explicitly in
settings.py
, but this doesn't solve the problem completelyExpected Result
Tell us what should happen.
Normally you expected
after_context_created
hook is the earliest hook to be triggered.Actual Result
Tell us what happens instead.
When you have more than one hooks. In this case, this is what happened
after_context_created
triggered -> it create a catalog within the hookafter_catalog_created
is trigger for the 1st timeafter_context_created
triggeredafter_catalog_created
is trigger for the 2nd time.Your Environment
Include as many relevant details about the environment in which you experienced the bug:
pip show kedro
orkedro -V
): 0.18.7python -V
): 3.8.5The text was updated successfully, but these errors were encountered: