CICD/app/other_api/doodad/service_test.py

61 lines
1.7 KiB
Python
Raw Permalink Normal View History

2019-05-18 19:47:47 +02:00
from flask_sqlalchemy import SQLAlchemy
from typing import List
from app.test.fixtures import app, db # noqa
from .model import Doodad
from .service import DoodadService # noqa
from .interface import DoodadInterface
def test_get_all(db: SQLAlchemy): # noqa
2019-08-03 18:55:38 +02:00
yin: Doodad = Doodad(doodad_id=1, name="Yin", purpose="thing 1")
yang: Doodad = Doodad(doodad_id=2, name="Yang", purpose="thing 2")
2019-05-18 19:47:47 +02:00
db.session.add(yin)
db.session.add(yang)
db.session.commit()
results: List[Doodad] = DoodadService.get_all()
assert len(results) == 2
assert yin in results and yang in results
def test_update(db: SQLAlchemy): # noqa
2019-08-03 18:55:38 +02:00
yin: Doodad = Doodad(doodad_id=1, name="Yin", purpose="thing 1")
2019-05-18 19:47:47 +02:00
db.session.add(yin)
db.session.commit()
2019-08-03 18:55:38 +02:00
updates: DoodadInterface = dict(name="New Doodad name")
2019-05-18 19:47:47 +02:00
DoodadService.update(yin, updates)
result: Doodad = Doodad.query.get(yin.doodad_id)
2019-08-03 18:55:38 +02:00
assert result.name == "New Doodad name"
2019-05-18 19:47:47 +02:00
def test_delete_by_id(db: SQLAlchemy): # noqa
2019-08-03 18:55:38 +02:00
yin: Doodad = Doodad(doodad_id=1, name="Yin", purpose="thing 1")
yang: Doodad = Doodad(doodad_id=2, name="Yang", purpose="thing 2")
2019-05-18 19:47:47 +02:00
db.session.add(yin)
db.session.add(yang)
db.session.commit()
DoodadService.delete_by_id(1)
db.session.commit()
results: List[Doodad] = Doodad.query.all()
assert len(results) == 1
assert yin not in results and yang in results
def test_create(db: SQLAlchemy): # noqa
2019-08-03 18:55:38 +02:00
yin: DoodadInterface = dict(name="Fancy new doodad", purpose="Fancy new purpose")
2019-05-18 19:47:47 +02:00
DoodadService.create(yin)
results: List[Doodad] = Doodad.query.all()
assert len(results) == 1
for k in yin.keys():
assert getattr(results[0], k) == yin[k]