from fastapi.testclient import TestClient from sqlalchemy import create_engine from sqlalchemy.orm import sessionmaker from main import app from models import Base from main import get_db engine = create_engine("sqlite:///:memory:", connect_args={"check_same_thread": False}) TestSession = sessionmaker(bind=engine) Base.metadata.create_all(bind=engine) def override_get_db(): db = TestSession() try: yield db finally: db.close() app.dependency_overrides[get_db] = override_get_db client = TestClient(app) def test_create_task(): response = client.post("/tasks/", json={"title": "Test Task", "due_date": "2023-12-31"}) assert response.status_code == 201 assert response.json()["title"] == "Test Task" assert response.json()["status"] == "pending" def test_read_tasks(): client.post("/tasks/", json={"title": "Task 1", "due_date": "2023-12-31"}) client.post("/tasks/", json={"title": "Task 2", "due_date": "2024-01-01"}) response = client.get("/tasks/") assert response.status_code == 200 assert len(response.json()) == 2 def test_read_task(): task = client.post("/tasks/", json={"title": "Test Task", "due_date": "2023-12-31"}).json() response = client.get(f"/tasks/{task['id']}") assert response.status_code == 200 assert response.json()["id"] == task["id"] def test_read_task_not_found(): response = client.get("/tasks/999") assert response.status_code == 404 def test_update_task(): task = client.post("/tasks/", json={"title": "Test Task", "due_date": "2023-12-31"}).json() response = client.put(f"/tasks/{task['id']}", json={"status": "completed"}) assert response.status_code == 200 assert response.json()["status"] == "completed" def test_delete_task(): task = client.post("/tasks/", json={"title": "Test Task", "due_date": "2023-12-31"}).json() response = client.delete(f"/tasks/{task['id']}") assert response.status_code == 204 response = client.get(f"/tasks/{task['id']}") assert response.status_code == 404