-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_data.py
More file actions
74 lines (59 loc) · 2.83 KB
/
test_data.py
File metadata and controls
74 lines (59 loc) · 2.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
from datetime import date
from models.database import SessionLocal
from models.entities import Counterparty, Invoice
def populate_test_data():
# Открываем сессию (соединение) с базой
db = SessionLocal()
try:
print("Добавляем тестовые данные...")
# Создаем Контрагента (поставщика)
supplier_1 = Counterparty(
name="ООО Абоба Индастрис"
)
# Добавляем в сессию
db.add(supplier_1)
# Делаем commit, чтобы данные улетели в базу
db.commit()
# Делаем refresh, чтобы получить присвоенный ID (он создается базой)
db.refresh(supplier_1)
print(f"-> Добавлен поставщик: {supplier_1.name} (ID: {supplier_1.id})")
# примеры счетов для этого поставщика
# Счет 1 (Нужно оплатить через 2 недели)
invoice_1 = Invoice(
counterparty_id=supplier_1.id, # Ссылаемся на ID созданного выше поставщика
invoice_number="ТК-001/24",
amount=150000.00,
invoice_date=date(2025, 12, 1),
supply_date=date(2025, 12, 5), # Поставка 5 декабря
deadline_date=date(2025, 12, 19),
is_paid=False,
payment_date=None
)
# Счет 2 (Уже оплачен)
invoice_2 = Invoice(
counterparty_id=supplier_1.id,
invoice_number="ТК-002/24",
amount=5600.50,
invoice_date=date(2025, 11, 20),
supply_date=date(2025, 11, 22),
deadline_date=date(2025, 11, 27),
is_paid=True, # поле "Оплачено"
payment_date=date(2025, 11, 26) # Дата фактической оплаты
)
db.add(invoice_1)
db.add(invoice_2)
db.commit()
print(f"-> Добавлены счета: {invoice_1.invoice_number} и {invoice_2.invoice_number}")
# Проверка чтения
print("\nПроверяем, что записалось в базу:")
saved_supplier = db.query(Counterparty).first()
print(f"Поставщик: {saved_supplier.name}")
for inv in saved_supplier.invoices:
print(f" - Счет {inv.invoice_number} на сумму {inv.amount} руб. (Оплатить до: {inv.deadline_date})")
except Exception as e:
print(f"ОШИБКА: {e}")
db.rollback() # Если ошибка, отменяем изменения
finally:
db.close() # Закрываем соединение
if __name__ == "__main__":
populate_test_data()