-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #19 from lmignon/master-recursive-mode-rebuild
Ensure recursive field annotation resolution
- Loading branch information
Showing
4 changed files
with
109 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
Fix problem with unresolved annotated types in the aggregated model. | ||
|
||
At the end of the registry building process, the registry contains the aggregated | ||
model. Each aggregated model is the result of the build of a new class based on | ||
a hierarchy of all the classes defined as 'extends' of the same base class. The | ||
order of the classes hierarchy is defined by the order in which the classes are | ||
loaded by the class loader or by a specific order defined by the developer when | ||
the registry is built. | ||
|
||
The last step of the build process is to resolve all the annotated types in the | ||
aggregated model and rebuild the pydantic schema validator. This step is necessary | ||
because when the developer defines a model, some fields can be annotated with a | ||
type that refers to a class that is an extendable class. It's therefore necessary | ||
to update the annotated type with the aggregated result of the specified | ||
extendable class and rebuild the pydantic schema validator to take into account | ||
the new annotated types. | ||
|
||
Prior to this commit, the resolution of the annotated types was not done in a | ||
recursive way and the rebuild of the pydantic schema validator was only done | ||
just after the resolution of an aggregated class. This means that if a class A | ||
is an extendable defining a fields annotated with a type that refers to a class | ||
B, and if the class B is an extendable class defining a field of type C, | ||
the annotated type of the field of the class A was resolved with the aggregated | ||
model of the class B but we didn't resolve th annotated type of the field ot type | ||
B with the aggregated model of the type C. Therefore when the pydantic schema | ||
validator was rebuilt after the resolution of the class A, if the class B was | ||
not yet resolved and therefore the pydantic schema validator was not rebuilt, | ||
the new schema validator for the class A was not correct because it didn't take | ||
into account the aggregated model of the class C nor the definition of extra | ||
fields of the aggregated model of the class B. | ||
|
||
This commit changes the resolution of the annotated types to be recursive. Therefore | ||
when the pydantic schema validator is rebuilt, we are sure that all referenced | ||
subtypes are resolved and defines a correct schema validator. In the | ||
same time, when an aggregated class is resolved, it's marked as resolved to avoid | ||
to resolve it again and rebuild the pydantic schema validator again for nothing. | ||
In addition to resolve the initial problem, this commit also improves | ||
the performance of the build process because schema validators rebuilds are | ||
done only once per aggregated class. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters