Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 4 additions & 3 deletions models.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
from sqlalchemy.orm import DeclarativeBase, Mapped, mapped_column
from sqlalchemy import String, Number
from sqlalchemy import String, Float
from pydantic import BaseModel, ConfigDict


Expand All @@ -18,14 +18,15 @@ class Book(Base):
id: Mapped[int] = mapped_column(primary_key=True, index=True)
title: Mapped[str] = mapped_column(String(255), index=True)
author: Mapped[str] = mapped_column(String(255))
price: Mapped[str] = mapped_column(Number(255), nullable=False)
price: Mapped[float] = mapped_column(Float, nullable=False)

# Pydantic models
class BookIn(BaseModel):
"""Pydantic model for book input"""

title: str
author: str
price: float


class BookOut(BaseModel):
Expand All @@ -35,4 +36,4 @@ class BookOut(BaseModel):
title: str
author: str

model_config = ConfigDict(from_attributes=True)
model_config = ConfigDict(from_attributes=True)
3 changes: 2 additions & 1 deletion repositories.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

# Create a new book
def create_book(db: Session, book: models.BookIn):
db_book = models.Book(title=book.title, author=book.author)
db_book = models.Book(title=book.title, author=book.author, price=book.price)
db.add(db_book)
db.commit()
db.refresh(db_book)
Expand All @@ -27,6 +27,7 @@ def update_book(db: Session, book_id: int, book: models.BookIn):
if db_book:
db_book.title = book.title
db_book.author = book.author
db_book.price = book.price
db.commit()
db.refresh(db_book)
return db_book
Expand Down
8 changes: 4 additions & 4 deletions test_main.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@

# Test data constants
TEST_BOOKS = [
{"title": "Carrie", "author": "Stephen King"},
{"title": "Ready Player One", "author": "Ernest Cline"},
{"title": "Carrie", "author": "Stephen King", "price": 9.99},
{"title": "Ready Player One", "author": "Ernest Cline", "price": 14.99},
]

class TestMainApp:
Expand Down Expand Up @@ -57,7 +57,7 @@ def test_update_book(self, test_db):

def test_delete_book(self, test_db):
"""Test deleting a book"""
book = create_book(test_db, BookIn(title="To Delete", author="Author"))
book = create_book(test_db, BookIn(title="To Delete", author="Author", price=19.99))
deleted_book = delete_book(test_db, book.id)

assert deleted_book is not None
Expand All @@ -67,5 +67,5 @@ def test_delete_book(self, test_db):
def test_nonexistent_operations(self, test_db):
"""Test operations on nonexistent books"""
assert get_book(test_db, 999999) is None
assert update_book(test_db, 999999, BookIn(title="Test", author="Test")) is None
assert update_book(test_db, 999999, BookIn(title="Test", author="Test", price=10.00)) is None
assert delete_book(test_db, 999999) is None