-
Notifications
You must be signed in to change notification settings - Fork 580
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
Define error #2444
Define error #2444
Conversation
@Wauplin Are there any other error classes that need to be modified or moved besides |
Hello, I was going over the same code actually. It looks like FileMetadataError is the only error that is not affected by hf_raise_for_status, so all the other errors _errors.py should remain there. @Wauplin So I won't create any separate PR. Thanks a lot for your response! |
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.
Hi @cjfghk5697 , thanks for your PR! Actually all errors from src/huggingface_hub/utils/_errors.py
are entitled to move to src/huggingface_hub/errors.py
as mentioned in #2069 (comment). The logic for hf_raise_for_status
stays where it is but the error classes definitions have to move. It can be done in this PR or a separate one.
Also, do you think there's a need for any error handling code for 500-level errors?
I don't think there is a special need for that no. Those are usually caught as HfHttpError
and then filtered using the status code directly.
@010kim sorry for the duplicate work. To avoid such a situation, would you like to focus on moving the 2 exceptions from src/huggingface_hub/utils/_cache_manager.py for example? They also have to be moved in a separate PR similar to this one. |
Of course! That's great, I'm on it! |
Co-authored-by: Lucain <lucainp@gmail.com>
@Wauplin, thank you for your reply! Do you have any recommended suggestions or issues for improving Hub? |
Hi @cjfghk5697, thanks for asking! Sorry for the noise on your PR, let's refocus on this one first 😉 As mentioned in #2444 (review), it would be great to move all errors from |
@Wauplin Thank you! I'm a bit confused should the class used in |
Yes, all of those classes! ( |
I got it and appreciate your reply😊 The classes in |
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.
Thanks @cjfghk5697 for the changes! Almost everything looks good to me for a merge. Left a minor comment and then we should be good to go! 🚀
src/huggingface_hub/utils/_errors.py
Outdated
REPO_API_REGEX = re.compile( | ||
r""" | ||
# staging or production endpoint | ||
^https://[^/]+ | ||
( | ||
# on /api/repo_type/repo_id | ||
/api/(models|datasets|spaces)/(.+) | ||
| | ||
# or /repo_id/resolve/revision/... | ||
/(.+)/resolve/(.+) | ||
) | ||
""", | ||
flags=re.VERBOSE, |
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 can be kept in ./utils/_errors.py
since it's not a Exception class definition
Thanks @Wauplin! I have put it back! |
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.
Perfect!
I fixed a circular import in f3525e6. That's why I want to avoid as much as possible logic to be defined in errors.py
. Here we can't do without it so it's fine :)
The docs for this PR live here. All of your documentation changes will be reflected on that endpoint. The docs are available until 30 days after the last update. |
Failing tests are unrelated to this PR so let's merge it :) Thanks @cjfghk5697 for the work and iterations 🤗 |
@Wauplin |
Hi @cjfghk5697, thanks again for your support! What do you say about tackling #2466? :) If not, you can always have a look to the list in https://github.com/huggingface/huggingface_hub/issues?q=is%3Aissue+is%3Aopen+label%3A%22good+first+issue%22. Let me know if you have any preferences. |
#2069
I have implemented the suggestion from issue #2069. The
FileMetadataError
class has been moved fromhuggingface_hub/inference/_templating.py
tohuggingface_hub/errors.py
.Could you please review this PR? If this is correct, I will move the other classes in the same way.