litellm-mirror/litellm/tests/test_budget_manager.py
2023-09-09 20:06:09 -07:00

71 lines
No EOL
2.1 KiB
Python

#### What this tests ####
# This tests calling batch_completions by running 100 messages together
import sys, os
import traceback
sys.path.insert(
0, os.path.abspath("../..")
) # Adds the parent directory to the system path
import litellm
from litellm import BudgetManager, completion
budget_manager = BudgetManager(type="local")
## Scenario 1: User budget enough to make call
def test_user_budget_enough():
user = "1234"
# create a budget for a user
budget_manager.create_budget(total_budget=10, user=user)
# check if a given call can be made
data = {
"model": "gpt-3.5-turbo",
"messages": [{"role": "user", "content": "Hey, how's it going?"}]
}
model = data["model"]
messages = data["messages"]
if budget_manager.get_current_cost(user=user) <= budget_manager.get_total_budget(user):
response = completion(**data)
print(budget_manager.update_cost(completion_obj=response, user=user))
else:
response = "Sorry - no budget!"
print(f"response: {response}")
test_user_budget_enough()
## Scenario 2: User budget not enough to make call
def test_user_budget_not_enough():
user = "12345"
# create a budget for a user
budget_manager.create_budget(total_budget=0, user=user)
# check if a given call can be made
data = {
"model": "gpt-3.5-turbo",
"messages": [{"role": "user", "content": "Hey, how's it going?"}]
}
model = data["model"]
messages = data["messages"]
if budget_manager.get_current_cost(user=user) < budget_manager.get_total_budget(user=user):
response = completion(**data)
print(budget_manager.update_cost(completion_obj=response, user=user))
else:
response = "Sorry - no budget!"
print(f"response: {response}")
test_user_budget_not_enough()
## Scenario 3: Saving budget to disk
def test_budget_save_to_disk():
budget_manager.save_data()
test_budget_save_to_disk()
## Scenario 4: Loading budget from disk
def test_budget_load_from_disk():
budget_manager_2 = BudgetManager(type="local")
test_budget_load_from_disk()