Coverage for tests / test_tutorial / test_indexes / test_tutorial001.py: 100%

23 statements  

« prev     ^ index     » next       coverage.py v7.13.0, created at 2026-01-06 21:09 +0000

1import importlib 1abcdefghi

2from types import ModuleType 1abcdefghi

3 

4import pytest 1abcdefghi

5from sqlalchemy import inspect 1abcdefghi

6from sqlalchemy.engine.reflection import Inspector 1abcdefghi

7from sqlmodel import create_engine 1abcdefghi

8 

9from ...conftest import PrintMock, needs_py310 1abcdefghi

10 

11 

12@pytest.fixture( 1abcdefghi

13 name="mod", 

14 params=[ 

15 pytest.param("tutorial001_py39"), 

16 pytest.param("tutorial001_py310", marks=needs_py310), 

17 ], 

18) 

19def get_module(request: pytest.FixtureRequest) -> ModuleType: 1abcdefghi

20 mod = importlib.import_module(f"docs_src.tutorial.indexes.{request.param}") 1abcdefghi

21 mod.sqlite_url = "sqlite://" 1abcdefghi

22 mod.engine = create_engine(mod.sqlite_url) 1abcdefghi

23 return mod 1abcdefghi

24 

25 

26def test_tutorial(print_mock: PrintMock, mod: ModuleType): 1abcdefghi

27 mod.main() 1jklmnopqr

28 assert print_mock.calls == [ 1jklmnopqr

29 [{"secret_name": "Dive Wilson", "age": None, "id": 1, "name": "Deadpond"}] 

30 ] 

31 

32 insp: Inspector = inspect(mod.engine) 1jklmnopqr

33 indexes = insp.get_indexes(str(mod.Hero.__tablename__)) 1jklmnopqr

34 expected_indexes = [ 1jklmnopqr

35 { 

36 "name": "ix_hero_name", 

37 "dialect_options": {}, 

38 "column_names": ["name"], 

39 "unique": 0, 

40 }, 

41 { 

42 "name": "ix_hero_age", 

43 "dialect_options": {}, 

44 "column_names": ["age"], 

45 "unique": 0, 

46 }, 

47 ] 

48 for index in expected_indexes: 1jklmnopqr

49 assert index in indexes, "This expected index should be in the indexes in DB" 1jklmnopqr

50 # Now that this index was checked, remove it from the list of indexes 

51 indexes.pop(indexes.index(index)) 1jklmnopqr

52 assert len(indexes) == 0, "The database should only have the expected indexes" 1jklmnopqr