ob-metaflow 2.12.9.1__tar.gz → 2.12.10.1rc1__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of ob-metaflow might be problematic. Click here for more details.

Files changed (358) hide show
  1. {ob_metaflow-2.12.9.1/ob_metaflow.egg-info → ob_metaflow-2.12.10.1rc1}/PKG-INFO +2 -2
  2. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datastores/gs_storage.py +10 -3
  3. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/kubernetes_job.py +34 -21
  4. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/storage_executor.py +5 -1
  5. ob_metaflow-2.12.10.1rc1/metaflow/tracing/threadpool.py +30 -0
  6. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tracing/tracing_modules.py +2 -1
  7. ob_metaflow-2.12.10.1rc1/metaflow/version.py +1 -0
  8. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1/ob_metaflow.egg-info}/PKG-INFO +2 -2
  9. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/ob_metaflow.egg-info/SOURCES.txt +1 -0
  10. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/ob_metaflow.egg-info/requires.txt +1 -1
  11. ob_metaflow-2.12.9.1/metaflow/version.py +0 -1
  12. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/LICENSE +0 -0
  13. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/MANIFEST.in +0 -0
  14. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/README.md +0 -0
  15. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/R.py +0 -0
  16. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/__init__.py +0 -0
  17. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/__init__.py +0 -0
  18. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/__init__.py +0 -0
  19. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/_bashcomplete.py +0 -0
  20. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/_compat.py +0 -0
  21. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/_termui_impl.py +0 -0
  22. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/_textwrap.py +0 -0
  23. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/_unicodefun.py +0 -0
  24. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/_winconsole.py +0 -0
  25. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/core.py +0 -0
  26. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/decorators.py +0 -0
  27. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/exceptions.py +0 -0
  28. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/formatting.py +0 -0
  29. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/globals.py +0 -0
  30. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/parser.py +0 -0
  31. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/termui.py +0 -0
  32. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/testing.py +0 -0
  33. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/types.py +0 -0
  34. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/click/utils.py +0 -0
  35. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/__init__.py +0 -0
  36. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_adapters.py +0 -0
  37. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_collections.py +0 -0
  38. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_compat.py +0 -0
  39. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_functools.py +0 -0
  40. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_itertools.py +0 -0
  41. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_meta.py +0 -0
  42. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/_text.py +0 -0
  43. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/importlib_metadata/py.typed +0 -0
  44. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/__init__.py +0 -0
  45. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/_elffile.py +0 -0
  46. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/_manylinux.py +0 -0
  47. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/_musllinux.py +0 -0
  48. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/_parser.py +0 -0
  49. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/_structures.py +0 -0
  50. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/_tokenizer.py +0 -0
  51. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/markers.py +0 -0
  52. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/py.typed +0 -0
  53. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/requirements.py +0 -0
  54. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/specifiers.py +0 -0
  55. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/tags.py +0 -0
  56. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/utils.py +0 -0
  57. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/packaging/version.py +0 -0
  58. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/__init__.py +0 -0
  59. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_checkers.py +0 -0
  60. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_config.py +0 -0
  61. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_decorators.py +0 -0
  62. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_exceptions.py +0 -0
  63. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_functions.py +0 -0
  64. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_importhook.py +0 -0
  65. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_memo.py +0 -0
  66. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_pytest_plugin.py +0 -0
  67. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_suppression.py +0 -0
  68. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_transformer.py +0 -0
  69. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_union_transformer.py +0 -0
  70. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/_utils.py +0 -0
  71. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typeguard/py.typed +0 -0
  72. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/typing_extensions.py +0 -0
  73. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_5/__init__.py +0 -0
  74. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_5/importlib_metadata/__init__.py +0 -0
  75. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_5/importlib_metadata/_compat.py +0 -0
  76. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_5/zipp.py +0 -0
  77. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/__init__.py +0 -0
  78. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/__init__.py +0 -0
  79. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_adapters.py +0 -0
  80. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_collections.py +0 -0
  81. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_compat.py +0 -0
  82. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_functools.py +0 -0
  83. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_itertools.py +0 -0
  84. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_meta.py +0 -0
  85. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/_text.py +0 -0
  86. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/importlib_metadata/py.typed +0 -0
  87. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/typing_extensions.py +0 -0
  88. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/v3_6/zipp.py +0 -0
  89. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/_vendor/zipp.py +0 -0
  90. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cards.py +0 -0
  91. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cli.py +0 -0
  92. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cli_args.py +0 -0
  93. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/client/__init__.py +0 -0
  94. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/client/core.py +0 -0
  95. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/client/filecache.py +0 -0
  96. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/clone_util.py +0 -0
  97. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/__init__.py +0 -0
  98. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/configure_cmd.py +0 -0
  99. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/develop/__init__.py +0 -0
  100. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/develop/stub_generator.py +0 -0
  101. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/develop/stubs.py +0 -0
  102. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/main_cli.py +0 -0
  103. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/tutorials_cmd.py +0 -0
  104. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd/util.py +0 -0
  105. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/cmd_with_io.py +0 -0
  106. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/__init__.py +0 -0
  107. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/content_addressed_store.py +0 -0
  108. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/datastore_set.py +0 -0
  109. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/datastore_storage.py +0 -0
  110. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/exceptions.py +0 -0
  111. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/flow_datastore.py +0 -0
  112. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/inputs.py +0 -0
  113. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/datastore/task_datastore.py +0 -0
  114. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/debug.py +0 -0
  115. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/decorators.py +0 -0
  116. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/event_logger.py +0 -0
  117. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/events.py +0 -0
  118. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/exception.py +0 -0
  119. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/extension_support/__init__.py +0 -0
  120. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/extension_support/_empty_file.py +0 -0
  121. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/extension_support/cmd.py +0 -0
  122. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/extension_support/integrations.py +0 -0
  123. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/extension_support/plugins.py +0 -0
  124. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/flowspec.py +0 -0
  125. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/graph.py +0 -0
  126. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/includefile.py +0 -0
  127. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/integrations.py +0 -0
  128. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/lint.py +0 -0
  129. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metadata/__init__.py +0 -0
  130. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metadata/heartbeat.py +0 -0
  131. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metadata/metadata.py +0 -0
  132. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metadata/util.py +0 -0
  133. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metaflow_config.py +0 -0
  134. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metaflow_config_funcs.py +0 -0
  135. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metaflow_current.py +0 -0
  136. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metaflow_environment.py +0 -0
  137. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metaflow_profile.py +0 -0
  138. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/metaflow_version.py +0 -0
  139. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/mflog/__init__.py +0 -0
  140. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/mflog/mflog.py +0 -0
  141. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/mflog/save_logs.py +0 -0
  142. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/mflog/save_logs_periodically.py +0 -0
  143. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/mflog/tee.py +0 -0
  144. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/monitor.py +0 -0
  145. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/multicore_utils.py +0 -0
  146. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/package.py +0 -0
  147. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/parameters.py +0 -0
  148. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/__init__.py +0 -0
  149. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/__init__.py +0 -0
  150. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/airflow.py +0 -0
  151. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/airflow_cli.py +0 -0
  152. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/airflow_decorator.py +0 -0
  153. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/airflow_utils.py +0 -0
  154. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/dag.py +0 -0
  155. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/exception.py +0 -0
  156. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/plumbing/__init__.py +0 -0
  157. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/plumbing/set_parameters.py +0 -0
  158. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/sensors/__init__.py +0 -0
  159. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/sensors/base_sensor.py +0 -0
  160. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/sensors/external_task_sensor.py +0 -0
  161. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/airflow/sensors/s3_sensor.py +0 -0
  162. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/__init__.py +0 -0
  163. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/argo_client.py +0 -0
  164. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/argo_events.py +0 -0
  165. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/argo_workflows.py +0 -0
  166. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/argo_workflows_cli.py +0 -0
  167. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/argo_workflows_decorator.py +0 -0
  168. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/argo_workflows_deployer.py +0 -0
  169. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/generate_input_paths.py +0 -0
  170. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/argo/jobset_input_paths.py +0 -0
  171. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/__init__.py +0 -0
  172. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/aws_client.py +0 -0
  173. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/aws_utils.py +0 -0
  174. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/batch/__init__.py +0 -0
  175. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/batch/batch.py +0 -0
  176. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/batch/batch_cli.py +0 -0
  177. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/batch/batch_client.py +0 -0
  178. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/batch/batch_decorator.py +0 -0
  179. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/secrets_manager/__init__.py +0 -0
  180. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/secrets_manager/aws_secrets_manager_secrets_provider.py +0 -0
  181. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/__init__.py +0 -0
  182. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/dynamo_db_client.py +0 -0
  183. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/event_bridge_client.py +0 -0
  184. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/production_token.py +0 -0
  185. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/schedule_decorator.py +0 -0
  186. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/set_batch_environment.py +0 -0
  187. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/step_functions.py +0 -0
  188. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/step_functions_cli.py +0 -0
  189. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/step_functions_client.py +0 -0
  190. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/step_functions_decorator.py +0 -0
  191. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/aws/step_functions/step_functions_deployer.py +0 -0
  192. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/__init__.py +0 -0
  193. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/azure_credential.py +0 -0
  194. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/azure_exceptions.py +0 -0
  195. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/azure_secret_manager_secrets_provider.py +0 -0
  196. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/azure_tail.py +0 -0
  197. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/azure_utils.py +0 -0
  198. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/blob_service_client_factory.py +0 -0
  199. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/azure/includefile_support.py +0 -0
  200. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/__init__.py +0 -0
  201. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_cli.py +0 -0
  202. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_client.py +0 -0
  203. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_creator.py +0 -0
  204. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_datastore.py +0 -0
  205. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_decorator.py +0 -0
  206. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/__init__.py +0 -0
  207. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/base.html +0 -0
  208. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/basic.py +0 -0
  209. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/bundle.css +0 -0
  210. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/card.py +0 -0
  211. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/chevron/__init__.py +0 -0
  212. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/chevron/main.py +0 -0
  213. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/chevron/metadata.py +0 -0
  214. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/chevron/renderer.py +0 -0
  215. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/chevron/tokenizer.py +0 -0
  216. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/components.py +0 -0
  217. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/convert_to_native_type.py +0 -0
  218. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/main.js +0 -0
  219. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/renderer_tools.py +0 -0
  220. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_modules/test_cards.py +0 -0
  221. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_resolver.py +0 -0
  222. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_server.py +0 -0
  223. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/card_viewer/viewer.html +0 -0
  224. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/component_serializer.py +0 -0
  225. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/cards/exception.py +0 -0
  226. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/catch_decorator.py +0 -0
  227. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datastores/__init__.py +0 -0
  228. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datastores/azure_storage.py +0 -0
  229. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datastores/local_storage.py +0 -0
  230. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datastores/s3_storage.py +0 -0
  231. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/__init__.py +0 -0
  232. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/local.py +0 -0
  233. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/s3/__init__.py +0 -0
  234. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/s3/s3.py +0 -0
  235. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/s3/s3op.py +0 -0
  236. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/s3/s3tail.py +0 -0
  237. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/datatools/s3/s3util.py +0 -0
  238. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/debug_logger.py +0 -0
  239. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/debug_monitor.py +0 -0
  240. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/__init__.py +0 -0
  241. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/client.py +0 -0
  242. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/client_modules.py +0 -0
  243. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/communication/__init__.py +0 -0
  244. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/communication/bytestream.py +0 -0
  245. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/communication/channel.py +0 -0
  246. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/communication/socket_bytestream.py +0 -0
  247. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/communication/utils.py +0 -0
  248. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/configurations/emulate_test_lib/__init__.py +0 -0
  249. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/configurations/emulate_test_lib/overrides.py +0 -0
  250. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/configurations/emulate_test_lib/server_mappings.py +0 -0
  251. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/configurations/test_lib_impl/__init__.py +0 -0
  252. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/configurations/test_lib_impl/test_lib.py +0 -0
  253. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/consts.py +0 -0
  254. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/data_transferer.py +0 -0
  255. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/exception_transferer.py +0 -0
  256. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/override_decorators.py +0 -0
  257. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/server.py +0 -0
  258. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/stub.py +0 -0
  259. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/env_escape/utils.py +0 -0
  260. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/environment_decorator.py +0 -0
  261. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/events_decorator.py +0 -0
  262. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/frameworks/__init__.py +0 -0
  263. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/frameworks/pytorch.py +0 -0
  264. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/__init__.py +0 -0
  265. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/gcp_secret_manager_secrets_provider.py +0 -0
  266. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/gs_exceptions.py +0 -0
  267. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/gs_storage_client_factory.py +0 -0
  268. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/gs_tail.py +0 -0
  269. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/gs_utils.py +0 -0
  270. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/gcp/includefile_support.py +0 -0
  271. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/__init__.py +0 -0
  272. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/kubernetes.py +0 -0
  273. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/kubernetes_cli.py +0 -0
  274. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/kubernetes_client.py +0 -0
  275. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/kubernetes_decorator.py +0 -0
  276. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/kubernetes/kubernetes_jobsets.py +0 -0
  277. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/logs_cli.py +0 -0
  278. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/metadata/__init__.py +0 -0
  279. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/metadata/local.py +0 -0
  280. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/metadata/service.py +0 -0
  281. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/package_cli.py +0 -0
  282. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/parallel_decorator.py +0 -0
  283. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/project_decorator.py +0 -0
  284. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/__init__.py +0 -0
  285. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/bootstrap.py +0 -0
  286. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/conda_decorator.py +0 -0
  287. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/conda_environment.py +0 -0
  288. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/micromamba.py +0 -0
  289. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/pip.py +0 -0
  290. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/pypi_decorator.py +0 -0
  291. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/pypi_environment.py +0 -0
  292. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/pypi/utils.py +0 -0
  293. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/resources_decorator.py +0 -0
  294. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/retry_decorator.py +0 -0
  295. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/secrets/__init__.py +0 -0
  296. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/secrets/inline_secrets_provider.py +0 -0
  297. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/secrets/secrets_decorator.py +0 -0
  298. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/tag_cli.py +0 -0
  299. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/test_unbounded_foreach_decorator.py +0 -0
  300. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/plugins/timeout_decorator.py +0 -0
  301. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/procpoll.py +0 -0
  302. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/py.typed +0 -0
  303. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/pylint_wrapper.py +0 -0
  304. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/__init__.py +0 -0
  305. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/click_api.py +0 -0
  306. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/deployer.py +0 -0
  307. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/metaflow_runner.py +0 -0
  308. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/nbdeploy.py +0 -0
  309. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/nbrun.py +0 -0
  310. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/subprocess_manager.py +0 -0
  311. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runner/utils.py +0 -0
  312. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/runtime.py +0 -0
  313. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/sidecar/__init__.py +0 -0
  314. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/sidecar/sidecar.py +0 -0
  315. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/sidecar/sidecar_messages.py +0 -0
  316. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/sidecar/sidecar_subprocess.py +0 -0
  317. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/sidecar/sidecar_worker.py +0 -0
  318. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/system/__init__.py +0 -0
  319. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/system/system_logger.py +0 -0
  320. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/system/system_monitor.py +0 -0
  321. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/system/system_utils.py +0 -0
  322. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tagging_util.py +0 -0
  323. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/task.py +0 -0
  324. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tracing/__init__.py +0 -0
  325. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tracing/propagator.py +0 -0
  326. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tracing/span_exporter.py +0 -0
  327. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tuple_util.py +0 -0
  328. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/00-helloworld/README.md +0 -0
  329. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/00-helloworld/helloworld.py +0 -0
  330. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/01-playlist/README.md +0 -0
  331. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/01-playlist/movies.csv +0 -0
  332. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/01-playlist/playlist.ipynb +0 -0
  333. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/01-playlist/playlist.py +0 -0
  334. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/02-statistics/README.md +0 -0
  335. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/02-statistics/movies.csv +0 -0
  336. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/02-statistics/stats.ipynb +0 -0
  337. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/02-statistics/stats.py +0 -0
  338. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/03-playlist-redux/README.md +0 -0
  339. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/03-playlist-redux/playlist.py +0 -0
  340. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/04-playlist-plus/README.md +0 -0
  341. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/04-playlist-plus/playlist.py +0 -0
  342. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/05-hello-cloud/README.md +0 -0
  343. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/05-hello-cloud/hello-cloud.ipynb +0 -0
  344. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/05-hello-cloud/hello-cloud.py +0 -0
  345. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/06-statistics-redux/README.md +0 -0
  346. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/06-statistics-redux/stats.ipynb +0 -0
  347. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/07-worldview/README.md +0 -0
  348. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/07-worldview/worldview.ipynb +0 -0
  349. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/08-autopilot/README.md +0 -0
  350. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/tutorials/08-autopilot/autopilot.ipynb +0 -0
  351. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/unbounded_foreach.py +0 -0
  352. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/util.py +0 -0
  353. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/metaflow/vendor.py +0 -0
  354. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/ob_metaflow.egg-info/dependency_links.txt +0 -0
  355. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/ob_metaflow.egg-info/entry_points.txt +0 -0
  356. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/ob_metaflow.egg-info/top_level.txt +0 -0
  357. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/setup.cfg +0 -0
  358. {ob_metaflow-2.12.9.1 → ob_metaflow-2.12.10.1rc1}/setup.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ob-metaflow
3
- Version: 2.12.9.1
3
+ Version: 2.12.10.1rc1
4
4
  Summary: Metaflow: More Data Science, Less Engineering
5
5
  Author: Netflix, Outerbounds & the Metaflow Community
6
6
  Author-email: help@outerbounds.co
@@ -12,7 +12,7 @@ Requires-Dist: boto3
12
12
  Requires-Dist: pylint
13
13
  Requires-Dist: kubernetes
14
14
  Provides-Extra: stubs
15
- Requires-Dist: metaflow-stubs==2.12.9.1; extra == "stubs"
15
+ Requires-Dist: metaflow-stubs==2.12.10.1rc1; extra == "stubs"
16
16
 
17
17
  ![Metaflow_Logo_Horizontal_FullColor_Ribbon_Dark_RGB](https://user-images.githubusercontent.com/763451/89453116-96a57e00-d713-11ea-9fa6-82b29d4d6eff.png)
18
18
 
@@ -8,6 +8,7 @@ from tempfile import mkdtemp
8
8
 
9
9
  from metaflow.datastore.datastore_storage import DataStoreStorage, CloseAfterUse
10
10
  from metaflow.exception import MetaflowInternalError
11
+ from metaflow.tracing import traced, tracing
11
12
  from metaflow.metaflow_config import (
12
13
  DATASTORE_SYSROOT_GS,
13
14
  ARTIFACT_LOCALROOT,
@@ -70,12 +71,14 @@ class _GSRootClient(object):
70
71
  """Drives GSStorage.is_file()"""
71
72
  try:
72
73
  blob = self.get_blob_client(path)
73
- result = blob.exists()
74
+ with traced("exists", dict(path=path)):
75
+ result = blob.exists()
74
76
 
75
77
  return result
76
78
  except Exception as e:
77
79
  process_gs_exception(e)
78
80
 
81
+ @tracing
79
82
  def list_content_single(self, path):
80
83
  """Drives GSStorage.list_content()"""
81
84
 
@@ -104,6 +107,7 @@ class _GSRootClient(object):
104
107
  except Exception as e:
105
108
  process_gs_exception(e)
106
109
 
110
+ @tracing
107
111
  def save_bytes_single(
108
112
  self,
109
113
  path_tmpfile_metadata_triple,
@@ -119,10 +123,12 @@ class _GSRootClient(object):
119
123
  blob.metadata = {"metaflow-user-attributes": json.dumps(metadata)}
120
124
  from google.cloud.storage.retry import DEFAULT_RETRY
121
125
 
122
- blob.upload_from_filename(tmpfile, retry=DEFAULT_RETRY)
126
+ with traced("upload_blob", dict(path=path)):
127
+ blob.upload_from_filename(tmpfile, retry=DEFAULT_RETRY)
123
128
  except Exception as e:
124
129
  process_gs_exception(e)
125
130
 
131
+ @tracing
126
132
  def load_bytes_single(self, tmpdir, key):
127
133
  """Drives GSStorage.load_bytes()"""
128
134
  tmp_filename = os.path.join(tmpdir, str(uuid.uuid4()))
@@ -136,7 +142,8 @@ class _GSRootClient(object):
136
142
  metaflow_user_attributes = json.loads(
137
143
  blob.metadata["metaflow-user-attributes"]
138
144
  )
139
- blob.download_to_filename(tmp_filename)
145
+ with traced("download_blob", dict(path=key)):
146
+ blob.download_to_filename(tmp_filename)
140
147
  except google.api_core.exceptions.NotFound:
141
148
  tmp_filename = None
142
149
  return key, tmp_filename, metaflow_user_attributes
@@ -5,6 +5,7 @@ import random
5
5
  import sys
6
6
  import time
7
7
 
8
+ from metaflow.tracing import inject_tracing_vars, tracing, traced
8
9
  from metaflow.exception import MetaflowException
9
10
  from metaflow.metaflow_config import KUBERNETES_SECRETS
10
11
  from metaflow.tracing import inject_tracing_vars
@@ -299,13 +300,19 @@ class KubernetesJob(object):
299
300
  # achieve the guarantees that we are seeking.
300
301
  # https://github.com/kubernetes/enhancements/issues/1040
301
302
  # Hopefully, we will be able to get creative with kube-batch
302
- response = (
303
- client.BatchV1Api()
304
- .create_namespaced_job(
305
- body=self._job, namespace=self._kwargs["namespace"]
303
+
304
+ with traced(
305
+ "submit_kubernetes_job",
306
+ {"job": "%s/%s" % (self._job.metadata.name, self._kwargs["namespace"])},
307
+ ):
308
+
309
+ response = (
310
+ client.BatchV1Api()
311
+ .create_namespaced_job(
312
+ body=self._job, namespace=self._kwargs["namespace"]
313
+ )
314
+ .to_dict()
306
315
  )
307
- .to_dict()
308
- )
309
316
  return RunningJob(
310
317
  client=self._client,
311
318
  name=response["metadata"]["name"],
@@ -434,11 +441,14 @@ class RunningJob(object):
434
441
  def _fetch_job(self):
435
442
  client = self._client.get()
436
443
  try:
437
- return (
438
- client.BatchV1Api()
439
- .read_namespaced_job(name=self._name, namespace=self._namespace)
440
- .to_dict()
441
- )
444
+ with traced(
445
+ "fetch_kubernetes_job", {"job": "%s/%s" % (self._name, self._namespace)}
446
+ ):
447
+ return (
448
+ client.BatchV1Api()
449
+ .read_namespaced_job(name=self._name, namespace=self._namespace)
450
+ .to_dict()
451
+ )
442
452
  except client.rest.ApiException as e:
443
453
  if e.status == 404:
444
454
  raise KubernetesJobException(
@@ -450,17 +460,20 @@ class RunningJob(object):
450
460
  def _fetch_pod(self):
451
461
  # Fetch pod metadata.
452
462
  client = self._client.get()
453
- pods = (
454
- client.CoreV1Api()
455
- .list_namespaced_pod(
456
- namespace=self._namespace,
457
- label_selector="job-name={}".format(self._name),
463
+ with traced(
464
+ "fetch_kubernetes_pod", {"job": "%s/%s" % (self._name, self._namespace)}
465
+ ):
466
+ pods = (
467
+ client.CoreV1Api()
468
+ .list_namespaced_pod(
469
+ namespace=self._namespace,
470
+ label_selector="job-name={}".format(self._name),
471
+ )
472
+ .to_dict()["items"]
458
473
  )
459
- .to_dict()["items"]
460
- )
461
- if pods:
462
- return pods[0]
463
- return {}
474
+ if pods:
475
+ return pods[0]
476
+ return {}
464
477
 
465
478
  def kill(self):
466
479
  # Terminating a Kubernetes job is a bit tricky. Issuing a
@@ -6,6 +6,7 @@ import sys
6
6
  from concurrent.futures import ProcessPoolExecutor, ThreadPoolExecutor
7
7
 
8
8
  from metaflow.exception import MetaflowException
9
+ from metaflow.tracing.threadpool import TracedThreadPoolExecutor
9
10
 
10
11
  if sys.version_info[:2] < (3, 7):
11
12
  # in 3.6, Only BrokenProcessPool exists (there is no BrokenThreadPool)
@@ -132,7 +133,10 @@ class StorageExecutor(object):
132
133
  msg="Cannot use ProcessPoolExecutor because Python version is older than 3.7 and multiprocess start method has been set to something other than 'spawn'"
133
134
  )
134
135
  else:
135
- self._executor = ThreadPoolExecutor(max_workers=threadpool_max_workers)
136
+ self._executor = TracedThreadPoolExecutor(
137
+ "StorageExecutor", max_workers=threadpool_max_workers
138
+ )
139
+ # self._executor = ThreadPoolExecutor(max_workers=threadpool_max_workers)
136
140
 
137
141
  def warm_up(self):
138
142
  # warm up at least one process or thread in the pool.
@@ -0,0 +1,30 @@
1
+ from concurrent.futures import ThreadPoolExecutor
2
+ from opentelemetry import context as otel_context
3
+ from opentelemetry.sdk.trace import Tracer
4
+ from opentelemetry import trace as trace_api
5
+ from typing import Callable
6
+
7
+
8
+ class TracedThreadPoolExecutor(ThreadPoolExecutor):
9
+ """Implementation of :class:`ThreadPoolExecutor` that will pass context into sub tasks."""
10
+
11
+ def __init__(self, name: str, *args, **kwargs):
12
+ tracer = trace_api.get_tracer(name)
13
+ self.tracer = tracer
14
+ super().__init__(*args, **kwargs)
15
+
16
+ def with_otel_context(self, context: otel_context.Context, fn: Callable):
17
+ otel_context.attach(context)
18
+ return fn()
19
+
20
+ def submit(self, fn, *args, **kwargs):
21
+ """Submit a new task to the thread pool."""
22
+
23
+ # get the current otel context
24
+ context = otel_context.get_current()
25
+ if context:
26
+ return super().submit(
27
+ lambda: self.with_otel_context(context, lambda: fn(*args, **kwargs)),
28
+ )
29
+ else:
30
+ return super().submit(lambda: fn(*args, **kwargs))
@@ -21,6 +21,7 @@ def init_tracing():
21
21
  if tracer_provider is not None:
22
22
  print("Tracing already initialized", file=sys.stderr)
23
23
  return
24
+ import os
24
25
 
25
26
  from .propagator import EnvPropagator
26
27
 
@@ -142,7 +143,7 @@ def traced(name, attrs={}):
142
143
  def tracing(func):
143
144
  @wraps(func)
144
145
  def wrapper_func(*args, **kwargs):
145
- tracer = trace_api.get_tracer_provider().get_tracer(func.__module__.__name__)
146
+ tracer = trace_api.get_tracer_provider().get_tracer(func.__module__)
146
147
 
147
148
  with tracer.start_as_current_span(func.__name__):
148
149
  return func(*args, **kwargs)
@@ -0,0 +1 @@
1
+ metaflow_version = "2.12.10.1rc1"
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ob-metaflow
3
- Version: 2.12.9.1
3
+ Version: 2.12.10.1rc1
4
4
  Summary: Metaflow: More Data Science, Less Engineering
5
5
  Author: Netflix, Outerbounds & the Metaflow Community
6
6
  Author-email: help@outerbounds.co
@@ -12,7 +12,7 @@ Requires-Dist: boto3
12
12
  Requires-Dist: pylint
13
13
  Requires-Dist: kubernetes
14
14
  Provides-Extra: stubs
15
- Requires-Dist: metaflow-stubs==2.12.9.1; extra == "stubs"
15
+ Requires-Dist: metaflow-stubs==2.12.10.1rc1; extra == "stubs"
16
16
 
17
17
  ![Metaflow_Logo_Horizontal_FullColor_Ribbon_Dark_RGB](https://user-images.githubusercontent.com/763451/89453116-96a57e00-d713-11ea-9fa6-82b29d4d6eff.png)
18
18
 
@@ -323,6 +323,7 @@ metaflow/system/system_utils.py
323
323
  metaflow/tracing/__init__.py
324
324
  metaflow/tracing/propagator.py
325
325
  metaflow/tracing/span_exporter.py
326
+ metaflow/tracing/threadpool.py
326
327
  metaflow/tracing/tracing_modules.py
327
328
  metaflow/tutorials/00-helloworld/README.md
328
329
  metaflow/tutorials/00-helloworld/helloworld.py
@@ -4,4 +4,4 @@ pylint
4
4
  kubernetes
5
5
 
6
6
  [stubs]
7
- metaflow-stubs==2.12.9.1
7
+ metaflow-stubs==2.12.10.1rc1
@@ -1 +0,0 @@
1
- metaflow_version = "2.12.9.1"