Commit 541fd57
committed
.Net: Fix enum deserialization mismatch between schema and tool calls
KernelJsonSchemaBuilder uses JsonStringEnumConverter when generating
tool parameter schemas, telling LLMs to return enum values as strings.
However, KernelFunctionFromMethod.TryToDeserializeValue did not use
the same converter when deserializing LLM responses, causing
JsonException for any function with enum parameters.
Fall back to KernelJsonSchemaBuilder's default options (which include
JsonStringEnumConverter) when no explicit JsonSerializerOptions are
provided, ensuring schema generation and deserialization stay in sync.
Closes #135891 parent 781881a commit 541fd57
File tree
3 files changed
+56
-2
lines changed- dotnet/src
- InternalUtilities/src/Schema
- SemanticKernel.Core/Functions
- SemanticKernel.UnitTests/Functions
3 files changed
+56
-2
lines changedLines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
61 | 61 | | |
62 | 62 | | |
63 | 63 | | |
64 | | - | |
| 64 | + | |
65 | 65 | | |
66 | 66 | | |
67 | 67 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
738 | 738 | | |
739 | 739 | | |
740 | 740 | | |
741 | | - | |
| 741 | + | |
742 | 742 | | |
743 | 743 | | |
744 | 744 | | |
| |||
Lines changed: 54 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
755 | 755 | | |
756 | 756 | | |
757 | 757 | | |
| 758 | + | |
| 759 | + | |
| 760 | + | |
| 761 | + | |
| 762 | + | |
| 763 | + | |
| 764 | + | |
| 765 | + | |
| 766 | + | |
| 767 | + | |
| 768 | + | |
| 769 | + | |
| 770 | + | |
| 771 | + | |
| 772 | + | |
| 773 | + | |
| 774 | + | |
| 775 | + | |
| 776 | + | |
| 777 | + | |
| 778 | + | |
| 779 | + | |
| 780 | + | |
| 781 | + | |
| 782 | + | |
| 783 | + | |
| 784 | + | |
| 785 | + | |
| 786 | + | |
| 787 | + | |
| 788 | + | |
| 789 | + | |
| 790 | + | |
| 791 | + | |
| 792 | + | |
| 793 | + | |
758 | 794 | | |
759 | 795 | | |
760 | 796 | | |
| |||
1590 | 1626 | | |
1591 | 1627 | | |
1592 | 1628 | | |
| 1629 | + | |
| 1630 | + | |
| 1631 | + | |
| 1632 | + | |
| 1633 | + | |
| 1634 | + | |
| 1635 | + | |
| 1636 | + | |
| 1637 | + | |
| 1638 | + | |
| 1639 | + | |
| 1640 | + | |
| 1641 | + | |
| 1642 | + | |
| 1643 | + | |
| 1644 | + | |
| 1645 | + | |
| 1646 | + | |
1593 | 1647 | | |
0 commit comments