-
Notifications
You must be signed in to change notification settings - Fork 47
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
[bug] Instructor when instrumented tries to instantiate the type that is given as a response_model
#1160
Comments
Thanks for the note @spott - we'll take a look. If there's a minimum working example we can take a look at that would be amazing. Let us know if we can help in any way. |
Let me try and show what I've found. I don't think a minimum working example is necessary, though it shouldn't be that hard to make one. When you patch instructor, the patched async function here is called (there is a similar function for sync functions as well). here that function calls After a few more layers of indirection, we get to here, the
AttributeValue = Union[
str,
bool,
int,
float,
Sequence[str],
Sequence[bool],
Sequence[int],
Sequence[float],
]
And there is where the problem lies. The function that this whole thing is wrapping ( Ultimately the problem is that the types that So, I'm happy to submit a pull request... but I'm not sure where the contract for I'm leaning towards enforcing it at the flattening of the kwargs. In this case, I would stringify anything that wasn't an AttributeValue in the kwargs dict before passing it as an attribute. It might also be worth adding some error catching so that an error in the tracing code doesn't result in the function not being called... but I'm not sure where that would go. |
Thanks for the detailed feedback. We'll get this prioritized. Appreciate it. |
Describe the bug
When using instructor, one of the things you pass to the
client.chat.completions.create
is a Pydantic model type for the kwargresponse_model
. When openinference instruments instructor, it takes all kwargs to theclient.chat.completions.create
and tries to save them as attributes. Unfortunately, it doesn't expect to get anything that isn't a standard type (or sequence of standard types), and themask
operation for a span when saving attributes returns with:return value() if callable(value) else value
which (in my case) tries to instantiate a pydantic type that can't be instantiated without arguments.
I would be happy to put together a pull request for this, however I'm not sure where the problem should be fixed. Should it be fixed in the mask function? or in the instructor _wrapped.py
patched_new_func
where it creates the dictionary of attributes (by stringifying all inputs), or in _WrappedSpan.set_attributes where it can check if a value isn't a AttributeValue and stringily it or similar before it passes it to _WrappedSpan.set_attribute.Let me know where you think this should be fixed.
The text was updated successfully, but these errors were encountered: