Files
dibbler/tests/queries/test_adjust_interest.py
h7x4 0b59d469dd
All checks were successful
Run tests / run-tests (push) Successful in 56s
fixup! WIP
2025-12-08 21:04:49 +09:00

73 lines
1.9 KiB
Python

import pytest
from datetime import datetime
from sqlalchemy.orm import Session
from dibbler.models import Transaction, User
from dibbler.queries.adjust_interest import adjust_interest
from dibbler.queries.current_interest import current_interest
def test_adjust_interest_no_history(sql_session: Session) -> None:
user = User("Test User")
sql_session.add(user)
sql_session.commit()
adjust_interest(
sql_session,
user_id=user.id,
new_interest=3,
message="Setting initial interest rate",
)
sql_session.commit()
current_interest_rate = current_interest(sql_session)
assert current_interest_rate == 3
def test_adjust_interest_existing_history(sql_session: Session) -> None:
user = User("Test User")
sql_session.add(user)
sql_session.commit()
transactions = [
Transaction.adjust_interest(
time=datetime(2023, 10, 1, 9, 0, 0),
user_id=user.id,
interest_rate_percent=5,
message="Initial interest rate",
),
]
sql_session.add_all(transactions)
sql_session.commit()
current_interest_rate = current_interest(sql_session)
assert current_interest_rate == 5
adjust_interest(
sql_session,
user_id=user.id,
new_interest=2,
message="Adjusting interest rate",
)
sql_session.commit()
current_interest_rate = current_interest(sql_session)
assert current_interest_rate == 2
def test_adjust_interest_negative_failure(sql_session: Session) -> None:
user = User("Test User")
sql_session.add(user)
sql_session.commit()
with pytest.raises(ValueError, match="Interest rate cannot be negative"):
adjust_interest(
sql_session,
user_id=user.id,
new_interest=-1,
message="Attempting to set negative interest rate",
)