93 lines
2.8 KiB
Python
93 lines
2.8 KiB
Python
import pytest
|
|
from fastapi.testclient import TestClient
|
|
from sqlalchemy import create_engine
|
|
from sqlalchemy.orm import sessionmaker
|
|
from sqlalchemy.pool import StaticPool
|
|
|
|
from app.core.auth import create_access_token
|
|
from app.core.database import Base, get_db
|
|
from app.main import app
|
|
from app.modules.auth.models import User
|
|
from app.modules.auth.service import hash_password
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
def override_db():
|
|
engine = create_engine(
|
|
"sqlite:///:memory:",
|
|
connect_args={"check_same_thread": False},
|
|
poolclass=StaticPool,
|
|
)
|
|
Base.metadata.create_all(bind=engine)
|
|
Session = sessionmaker(bind=engine)
|
|
session = Session()
|
|
app.dependency_overrides[get_db] = lambda: session
|
|
yield session
|
|
app.dependency_overrides.clear()
|
|
session.close()
|
|
Base.metadata.drop_all(bind=engine)
|
|
|
|
|
|
@pytest.fixture
|
|
def client():
|
|
return TestClient(app, follow_redirects=False)
|
|
|
|
|
|
@pytest.fixture
|
|
def auth_cookies(override_db):
|
|
user = User(username="testuser", full_name="Test User", pw_hash=hash_password("pw"))
|
|
override_db.add(user)
|
|
override_db.commit()
|
|
token = create_access_token(username="testuser", is_admin=False)
|
|
return {"access_token": token}
|
|
|
|
|
|
@pytest.fixture
|
|
def admin_cookies(override_db):
|
|
user = User(username="adminuser", full_name="Admin User", is_admin=True, pw_hash=hash_password("pw"))
|
|
override_db.add(user)
|
|
override_db.commit()
|
|
token = create_access_token(username="adminuser", is_admin=True)
|
|
return {"access_token": token}
|
|
|
|
|
|
def test_landing_accessible_without_auth(client):
|
|
response = client.get("/")
|
|
assert response.status_code == 200
|
|
assert "text/html" in response.headers["content-type"]
|
|
|
|
|
|
def test_landing_shows_no_modules_for_anonymous(client):
|
|
response = client.get("/")
|
|
assert response.status_code == 200
|
|
assert "RSS-Feed Server" not in response.text
|
|
|
|
|
|
def test_landing_shows_modules_for_authenticated(client, auth_cookies):
|
|
response = client.get("/", cookies=auth_cookies)
|
|
assert response.status_code == 200
|
|
assert "RSS-Feed Server" in response.text
|
|
|
|
|
|
def test_landing_contains_title(client):
|
|
response = client.get("/")
|
|
assert "University Process Hub" in response.text
|
|
|
|
|
|
def test_landing_info_strip_shows_db_mode(client, auth_cookies):
|
|
response = client.get("/", cookies=auth_cookies)
|
|
assert "SQLite" in response.text or "MariaDB" in response.text
|
|
|
|
|
|
def test_navbar_shows_login_button_for_anonymous(client):
|
|
response = client.get("/")
|
|
assert "Anmelden" in response.text
|
|
assert "Abmelden" not in response.text
|
|
|
|
|
|
def test_navbar_shows_username_and_logout_when_logged_in(client, auth_cookies):
|
|
response = client.get("/", cookies=auth_cookies)
|
|
assert "testuser" in response.text
|
|
assert "Abmelden" in response.text
|
|
assert "Anmelden" not in response.text
|