2021-08-24 13:15:26 +00:00
|
|
|
from unittest.mock import patch
|
|
|
|
|
|
|
|
import pytest
|
2021-08-24 13:41:03 +00:00
|
|
|
from sqlalchemy.exc import MultipleResultsFound
|
|
|
|
from sqlmodel import Session, create_engine, delete
|
2021-08-24 13:15:26 +00:00
|
|
|
|
|
|
|
from ...conftest import get_testing_print_function
|
|
|
|
|
|
|
|
|
|
|
|
def test_tutorial(clear_sqlmodel):
|
|
|
|
from docs_src.tutorial.one import tutorial004 as mod
|
|
|
|
|
|
|
|
mod.sqlite_url = "sqlite://"
|
|
|
|
mod.engine = create_engine(mod.sqlite_url)
|
|
|
|
with pytest.raises(MultipleResultsFound):
|
|
|
|
mod.main()
|
|
|
|
with Session(mod.engine) as session:
|
|
|
|
# TODO: create delete() function
|
|
|
|
# TODO: add overloads for .exec() with delete object
|
|
|
|
session.exec(delete(mod.Hero))
|
|
|
|
session.add(mod.Hero(name="Test Hero", secret_name="Secret Test Hero", age=24))
|
|
|
|
session.commit()
|
|
|
|
|
|
|
|
calls = []
|
|
|
|
|
|
|
|
new_print = get_testing_print_function(calls)
|
|
|
|
|
|
|
|
with patch("builtins.print", new=new_print):
|
|
|
|
mod.select_heroes()
|
|
|
|
assert calls == [
|
|
|
|
[
|
|
|
|
"Hero:",
|
|
|
|
{
|
|
|
|
"id": 1,
|
|
|
|
"name": "Test Hero",
|
|
|
|
"secret_name": "Secret Test Hero",
|
|
|
|
"age": 24,
|
|
|
|
},
|
|
|
|
]
|
|
|
|
]
|