File: test_benchmark_values.py

package info (click to toggle)
ormar 0.20.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,136 kB
  • sloc: python: 23,758; makefile: 34; sh: 14
file content (29 lines) | stat: -rw-r--r-- 952 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
from typing import List

import pytest

from benchmarks.conftest import Author

pytestmark = pytest.mark.asyncio


@pytest.mark.parametrize("num_models", [250, 500, 1000])
async def test_values(aio_benchmark, num_models: int, authors_in_db: List[Author]):
    @aio_benchmark
    async def get_all_values(authors: List[Author]):
        return await Author.objects.values()

    authors_list = get_all_values(authors_in_db)
    for idx, author in enumerate(authors_in_db):
        assert authors_list[idx]["id"] == author.id


@pytest.mark.parametrize("num_models", [250, 500, 1000])
async def test_values_list(aio_benchmark, num_models: int, authors_in_db: List[Author]):
    @aio_benchmark
    async def get_all_values_list(authors: List[Author]):
        return await Author.objects.values_list()

    authors_list = get_all_values_list(authors_in_db)
    for idx, author in enumerate(authors_in_db):
        assert authors_list[idx][0] == author.id