123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- import pytest
- from sqlalchemy.exc import OperationalError
- from sqlalchemy_utils.functions import create_database, drop_database
- from flaskbb.extensions import alembic, db
- from flaskbb.utils.populate import delete_settings_from_fixture, \
- create_settings_from_fixture, update_settings_from_fixture, \
- create_default_groups, create_test_data, insert_bulk_data, \
- create_welcome_forum, create_user
- from flaskbb.fixtures.groups import fixture as group_fixture
- from flaskbb.fixtures.settings import fixture as settings_fixture
- from flaskbb.user.models import Group, User
- from flaskbb.forum.models import Category, Topic, Post
- from flaskbb.management.models import Setting, SettingsGroup
- def _individual_settings(update_result):
- """Helper that returns the number of settings that were updated."""
- return sum(
- len(settings_in_a_group)
- for settings_in_a_group in update_result.values()
- )
- def test_delete_settings_from_fixture(default_settings):
- groups_count = SettingsGroup.query.count()
- assert len(settings_fixture) == groups_count
- deleted = delete_settings_from_fixture(settings_fixture)
- assert len(settings_fixture) == len(deleted)
- assert not SettingsGroup.query.count()
- assert not Setting.query.count()
- def test_create_settings_from_fixture(database):
- assert not SettingsGroup.query.count()
- assert not Setting.query.count()
- created = create_settings_from_fixture(settings_fixture)
- assert len(settings_fixture) == len(created)
- assert SettingsGroup.query.count() == len(created)
- def test_update_settings_from_fixture(database):
- settings_fixture_group_count = len(settings_fixture)
- settings_fixture_setting_count = sum(
- len(settings_fixture[k][1]['settings'])
- for k in range(len(settings_fixture))
- )
- assert not SettingsGroup.query.count()
- assert not Setting.query.count()
- # No force-overwrite - the fixtures will be created because they
- # do not exist.
- updated = update_settings_from_fixture(settings_fixture)
- assert settings_fixture_group_count == len(updated)
- assert settings_fixture_group_count == SettingsGroup.query.count()
- assert settings_fixture_setting_count == _individual_settings(updated)
- assert settings_fixture_setting_count == Setting.query.count()
- def test_update_settings_from_fixture_overwrite(database, default_settings,
- updated_fixture):
- # should add groups: testgroup
- # should add testgroup/monty_python, general/test_fixture
- pre_update_group_count = SettingsGroup.query.count()
- pre_update_setting_count = Setting.query.count()
- updated = update_settings_from_fixture(updated_fixture)
- assert len(updated) == 2
- assert _individual_settings(updated) == 2
- assert pre_update_group_count + 1 == SettingsGroup.query.count()
- assert pre_update_setting_count + 2 == Setting.query.count()
- def test_update_settings_from_fixture_force(database, default_settings,
- updated_fixture):
- # force-overwrite - nothing changed so nothing should happen here
- pre_update_group_count = SettingsGroup.query.count()
- pre_update_setting_count = Setting.query.count()
- force_updated = update_settings_from_fixture(settings_fixture,
- overwrite_group=True,
- overwrite_setting=True)
- assert len(force_updated) == 0
- assert _individual_settings(force_updated) == 0
- assert pre_update_group_count == SettingsGroup.query.count()
- assert pre_update_setting_count == Setting.query.count()
- # should update groups: general
- # should update settings: 2 in general, 1 in testgroup
- force_updated_1 = update_settings_from_fixture(updated_fixture,
- overwrite_group=True,
- overwrite_setting=True)
- assert len(force_updated_1) == 2
- assert _individual_settings(force_updated_1) == 3
- assert pre_update_group_count + 1 == SettingsGroup.query.count()
- assert pre_update_setting_count + 2 == Setting.query.count()
- def test_create_user(default_groups):
- user = User.query.filter_by(username="admin").first()
- assert not user
- user = create_user(username="admin", password="test",
- email="test@example.org", groupname="admin")
- assert user.username == "admin"
- assert user.permissions["admin"]
- def test_create_welcome_forum(default_groups):
- assert not create_welcome_forum()
- create_user(username="admin", password="test",
- email="test@example.org", groupname="admin")
- assert create_welcome_forum()
- def test_create_test_data(database):
- assert Category.query.count() == 0
- data_created = create_test_data()
- assert Category.query.count() == data_created['categories']
- def test_insert_bulk_data(database):
- assert not insert_bulk_data(topic_count=1, post_count=1)
- create_test_data(categories=1, forums=1, topics=0)
- assert Topic.query.count() == 0
- topics, posts = insert_bulk_data(topic_count=1, post_count=1)
- assert Topic.query.count() == topics
- # -1 bc the topic post also counts as post
- assert Post.query.count() - 1 == posts
- def test_create_default_groups(database):
- """Test that the default groups are created correctly."""
- assert Group.query.count() == 0
- create_default_groups()
- assert Group.query.count() == len(group_fixture)
- for key, attributes in group_fixture.items():
- group = Group.query.filter_by(name=key).first()
- for attribute, value in attributes.items():
- assert getattr(group, attribute) == value
- def test_migrations_upgrade():
- with pytest.raises(OperationalError):
- User.query.all()
- # ensure that the database is created
- create_database(db.engine.url)
- alembic.upgrade()
- assert len(User.query.all()) == 0
- drop_database(db.engine.url)
|