Files
TimeTracker/tests/test_api_audit_activities_v1.py
T
Dries Peeters 3641b277f5 Update tests
2026-03-08 06:50:42 +01:00

56 lines
1.3 KiB
Python

import pytest
pytestmark = [pytest.mark.api, pytest.mark.integration]
from app import create_app, db
from app.models import User, ApiToken
@pytest.fixture
def app():
app = create_app(
{
"TESTING": True,
"SQLALCHEMY_DATABASE_URI": "sqlite:///test_api_audit_activities.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 admin_user(app):
u = User(username="admin", email="admin@example.com", role="admin")
u.is_active = True
db.session.add(u)
db.session.commit()
return u
@pytest.fixture
def admin_token(app, admin_user):
token, plain = ApiToken.create_token(user_id=admin_user.id, name="Admin Token", scopes="admin:all,read:reports")
db.session.add(token)
db.session.commit()
return plain
def _auth(t):
return {"Authorization": f"Bearer {t}", "Content-Type": "application/json"}
def test_audit_and_activities_list(client, admin_token):
r = client.get("/api/v1/audit-logs", headers=_auth(admin_token))
assert r.status_code == 200
r = client.get("/api/v1/activities", headers=_auth(admin_token))
assert r.status_code == 200