update docs, fix for ellipsis for whole model, some more tests
This commit is contained in:
@ -176,27 +176,27 @@ async def test_sort_order_on_related_model():
|
||||
|
||||
owner = (
|
||||
await Owner.objects.select_related("toys")
|
||||
.order_by("toys__name")
|
||||
.filter(name="Zeus")
|
||||
.get()
|
||||
.order_by("toys__name")
|
||||
.filter(name="Zeus")
|
||||
.get()
|
||||
)
|
||||
assert owner.toys[0].name == "Toy 1"
|
||||
assert owner.toys[1].name == "Toy 4"
|
||||
|
||||
owner = (
|
||||
await Owner.objects.select_related("toys")
|
||||
.order_by("-toys__name")
|
||||
.filter(name="Zeus")
|
||||
.get()
|
||||
.order_by("-toys__name")
|
||||
.filter(name="Zeus")
|
||||
.get()
|
||||
)
|
||||
assert owner.toys[0].name == "Toy 4"
|
||||
assert owner.toys[1].name == "Toy 1"
|
||||
|
||||
owners = (
|
||||
await Owner.objects.select_related("toys")
|
||||
.order_by("-toys__name")
|
||||
.filter(name__in=["Zeus", "Hermes"])
|
||||
.all()
|
||||
.order_by("-toys__name")
|
||||
.filter(name__in=["Zeus", "Hermes"])
|
||||
.all()
|
||||
)
|
||||
assert owners[0].toys[0].name == "Toy 6"
|
||||
assert owners[0].toys[1].name == "Toy 5"
|
||||
@ -210,9 +210,9 @@ async def test_sort_order_on_related_model():
|
||||
|
||||
owners = (
|
||||
await Owner.objects.select_related("toys")
|
||||
.order_by("-toys__name")
|
||||
.filter(name__in=["Zeus", "Hermes"])
|
||||
.all()
|
||||
.order_by("-toys__name")
|
||||
.filter(name__in=["Zeus", "Hermes"])
|
||||
.all()
|
||||
)
|
||||
assert owners[0].toys[0].name == "Toy 7"
|
||||
assert owners[0].toys[1].name == "Toy 4"
|
||||
@ -252,9 +252,9 @@ async def test_sort_order_on_many_to_many():
|
||||
|
||||
user = (
|
||||
await User.objects.select_related("cars")
|
||||
.filter(name="Mark")
|
||||
.order_by("cars__name")
|
||||
.get()
|
||||
.filter(name="Mark")
|
||||
.order_by("cars__name")
|
||||
.get()
|
||||
)
|
||||
assert user.cars[0].name == "Buggy"
|
||||
assert user.cars[1].name == "Ferrari"
|
||||
@ -263,9 +263,9 @@ async def test_sort_order_on_many_to_many():
|
||||
|
||||
user = (
|
||||
await User.objects.select_related("cars")
|
||||
.filter(name="Mark")
|
||||
.order_by("-cars__name")
|
||||
.get()
|
||||
.filter(name="Mark")
|
||||
.order_by("-cars__name")
|
||||
.get()
|
||||
)
|
||||
assert user.cars[3].name == "Buggy"
|
||||
assert user.cars[2].name == "Ferrari"
|
||||
@ -281,8 +281,8 @@ async def test_sort_order_on_many_to_many():
|
||||
|
||||
users = (
|
||||
await User.objects.select_related(["cars", "cars__factory"])
|
||||
.order_by(["-cars__factory__name", "cars__name"])
|
||||
.all()
|
||||
.order_by(["-cars__factory__name", "cars__name"])
|
||||
.all()
|
||||
)
|
||||
|
||||
assert users[0].name == "Julie"
|
||||
@ -328,8 +328,8 @@ async def test_sort_order_with_aliases():
|
||||
|
||||
aliases = (
|
||||
await AliasTest.objects.select_related("nested")
|
||||
.order_by("-nested__name")
|
||||
.all()
|
||||
.order_by("-nested__name")
|
||||
.all()
|
||||
)
|
||||
assert aliases[0].nested.name == "Try4"
|
||||
assert aliases[1].nested.name == "Try3"
|
||||
|
||||
@ -193,7 +193,13 @@ async def test_selecting_subset():
|
||||
assert car.manufacturer.hq.name is None
|
||||
|
||||
all_cars_check = await Car.objects.select_related("manufacturer").all()
|
||||
for car in all_cars_check:
|
||||
all_cars_with_whole_nested = (
|
||||
await Car.objects.select_related("manufacturer")
|
||||
.fields(["id", "name", "year", "gearbox_type", "gears", "aircon_type"])
|
||||
.fields({"manufacturer": ...})
|
||||
.all()
|
||||
)
|
||||
for car in itertools.chain(all_cars_check, all_cars_with_whole_nested):
|
||||
assert all(
|
||||
getattr(car, x) is not None
|
||||
for x in ["year", "gearbox_type", "gears", "aircon_type"]
|
||||
@ -201,6 +207,18 @@ async def test_selecting_subset():
|
||||
assert car.manufacturer.name == "Toyota"
|
||||
assert car.manufacturer.founded == 1937
|
||||
|
||||
all_cars_dummy = (
|
||||
await Car.objects.select_related("manufacturer")
|
||||
.fields(["id", "name", "year", "gearbox_type", "gears", "aircon_type"])
|
||||
.fields({"manufacturer": ...})
|
||||
.exclude_fields({"manufacturer": ...})
|
||||
.fields({"manufacturer": {"name"}})
|
||||
.exclude_fields({"manufacturer__founded"})
|
||||
.all()
|
||||
)
|
||||
|
||||
assert all_cars_dummy[0].manufacturer.founded is None
|
||||
|
||||
with pytest.raises(pydantic.error_wrappers.ValidationError):
|
||||
# cannot exclude mandatory model columns - company__name in this example
|
||||
await Car.objects.select_related("manufacturer").fields(
|
||||
|
||||
Reference in New Issue
Block a user