melvinkcx/fastapi-events

pydantic v2 import errors

Closed this issue · 6 comments

When trying to upgrade to pydantic V2. there is the following import error

  File "/app/src/services/mail/events.py", line 1, in <module>
    from fastapi_events.handlers.local import local_handler
  File "/usr/local/lib/python3.11/site-packages/fastapi_events/handlers/local.py", line 10, in <module>
    from pydantic.error_wrappers import ErrorWrapper
  File "/usr/local/lib/python3.11/site-packages/pydantic/_migration.py", line 295, in wrapper
    raise PydanticImportError(f'`{import_path}` has been removed in V2.')
pydantic.errors.PydanticImportError: `pydantic.error_wrappers:ErrorWrapper` has been removed in V2.

For further information visit https://errors.pydantic.dev/2.1.1/u/import-error

it does not seem there is a direct replacement for "ErrorWrapper"
https://github.com/pydantic/pydantic/blob/main/pydantic/errors.py

Hi @bVdCreations, thanks for reporting this. This is indeed an issue, I'll look into the compatibility issue with Pydantic v2 more this week.

@melvinkcx let me know if I can help. I love this project so I don't mind to contribute.
Any docs on how to setup the local dev env?

I would try replacing "ErrorWrapper" with a custom type/protocol, so we loose the dependency to pydantic. I would love to hear your thoughts on this.

Hi, to set up your dev env, you may create a virtualenv and run pip install -e '.[test]'.

I plan to replace ErrorWrapper with a Protocol as well.

This library is supposed to support Pydantic for payload validation, but it's completely optional. So, I'd like to make sure it works properly with or without the presence of Pydantic. I'm also intended to change the test setup to ensure both scenario are well covered. I'll probably have some time this week to work on the changes.

hi @melvinkcx,

Looking at he local handler I did not see we where using the errors to I removed them in this pull request.
#46

I'm under the impression that the payload validation happens in the dispatch function, maybe I'm missing if it is propagated in the local handler

I'm not sure that was where you where headed, let me know.

Hi @bVdCreations, I just released a new version, which includes a fix for this error. Feel free to try it out. Thanks.

@melvinkcx thanks a lot, I could complete the migration to pydantic v2.
I had noticed some warnings popping I reported in a new issue #48