pass the tests

This commit is contained in:
Waylon Walker 2023-05-22 10:03:25 -05:00
parent 0eb29bdc10
commit daf81343bf
No known key found for this signature in database
GPG key ID: 66E2BF2B4190EFE4
3 changed files with 64 additions and 13 deletions

View file

@ -2,10 +2,9 @@ from typing import List, Union
from pydantic_typer import expand_pydantic_args
from rich.console import Console
from sqlmodel import SQLModel
import typer
from learn_sql_model.config import Config, get_config
from learn_sql_model.config import Config
from learn_sql_model.factories.hero import HeroFactory
from learn_sql_model.factories.pet import PetFactory
from learn_sql_model.models.hero import Hero
@ -17,12 +16,16 @@ hero_app = typer.Typer()
@hero_app.callback()
def hero():
"model cli"
SQLModel.metadata.create_all(get_config().database.engine)
@hero_app.command()
def get(id: int = None) -> Union[Hero, List[Hero]]:
@expand_pydantic_args(typer=True)
def get(
id: int = None,
config: Config = None,
) -> Union[Hero, List[Hero]]:
"get one hero"
config.init()
hero = Hero().get(id=id)
Console().print(hero)
return hero
@ -36,6 +39,7 @@ def create(
config: Config = None,
) -> Hero:
"read all the heros"
config.init()
hero.pet = pet
hero = hero.post(config=config)
Console().print(hero)
@ -48,6 +52,7 @@ def populate(
config: Config = None,
) -> Hero:
"read all the heros"
config.init()
if config is None:
config = Config()
if config.env == "prod":

View file

@ -2,7 +2,7 @@ from typing import TYPE_CHECKING
from pydantic import BaseModel, BaseSettings
from sqlalchemy import create_engine
from sqlmodel import Session
from sqlmodel import SQLModel, Session
from learn_sql_model.standard_config import load
@ -24,7 +24,6 @@ class Database:
self.config = get_config()
else:
self.config = config
self.create_db_and_tables()
@property
def engine(self) -> "Engine":
@ -49,6 +48,9 @@ class Config(BaseSettings):
def database(self) -> Database:
return get_database(config=self)
def init(self) -> None:
SQLModel.metadata.create_all(self.database.engine)
def get_database(config: Config = None) -> Database:

View file

@ -1,12 +1,17 @@
import tempfile
from fastapi.testclient import TestClient
import pytest
from typer.testing import CliRunner
from learn_sql_model.api.app import app
from learn_sql_model.cli.hero import hero_app
from learn_sql_model.config import Config, get_config
from learn_sql_model.factories.hero import HeroFactory
from learn_sql_model.models.hero import Hero
Hero
runner = CliRunner()
client = TestClient(app)
@pytest.fixture
@ -17,18 +22,57 @@ def config() -> Config:
def test_post_hero(config: Config) -> None:
config.init() # required for python api, and no existing db
hero = HeroFactory().build(name="Batman", age=50, id=1)
hero = hero.post(config=config)
db_hero = Hero().get(hero.id, config=config)
assert db_hero == hero
db_hero = Hero().get(id=1, config=config)
assert db_hero.age == 50
assert db_hero.name == "Batman"
def test_update_hero(config: Config) -> None:
config.init() # required for python api, and no existing db
hero = HeroFactory().build(name="Batman", age=50, id=1)
hero = hero.post(config=config)
db_hero = Hero().get(id=hero.id, config=config)
assert db_hero.dict() == hero.dict()
db_hero = Hero().get(id=1, config=config)
db_hero.name = "Superman"
hero = db_hero.post(config=config)
db_hero = Hero().get(id=hero.id, config=config)
assert db_hero.dict() == hero.dict()
db_hero = Hero().get(id=1, config=config)
assert db_hero.age == 50
assert db_hero.name == "Superman"
def test_cli_create(config):
result = runner.invoke(
hero_app,
[
"create",
"--name",
"Darth Vader",
"--secret-name",
"Anakin",
"--id",
"2",
"--age",
"100",
"--database-url",
config.database_url,
],
)
assert result.exit_code == 0
db_hero = Hero().get(id=2, config=config)
assert db_hero.age == 100
assert db_hero.name == "Darth Vader"
def test_read_main(config):
config.init()
hero = HeroFactory().build(name="Ironman", age=25, id=99)
hero_id = hero.id
hero = hero.post(config=config)
response = client.get(f"/hero/{hero_id}")
assert response.status_code == 200
reponse_hero = Hero.parse_obj(response.json())
assert reponse_hero.id == hero_id
assert reponse_hero.name == "Ironman"
assert reponse_hero.age == 25