Coverage for polar/models/discount_redemption.py: 91%
21 statements
« prev ^ index » next coverage.py v7.10.6, created at 2025-12-05 17:15 +0000
« prev ^ index » next coverage.py v7.10.6, created at 2025-12-05 17:15 +0000
1from typing import TYPE_CHECKING 1ab
2from uuid import UUID 1ab
4from sqlalchemy import ForeignKey, Uuid 1ab
5from sqlalchemy.orm import Mapped, declared_attr, mapped_column, relationship 1ab
7from polar.kit.db.models import RecordModel 1ab
9if TYPE_CHECKING: 9 ↛ 10line 9 didn't jump to line 10 because the condition on line 9 was never true1ab
10 from polar.models import Checkout, Discount, Subscription
13class DiscountRedemption(RecordModel): 1ab
14 __tablename__ = "discount_redemptions" 1ab
16 discount_id: Mapped[UUID] = mapped_column( 1ab
17 Uuid, ForeignKey("discounts.id", ondelete="cascade")
18 )
20 @declared_attr 1ab
21 def discount(cls) -> Mapped["Discount"]: 1ab
22 return relationship( 1ab
23 "Discount", lazy="raise", back_populates="discount_redemptions"
24 )
26 checkout_id: Mapped[UUID | None] = mapped_column( 1ab
27 Uuid, ForeignKey("checkouts.id", ondelete="cascade")
28 )
30 @declared_attr 1ab
31 def checkout(cls) -> Mapped["Checkout | None"]: 1ab
32 return relationship("Checkout", lazy="raise") 1ab
34 subscription_id: Mapped[UUID | None] = mapped_column( 1ab
35 Uuid, ForeignKey("subscriptions.id", ondelete="cascade")
36 )
38 @declared_attr 1ab
39 def subscription(cls) -> Mapped["Subscription | None"]: 1ab
40 return relationship("Subscription", lazy="raise") 1ab