55 lines
1.2 KiB
Python
55 lines
1.2 KiB
Python
from fastapi.testclient import TestClient
|
|
from sqlalchemy import create_engine
|
|
from sqlalchemy.orm import sessionmaker
|
|
from sqlalchemy.pool import StaticPool
|
|
|
|
from database import Base
|
|
from dev import app, get_db
|
|
from models import Movie
|
|
|
|
|
|
SQLALCHEMY_DATABASE_URL = "sqlite://"
|
|
|
|
engine = create_engine(
|
|
SQLALCHEMY_DATABASE_URL,
|
|
connect_args={"check_same_thread": False},
|
|
poolclass=StaticPool,
|
|
)
|
|
TestingSessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
|
|
|
|
|
Base.metadata.create_all(bind=engine)
|
|
|
|
|
|
def override_get_db():
|
|
try:
|
|
db = TestingSessionLocal()
|
|
yield db
|
|
finally:
|
|
db.close()
|
|
|
|
|
|
app.dependency_overrides[get_db] = override_get_db
|
|
|
|
client = TestClient(app)
|
|
|
|
|
|
def test_create_moviem_models():
|
|
import random
|
|
|
|
name = f"rand_{random.randint(1, 1000)}"
|
|
movie = Movie(name=name)
|
|
assert movie.name == name
|
|
|
|
|
|
def test_create_movie_api():
|
|
import random
|
|
|
|
name = f"rand_{random.randint(1, 1000)}"
|
|
response = client.post("/movies/", json={"name": name})
|
|
assert response.status_code == 200
|
|
movie_id = response.json()["id"]
|
|
assert f"Created {name}" in response.json()["message"]
|
|
response = client.get(f"/movies/{movie_id}")
|
|
assert response.json()["name"] == name
|