mirror of
https://github.com/DRYTRIX/TimeTracker.git
synced 2026-01-06 03:30:25 -06:00
- Normalize line endings from CRLF to LF across all files to match .editorconfig - Standardize quote style from single quotes to double quotes - Normalize whitespace and formatting throughout codebase - Apply consistent code style across 372 files including: * Application code (models, routes, services, utils) * Test files * Configuration files * CI/CD workflows This ensures consistency with the project's .editorconfig settings and improves code maintainability.
100 lines
2.6 KiB
Python
100 lines
2.6 KiB
Python
import pytest
|
|
from datetime import date
|
|
|
|
from app import create_app, db
|
|
from app.models import User, Client, Project, Invoice, ApiToken
|
|
|
|
|
|
@pytest.fixture
|
|
def app():
|
|
app = create_app(
|
|
{
|
|
"TESTING": True,
|
|
"SQLALCHEMY_DATABASE_URI": "sqlite:///test_api_payments.sqlite",
|
|
"WTF_CSRF_ENABLED": False,
|
|
}
|
|
)
|
|
with app.app_context():
|
|
db.create_all()
|
|
yield app
|
|
db.session.remove()
|
|
db.drop_all()
|
|
|
|
|
|
@pytest.fixture
|
|
def client(app):
|
|
return app.test_client()
|
|
|
|
|
|
@pytest.fixture
|
|
def user(app):
|
|
u = User(username="payuser", email="payuser@example.com", role="admin")
|
|
u.is_active = True
|
|
db.session.add(u)
|
|
db.session.commit()
|
|
return u
|
|
|
|
|
|
@pytest.fixture
|
|
def api_token(app, user):
|
|
token, plain = ApiToken.create_token(
|
|
user_id=user.id, name="Payments Token", scopes="read:payments,write:payments,read:invoices"
|
|
)
|
|
db.session.add(token)
|
|
db.session.commit()
|
|
return plain
|
|
|
|
|
|
@pytest.fixture
|
|
def setup_invoice(app, user):
|
|
c = Client(name="Pay Client", email="client@example.com")
|
|
db.session.add(c)
|
|
db.session.commit()
|
|
p = Project(name="Pay Project", client_id=c.id, status="active")
|
|
db.session.add(p)
|
|
db.session.commit()
|
|
inv = Invoice(
|
|
invoice_number=Invoice.generate_invoice_number(),
|
|
project_id=p.id,
|
|
client_name=c.name,
|
|
client_id=c.id,
|
|
due_date=date.today(),
|
|
created_by=user.id,
|
|
)
|
|
db.session.add(inv)
|
|
db.session.commit()
|
|
return inv
|
|
|
|
|
|
def _auth(t):
|
|
return {"Authorization": f"Bearer {t}", "Content-Type": "application/json"}
|
|
|
|
|
|
def test_payments_crud(client, api_token, setup_invoice):
|
|
inv = setup_invoice
|
|
# list empty
|
|
r = client.get(f"/api/v1/payments?invoice_id={inv.id}", headers=_auth(api_token))
|
|
assert r.status_code == 200
|
|
assert r.get_json()["payments"] == []
|
|
|
|
# create
|
|
payload = {"invoice_id": inv.id, "amount": 100.0, "currency": "EUR", "method": "bank_transfer"}
|
|
r = client.post("/api/v1/payments", headers=_auth(api_token), json=payload)
|
|
assert r.status_code == 201
|
|
pay = r.get_json()["payment"]
|
|
pid = pay["id"]
|
|
assert pay["amount"] == 100.0
|
|
|
|
# get
|
|
r = client.get(f"/api/v1/payments/{pid}", headers=_auth(api_token))
|
|
assert r.status_code == 200
|
|
|
|
# update
|
|
r = client.patch(f"/api/v1/payments/{pid}", headers=_auth(api_token), json={"notes": "noted"})
|
|
assert r.status_code == 200
|
|
assert r.get_json()["payment"]["notes"] == "noted"
|
|
|
|
# delete
|
|
r = client.delete(f"/api/v1/payments/{pid}", headers=_auth(api_token))
|
|
assert r.status_code == 200
|