- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 10.8k
[Bugfix] Fix pydantic.errors.PydanticUserError #17962
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
Conversation
| 👋 Hi! Thank you for contributing to the vLLM project. 💬 Join our developer Slack at https://slack.vllm.ai to discuss your PR in #pr-reviews, coordinate on features in #feat- channels, or join special interest groups in #sig- channels. Just a reminder: PRs would not trigger full CI run by default. Instead, it would only run  Once the PR is approved and ready to go, your PR reviewer(s) can run CI to test the changes comprehensively before merging. To run CI, PR reviewers can either: Add  🚀 | 
| Looks reasonable, pydantic will do real check on typing imported typeddict. Then, it raised error in python 3.10. Consider, vllm support python > 3.9 currently, we need this. | 
| @frieda-huang @DarkLight1337 Would you mind taking a look on this? | 
| I have tested the latest code in Python's interactive terminal with vllm latest code on A100: Python 3.10.16 (main, Dec 11 2024, 16:24:50) [GCC 11.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from vllm.entrypoints.openai.serving_engine import OpenAIServingthe result is: INFO 05-11 23:19:22 [__init__.py:248] Automatically detected platform cuda.
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/root/autodl-tmp/wl/vllm/vllm/entrypoints/openai/serving_engine.py", line 102, in <module>
    class RequestProcessingMixin(BaseModel):
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_model_construction.py", line 237, in __new__
    complete_model_class(
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_model_construction.py", line 597, in complete_model_class
    schema = gen_schema.generate_schema(cls)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 706, in generate_schema
    schema = self._generate_schema_inner(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 999, in _generate_schema_inner
    return self._model_schema(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 832, in _model_schema
    {k: self._generate_md_field_schema(k, v, decorators) for k, v in fields.items()},
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 832, in <dictcomp>
    {k: self._generate_md_field_schema(k, v, decorators) for k, v in fields.items()},
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1201, in _generate_md_field_schema
    common_field = self._common_field_schema(name, field_info, decorators)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1367, in _common_field_schema
    schema = self._apply_annotations(
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 2279, in _apply_annotations
    schema = get_inner_schema(source_type)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_schema_generation_shared.py", line 83, in __call__
    schema = self._handler(source_type)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 2261, in inner_handler
    schema = self._generate_schema_inner(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1004, in _generate_schema_inner
    return self.match_type(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1118, in match_type
    return self._match_generic_type(obj, origin)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1141, in _match_generic_type
    return self._union_schema(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1429, in _union_schema
    choices.append(self.generate_schema(arg))
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 706, in generate_schema
    schema = self._generate_schema_inner(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1004, in _generate_schema_inner
    return self.match_type(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1118, in match_type
    return self._match_generic_type(obj, origin)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1165, in _match_generic_type
    return self._sequence_schema(self._get_first_arg_or_any(obj))
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1813, in _sequence_schema
    item_type_schema = self.generate_schema(items_type)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 706, in generate_schema
    schema = self._generate_schema_inner(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1004, in _generate_schema_inner
    return self.match_type(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1118, in match_type
    return self._match_generic_type(obj, origin)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1141, in _match_generic_type
    return self._union_schema(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1429, in _union_schema
    choices.append(self.generate_schema(arg))
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 706, in generate_schema
    schema = self._generate_schema_inner(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1004, in _generate_schema_inner
    return self.match_type(obj)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1086, in match_type
    return self._typed_dict_schema(obj, None)
  File "/root/autodl-tmp/miniconda/envs/vllm_test/lib/python3.10/site-packages/pydantic/_internal/_generate_schema.py", line 1506, in _typed_dict_schema
    raise PydanticUserError(
pydantic.errors.PydanticUserError: Please use `typing_extensions.TypedDict` instead of `typing.TypedDict` on Python < 3.12.and I test with this patch: Python 3.10.16 (main, Dec 11 2024, 16:24:50) [GCC 11.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from vllm.entrypoints.openai.serving_engine import OpenAIServing
INFO 05-11 23:25:19 [__init__.py:248] Automatically detected platform cuda.
>>>  | 
| 
 Ok. I'm on it! | 
| 
 Looks reasonable to me as well! Will take a note on that for future contribution. | 
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 for fixing!
| Some error occurred in   | 
Signed-off-by: wangli <wangli858794774@gmail.com>
Head branch was pushed to by a user without write access
### What this PR does / why we need it? For the [#17962](vllm-project/vllm#17962) has merged, vllm openapi server can now launch normally on python==3.10, we re-enable the related tests Signed-off-by: wangli <wangli858794774@gmail.com>
Signed-off-by: wangli <wangli858794774@gmail.com> Signed-off-by: Mu Huai <tianbowen.tbw@antgroup.com>
Signed-off-by: wangli <wangli858794774@gmail.com>
Signed-off-by: wangli <wangli858794774@gmail.com> Signed-off-by: Yuqi Zhang <yuqizhang@google.com>
### What this PR does / why we need it? For the [#17962](vllm-project/vllm#17962) has merged, vllm openapi server can now launch normally on python==3.10, we re-enable the related tests Signed-off-by: wangli <wangli858794774@gmail.com>
### What this PR does / why we need it? For the [#17962](vllm-project/vllm#17962) has merged, vllm openapi server can now launch normally on python==3.10, we re-enable the related tests Signed-off-by: wangli <wangli858794774@gmail.com>
FIX
pydantic.errors.PydanticUserError, when we are using python<3.12, pydantic needs theTypedDictfrom typing_extensionsFIX #17966