-
Notifications
You must be signed in to change notification settings - Fork 267
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
[Fix] Removed unnecessarily changing tuple output to list output #608
Conversation
# If the function returns multiple values, record them all in the same event | ||
if isinstance(returns, tuple): | ||
returns = list(returns) | ||
|
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.
Instead of removing these functions, we can instead do what we intended at fist-- just return a tuple
if istinatnce(returns, tuple):
returns = tuple(returns)
Removing these lines of code altogether will have unintended consequences.
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.
May I ask what the suggested change does? It seems (in most cases) equivalent to removing the two lines of code.
Unfortunately your suggested change would still break the code I'm using, since the code checks the output of the function is an instance of a specific subclass of tuple
(more specifically, a custom namedtuple
). Maybe one could argue that this is bad practice, but I believe it's more important that a decorator that does logging doesn't change the output of the function.
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.
but AFAIK the only reason the tuple was being cast to a list was so that it can be dumped into a JSON, but json.dumps actually handles that automatically.
Indeed that should be handled by a JSONEncoder
which is where these sorts of casts belong
Left a review @zli11010-- should be an easy fix! Please let me know if it still causes problems with the repo you're trying |
@areibman can we have more documentation around the expected functionality of |
@areibman Since you had concerns about deleting the lines, I tried to keep the original semantics with the only change being fixing the fact that the type casting modified the output of the original function. Hopefully that's better! |
What's the status of this PR? |
@teocns can you take a stab at completing this? Just want to make sure we don’t have any downstream effects if we merge |
Codecov ReportAll modified and coverable lines are covered by tests ✅
Flags with carried forward coverage won't be shown. Click here to find out more.
|
Added tests to verify PR AgentOps-AI#608, which fixes decorators changing tuple outputs into lists. Checks: 1. Decorators keep the original return type for: - Simple tuples like (1, "test") - Named tuples like Point(x=1, y=2) - Nested tuples containing multiple values - Custom tuple types (fixing bug AgentOps-AI#607) 2. Tests also show that JSON handles tuples correctly without needing to convert them to lists first, proving the point that the conversion was unnecessary.
The removal of the tuple-to-list conversion seems to be the right approach; the conversion was actually unnecessary since:
Added some tests to ensure If this gets merged, we should open a ticket to unify: into:
|
Fix style in pr #608 Signed-off-by: Teo <[email protected]>
📥 Pull Request
📘 Description
Fixed this bug: #607
🧪 Testing
Ran my code that uses AgentOps and now it works. (Changing list to tuple doesn't affect what gets logged.)