Skip to content

pass a logger and a task schedular to handlers#300

Open
craigrose wants to merge 5 commits into
mainfrom
feature/8472-changes-for-prefect
Open

pass a logger and a task schedular to handlers#300
craigrose wants to merge 5 commits into
mainfrom
feature/8472-changes-for-prefect

Conversation

@craigrose

Copy link
Copy Markdown
Contributor

No description provided.

Copilot AI review requested due to automatic review settings June 11, 2026 07:18

Copilot AI left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

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

Pull request overview

This PR introduces dependency injection for handlers by allowing an external logger and a task “schedular”/scheduler to be passed in, enabling custom scheduling of batch processing instead of always creating a Dask cluster.

Changes:

  • Allow CommonHandler (and factory cloud_optimised_creation) to accept a provided logger instead of always creating one.
  • Add a schedular hook to CommonHandler and use it in GenericParquetHandler.to_cloud_optimised() to schedule batch tasks externally.
  • Add defensive handling around logger handler cleanup in GenericParquetHandler.

Reviewed changes

Copilot reviewed 2 out of 2 changed files in this pull request and generated 4 comments.

File Description
aodn_cloud_optimised/lib/GenericParquetHandler.py Adds optional external scheduling path and adjusts logger handler cleanup logic.
aodn_cloud_optimised/lib/CommonHandler.py Adds logger injection, plumbs schedular kwarg through handler creation, and updates logger selection logic.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment on lines +96 to 100
self.logger = kwargs.get("logger", None)
if not self.logger:
logger_name = self.dataset_config.get("logger_name", "generic")
self.logger = get_logger(logger_name, raise_error=self.raise_error)

Comment on lines +690 to +694
if not logger:
logger_name = dataset_config.get("logger_name", "generic")
logger = get_logger(logger_name, raise_error=kwargs.get("raise_error", False))
else:
kwargs_handler_class["logger"] = logger
Comment on lines +1668 to +1671
try:
self.logger.handlers.clear()
except AttributeError:
pass
logger=self.logger,
)

self.schedular = kwargs.get("schedular", None)
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