Skip to content

Commit

Permalink
Merge branch 'main' into feat/openai-assistants-beta
Browse files Browse the repository at this point in the history
  • Loading branch information
the-praxs authored Dec 29, 2024
2 parents 71791d1 + 82f9bb9 commit a6de520
Show file tree
Hide file tree
Showing 3 changed files with 87 additions and 1 deletion.
2 changes: 1 addition & 1 deletion agentops/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@
import threading
import traceback
from decimal import Decimal
from functools import cached_property
from typing import List, Optional, Tuple, Union
from uuid import UUID, uuid4

Expand All @@ -28,6 +27,7 @@
from .meta_client import MetaClient
from .session import Session, active_sessions
from .singleton import conditional_singleton
from .helpers import cached_property


@conditional_singleton
Expand Down
19 changes: 19 additions & 0 deletions agentops/helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -174,3 +174,22 @@ def wrapper(self, *args, **kwargs):
return func(self, *args, **kwargs)

return wrapper


class cached_property:
"""
Decorator that converts a method with a single self argument into a
property cached on the instance.
See: https://github.com/AgentOps-AI/agentops/issues/612
"""

def __init__(self, func):
self.func = func
self.__doc__ = func.__doc__

def __get__(self, instance, cls=None):
if instance is None:
return self
value = self.func(instance)
setattr(instance, self.func.__name__, value)
return value
67 changes: 67 additions & 0 deletions tests/test_helpers.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
import pytest
from agentops.helpers import cached_property


def test_cached_property():
class TestClass:
def __init__(self):
self.compute_count = 0

@cached_property
def expensive_computation(self):
self.compute_count += 1
return 42

# Create instance
obj = TestClass()

# First access should compute the value
assert obj.expensive_computation == 42
assert obj.compute_count == 1

# Second access should use cached value
assert obj.expensive_computation == 42
assert obj.compute_count == 1 # Count shouldn't increase

# Third access should still use cached value
assert obj.expensive_computation == 42
assert obj.compute_count == 1 # Count shouldn't increase


def test_cached_property_different_instances():
class TestClass:
def __init__(self):
self.compute_count = 0

@cached_property
def expensive_computation(self):
self.compute_count += 1
return id(self) # Return unique id for each instance

# Create two different instances
obj1 = TestClass()
obj2 = TestClass()

# Each instance should compute its own value
val1 = obj1.expensive_computation
val2 = obj2.expensive_computation

assert val1 != val2 # Values should be different
assert obj1.compute_count == 1
assert obj2.compute_count == 1

# Accessing again should use cached values
assert obj1.expensive_computation == val1
assert obj2.expensive_computation == val2
assert obj1.compute_count == 1 # Counts shouldn't increase
assert obj2.compute_count == 1


def test_cached_property_class_access():
class TestClass:
@cached_property
def expensive_computation(self):
return 42

# Accessing via class should return the descriptor
assert isinstance(TestClass.expensive_computation, cached_property)

0 comments on commit a6de520

Please sign in to comment.