test_populate.py 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. from flaskbb.utils.populate import delete_settings_from_fixture, \
  2. create_settings_from_fixture, update_settings_from_fixture, \
  3. create_default_groups, create_test_data, insert_bulk_data, \
  4. create_welcome_forum, create_user
  5. from flaskbb.fixtures.groups import fixture as group_fixture
  6. from flaskbb.fixtures.settings import fixture as settings_fixture
  7. from flaskbb.user.models import Group, User
  8. from flaskbb.forum.models import Category, Topic, Post
  9. from flaskbb.management.models import Setting, SettingsGroup
  10. def test_delete_settings_from_fixture(default_settings):
  11. groups_count = SettingsGroup.query.count()
  12. assert len(settings_fixture) == groups_count
  13. deleted = delete_settings_from_fixture(settings_fixture)
  14. assert len(settings_fixture) == len(deleted)
  15. assert not SettingsGroup.query.count()
  16. assert not Setting.query.count()
  17. def test_create_settings_from_fixture(database):
  18. assert not SettingsGroup.query.count()
  19. assert not Setting.query.count()
  20. created = create_settings_from_fixture(settings_fixture)
  21. assert len(settings_fixture) == len(created)
  22. assert SettingsGroup.query.count() == len(created)
  23. def test_update_settings_from_fixture(database):
  24. def individual_settings(update_result):
  25. """helper that returns the number of settings that were updated"""
  26. return sum(len(settings_in_a_group) for settings_in_a_group in update_result.values())
  27. settings_fixture_group_count = len(settings_fixture)
  28. settings_fixture_setting_count = sum(
  29. len(settings_fixture[k][1]['settings']) for k in range(len(settings_fixture))
  30. )
  31. assert not SettingsGroup.query.count()
  32. assert not Setting.query.count()
  33. # No force-overwrite - the fixtures will be created because they do not exist.
  34. updated_1 = update_settings_from_fixture(settings_fixture)
  35. assert settings_fixture_group_count == len(updated_1)
  36. assert settings_fixture_group_count == SettingsGroup.query.count()
  37. assert settings_fixture_setting_count == individual_settings(updated_1)
  38. assert settings_fixture_setting_count == Setting.query.count()
  39. # force-overwrite - nothing changed so nothing should happen here
  40. force_updated_1 = update_settings_from_fixture(settings_fixture,
  41. overwrite_group=True,
  42. overwrite_setting=True)
  43. assert len(force_updated_1) == 0
  44. assert individual_settings(force_updated_1) == 0
  45. assert settings_fixture_group_count == SettingsGroup.query.count()
  46. assert settings_fixture_setting_count == Setting.query.count()
  47. fixture_to_update_with = (
  48. # a group where we change a lot
  49. ('general', {
  50. 'name': "General Settings",
  51. 'description': "This description is wrong.",
  52. 'settings': (
  53. # change value
  54. ('project_title', {
  55. 'value': "FlaskBB is cool!",
  56. 'value_type': "string",
  57. 'name': "Project title",
  58. 'description': "The title of the project.",
  59. }),
  60. # change name
  61. ('project_subtitle', {
  62. 'value': "A lightweight forum software in Flask",
  63. 'value_type': "string",
  64. 'name': "Subtitle of the project",
  65. 'description': "A short description of the project.",
  66. }),
  67. # change options (extra)
  68. ('posts_per_page', {
  69. 'value': 10,
  70. 'value_type': "integer",
  71. 'extra': {'min': 1},
  72. 'name': "Posts per page",
  73. 'description': "Number of posts displayed per page.",
  74. }),
  75. # change description
  76. ('topics_per_page', {
  77. 'value': 10,
  78. 'value_type': "integer",
  79. 'extra': {'min': 5},
  80. 'name': "Topics per page",
  81. 'description': "The number of topics to be displayed per page.",
  82. }),
  83. # add
  84. ('test_fixture', {
  85. 'description': 'This is a test fixture',
  86. 'name': 'Test Fixture',
  87. 'value': 'FlaskBBTest',
  88. 'value_type': 'string'
  89. }),
  90. )
  91. }),
  92. # a group where we change nothing
  93. ('auth', {
  94. 'name': 'Authentication Settings',
  95. 'description': 'Configurations for the Login and Register process!',
  96. # the same as in flaskbb/settings/fixtures/settings.py
  97. 'settings': (
  98. ('registration_enabled', {
  99. 'value': True,
  100. 'value_type': "boolean",
  101. 'name': "Enable Registration",
  102. 'description': "Enable or disable the registration",
  103. }),
  104. )
  105. }),
  106. # a wholly new group
  107. ('testgroup', {
  108. 'name': "Important settings",
  109. 'description': "Some settings without which the world would not work.",
  110. 'settings': (
  111. # change value
  112. ('monty_python', {
  113. 'value': "And now for something completely different...",
  114. 'value_type': "string",
  115. 'name': "Monty Python",
  116. 'description': "A random quote from Monty Python.",
  117. }),
  118. )
  119. })
  120. )
  121. # should add groups: testgroup
  122. # should add testgroup/monty_python, general/test_fixture
  123. updated_2 = update_settings_from_fixture(fixture_to_update_with)
  124. assert len(updated_2) == 2
  125. assert individual_settings(updated_2) == 2
  126. assert settings_fixture_group_count + 1 == SettingsGroup.query.count()
  127. assert settings_fixture_setting_count + 2 == Setting.query.count()
  128. fixture_to_update_with[2][1]['settings'][0][1]['description'] = "Something meaningless."
  129. # should update groups: general
  130. # should update settings: 4 in general, 1 in testgroup
  131. force_updated_2 = update_settings_from_fixture(fixture_to_update_with,
  132. overwrite_group=True,
  133. overwrite_setting=True)
  134. assert len(force_updated_2) == 2
  135. assert individual_settings(force_updated_2) == 5
  136. assert settings_fixture_group_count + 1 == SettingsGroup.query.count()
  137. assert settings_fixture_setting_count + 2 == Setting.query.count()
  138. modified_settings_fixture = [item for item in settings_fixture]
  139. modified_settings_fixture.append(
  140. # another wholly new group
  141. ('testgroup2', {
  142. 'name': "Important settings",
  143. 'description': "Some settings without which the world would not work.",
  144. 'settings': (
  145. # change value
  146. ('monty_python_reborn', {
  147. 'value': "And now for something completely different...",
  148. 'value_type': "string",
  149. 'name': "Monty Python",
  150. 'description': "A random quote from Monty Python.",
  151. }),
  152. )
  153. })
  154. )
  155. # should revert 4 in general
  156. # should add testgroup2 and one subitem
  157. force_updated_3 = update_settings_from_fixture(modified_settings_fixture,
  158. overwrite_group=True,
  159. overwrite_setting=True)
  160. assert len(force_updated_3) == 2
  161. assert individual_settings(force_updated_3) == 5
  162. assert settings_fixture_group_count + 2 == SettingsGroup.query.count()
  163. assert settings_fixture_setting_count + 3 == Setting.query.count()
  164. def test_create_user(default_groups):
  165. user = User.query.filter_by(username="admin").first()
  166. assert not user
  167. user = create_user(username="admin", password="test",
  168. email="test@example.org", groupname="admin")
  169. assert user.username == "admin"
  170. assert user.permissions["admin"]
  171. def test_create_welcome_forum(default_groups):
  172. assert not create_welcome_forum()
  173. create_user(username="admin", password="test",
  174. email="test@example.org", groupname="admin")
  175. assert create_welcome_forum()
  176. def test_create_test_data(database):
  177. assert Category.query.count() == 0
  178. data_created = create_test_data()
  179. assert Category.query.count() == data_created['categories']
  180. def test_insert_bulk_data(database):
  181. assert not insert_bulk_data(topic_count=1, post_count=1)
  182. create_test_data(categories=1, forums=1, topics=0)
  183. assert Topic.query.count() == 0
  184. topics, posts = insert_bulk_data(topic_count=1, post_count=1)
  185. assert Topic.query.count() == topics
  186. # -1 bc the topic post also counts as post
  187. assert Post.query.count() - 1 == posts
  188. def test_create_default_groups(database):
  189. """Test that the default groups are created correctly."""
  190. assert Group.query.count() == 0
  191. create_default_groups()
  192. assert Group.query.count() == len(group_fixture)
  193. for key, attributes in group_fixture.items():
  194. group = Group.query.filter_by(name=key).first()
  195. for attribute, value in attributes.items():
  196. assert getattr(group, attribute) == value