-
Notifications
You must be signed in to change notification settings - Fork 87
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
Exception class for failed task #747
Comments
|
Can you point out where dictionaries are returned? I thought all of these were updated, but it sounds like you found some that were missed? Or are are you using the |
There is nothing to add; @sanders41 sander has already answered perfectly! |
@alallema I have found at least some of them. The tasks from |
@sanders41, that would be great! Yes, I think it's better to have everything coherently, even if it brings a breaking change. |
750: Return task instances from task methods instead of dicts r=alallema a=sanders41 # Pull Request ## Related issue Relates to #747 ## What does this PR do? - Returns an appropriate task class instance from task methods instead of dicts ## PR checklist Please check if your PR fulfills the following requirements: - [x] Does this PR fix an existing issue, or have you listed the changes applied in the PR description (and why they are needed)? - [x] Have you read the contributing guidelines? - [x] Have you made sure that the title is accurate and descriptive of the changes? Thank you so much for contributing to Meilisearch! Co-authored-by: Paul Sanders <[email protected]>
To be clear, I wasn't asking specifically for a However I do believe something like this is a great idea. It greatly reduces the amount of boilerplate code users of this library need to write to be able to write correct code with good error handling. |
A way do to this would be to add def wait_for_task(
self,
uid: int,
timeout_in_ms: int = 5000,
interval_in_ms: int = 50,
raise_for_status: bool = False,
) -> Task:
start_time = datetime.now()
elapsed_time = 0.0
while elapsed_time < timeout_in_ms:
task = self.get_task(uid)
if task.status not in ("enqueued", "processing"):
if raise_for_status and task.status == "failed":
raise MeilisearchFailedTaskError(f"Task {uid} failed")
return task
sleep(interval_in_ms / 1000)
time_delta = datetime.now() - start_time
elapsed_time = time_delta.seconds * 1000 + time_delta.microseconds / 1000
raise MeilisearchTimeoutError(
f"timeout of ${timeout_in_ms}ms has exceeded on process ${uid} when waiting for task to be resolve."
) Then, for example, @alallema thoughts? This would be the only SDK to implement this unless the team wanted to add it everywhere. |
I find the idea of how to solve this problem very nice and interesting however I do not think that this is very hard for the user to raise his own exception and especially I think that if we implement this new feature it should be present on all SDKs. We are already in a great debate about this wait_for_task method as you know, so I allow myself to add this to the already present discussion. |
Right now, there is no way to easily raise an exception for a failed task. When I use the built-in "wait for task" functionality, I'd like a way to get it to automatically raise an exception if the task I've waited for did not succeed. This could happen automatically as part of calling the method, or it could take the form of a
raise_for_status()
method (like what therequests
library exposes on response objects).The latter suggestion is complicated by the fact that right now, not all methods that return task data return the actual
Task
object. Some of them return dictionaries while others return instances of theTask
class. I think this inconsistency would need to be addressed at the same time.It is worth noting that the
MeilisearchApiError
exception contains very similar fields to what is available in theerror
data in the API task data. Unfortunately it also contains other information that make it difficult to easily re-use for the purpose I've described (a "failed task" exception).The text was updated successfully, but these errors were encountered: