| Total Complexity | 4 |
| Total Lines | 48 |
| Duplicated Lines | 0 % |
| Changes | 0 | ||
| 1 | from __future__ import print_function |
||
| 2 | |||
| 3 | import itertools |
||
| 4 | from datetime import datetime, timedelta |
||
| 5 | |||
| 6 | import faker |
||
| 7 | import pytest |
||
| 8 | from sqlalchemy import create_engine |
||
| 9 | from sqlalchemy.orm import sessionmaker |
||
| 10 | |||
| 11 | from .models import Address, Base, User |
||
| 12 | |||
| 13 | |||
| 14 | def populate(session): |
||
| 15 | """Create 3 adresses and 50 users.""" |
||
| 16 | users = [] |
||
| 17 | f = faker.Faker(seed=1) |
||
| 18 | addresses = [Address(description=d) for d in ['Street', 'Avenue', 'Road']] |
||
| 19 | session.add_all(addresses) |
||
| 20 | |||
| 21 | for i, addr in zip(range(0, 50), itertools.cycle(addresses)): |
||
| 22 | user = User( |
||
| 23 | name=f.name(), |
||
| 24 | address=addr, |
||
| 25 | birthday=datetime(1970, 1, 2) + timedelta(days=10 * i)) |
||
| 26 | users.append(user) |
||
| 27 | |||
| 28 | session.add_all(users) |
||
| 29 | session.commit() |
||
| 30 | |||
| 31 | |||
| 32 | @pytest.fixture(scope="session") |
||
| 33 | def engine(): |
||
| 34 | print("TestCase: Using sqlite database") |
||
| 35 | return create_engine('sqlite:///', echo=False) |
||
| 36 | |||
| 37 | |||
| 38 | @pytest.fixture(scope="session") |
||
| 39 | def session(engine): |
||
| 40 | sessionmaker_ = sessionmaker(bind=engine) |
||
| 41 | session = sessionmaker_() |
||
| 42 | Base.metadata.create_all(engine) |
||
| 43 | populate(session) |
||
| 44 | |||
| 45 | yield session |
||
| 46 | |||
| 47 | session.close() |
||
| 48 |