mirror of
https://github.com/aljazceru/goose.git
synced 2026-01-06 07:54:23 +01:00
feat: track cost and token usage in log file (#80)
This commit is contained in:
38
tests/utils/test_cost_calculator.py
Normal file
38
tests/utils/test_cost_calculator.py
Normal file
@@ -0,0 +1,38 @@
|
||||
from goose.utils._cost_calculator import _calculate_cost, get_total_cost_message
|
||||
from exchange.providers.base import Usage
|
||||
|
||||
|
||||
def test_calculate_cost():
|
||||
cost = _calculate_cost("gpt-4o", Usage(input_tokens=10000, output_tokens=600, total_tokens=10600))
|
||||
assert cost == 0.059
|
||||
|
||||
|
||||
def test_get_total_cost_message():
|
||||
message = get_total_cost_message(
|
||||
{
|
||||
"gpt-4o": Usage(input_tokens=10000, output_tokens=600, total_tokens=10600),
|
||||
"gpt-4o-mini": Usage(input_tokens=3000000, output_tokens=4000000, total_tokens=7000000),
|
||||
}
|
||||
)
|
||||
expected_message = (
|
||||
"Cost for model gpt-4o Usage(input_tokens=10000, output_tokens=600, total_tokens=10600): $0.06\n"
|
||||
+ "Cost for model gpt-4o-mini Usage(input_tokens=3000000, output_tokens=4000000, total_tokens=7000000)"
|
||||
+ ": $2.85\nTotal cost: $2.91"
|
||||
)
|
||||
assert message == expected_message
|
||||
|
||||
|
||||
def test_get_total_cost_message_with_non_available_pricing():
|
||||
message = get_total_cost_message(
|
||||
{
|
||||
"non_pricing_model": Usage(input_tokens=10000, output_tokens=600, total_tokens=10600),
|
||||
"gpt-4o-mini": Usage(input_tokens=3000000, output_tokens=4000000, total_tokens=7000000),
|
||||
}
|
||||
)
|
||||
expected_message = (
|
||||
"Cost for model non_pricing_model Usage(input_tokens=10000, output_tokens=600, total_tokens=10600): "
|
||||
+ "Not available\n"
|
||||
+ "Cost for model gpt-4o-mini Usage(input_tokens=3000000, output_tokens=4000000, total_tokens=7000000)"
|
||||
+ ": $2.85\nTotal cost: $2.85"
|
||||
)
|
||||
assert message == expected_message
|
||||
Reference in New Issue
Block a user