__init__.py 6.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. # -*- coding: utf-8 -*-
  2. import unittest
  3. import transaction
  4. from depot.manager import DepotManager
  5. from pyramid import testing
  6. from sqlalchemy.exc import IntegrityError
  7. from tracim.command.initializedb import InitializeDBCommand
  8. from tracim.lib.core.content import ContentApi
  9. from tracim.lib.core.workspace import WorkspaceApi
  10. from tracim.models import get_engine, DeclarativeBase, get_session_factory, \
  11. get_tm_session
  12. from tracim.models.data import Workspace, ContentType
  13. from tracim.models.data import Content
  14. from tracim.lib.utils.logger import logger
  15. from tracim.fixtures import FixturesLoader
  16. from tracim.fixtures.users_and_groups import Base as BaseFixture
  17. from tracim.config import CFG
  18. from tracim import main
  19. from webtest import TestApp
  20. def eq_(a, b, msg=None):
  21. # TODO - G.M - 05-04-2018 - Remove this when all old nose code is removed
  22. assert a == b, msg or "%r != %r" % (a, b)
  23. class FunctionalTest(unittest.TestCase):
  24. def setUp(self):
  25. DepotManager._clear()
  26. settings = {
  27. 'sqlalchemy.url': 'sqlite:///tracim_test.sqlite',
  28. 'user.auth_token.validity': '604800',
  29. 'depot_storage_dir': '/tmp/test/depot',
  30. 'depot_storage_name': 'test',
  31. 'preview_cache_dir': '/tmp/test/preview_cache',
  32. }
  33. from tracim.extensions import hapic
  34. hapic._context = None
  35. app = main({}, **settings)
  36. self.init_database(settings)
  37. self.testapp = TestApp(app)
  38. def init_database(self, settings):
  39. self.engine = get_engine(settings)
  40. DeclarativeBase.metadata.create_all(self.engine)
  41. session_factory = get_session_factory(self.engine)
  42. app_config = CFG(settings)
  43. with transaction.manager:
  44. dbsession = get_tm_session(session_factory, transaction.manager)
  45. try:
  46. fixtures_loader = FixturesLoader(dbsession, app_config)
  47. fixtures_loader.loads([BaseFixture])
  48. transaction.commit()
  49. print("Database initialized.")
  50. except IntegrityError:
  51. print('Warning, there was a problem when adding default data'
  52. ', it may have already been added:')
  53. import traceback
  54. print(traceback.format_exc())
  55. transaction.abort()
  56. print('Database initialization failed')
  57. def tearDown(self):
  58. logger.debug(self, 'TearDown Test...')
  59. from tracim.models.meta import DeclarativeBase
  60. testing.tearDown()
  61. transaction.abort()
  62. DeclarativeBase.metadata.drop_all(self.engine)
  63. DepotManager._clear()
  64. class BaseTest(unittest.TestCase):
  65. """
  66. Pyramid default test.
  67. """
  68. def setUp(self):
  69. logger.debug(self, 'Setup Test...')
  70. self.config = testing.setUp(settings={
  71. 'sqlalchemy.url': 'sqlite:///:memory:',
  72. 'user.auth_token.validity': '604800',
  73. 'depot_storage_dir': '/tmp/test/depot',
  74. 'depot_storage_name': 'test',
  75. 'preview_cache_dir': '/tmp/test/preview_cache',
  76. })
  77. self.config.include('tracim.models')
  78. DepotManager._clear()
  79. DepotManager.configure(
  80. 'test', {'depot.backend': 'depot.io.memory.MemoryFileStorage'}
  81. )
  82. settings = self.config.get_settings()
  83. self.app_config = CFG(settings)
  84. from tracim.models import (
  85. get_engine,
  86. get_session_factory,
  87. get_tm_session,
  88. )
  89. self.engine = get_engine(settings)
  90. session_factory = get_session_factory(self.engine)
  91. self.session = get_tm_session(session_factory, transaction.manager)
  92. self.init_database()
  93. def init_database(self):
  94. logger.debug(self, 'Init Database Schema...')
  95. from tracim.models.meta import DeclarativeBase
  96. DeclarativeBase.metadata.create_all(self.engine)
  97. def tearDown(self):
  98. logger.debug(self, 'TearDown Test...')
  99. from tracim.models.meta import DeclarativeBase
  100. testing.tearDown()
  101. transaction.abort()
  102. DeclarativeBase.metadata.drop_all(self.engine)
  103. class StandardTest(BaseTest):
  104. """
  105. BaseTest with default fixtures
  106. """
  107. fixtures = [BaseFixture]
  108. def init_database(self):
  109. BaseTest.init_database(self)
  110. fixtures_loader = FixturesLoader(
  111. session=self.session,
  112. config=CFG(self.config.get_settings()))
  113. fixtures_loader.loads(self.fixtures)
  114. class DefaultTest(StandardTest):
  115. def _create_workspace_and_test(self, name, user) -> Workspace:
  116. """
  117. All extra parameters (*args, **kwargs) are for Workspace init
  118. :return: Created workspace instance
  119. """
  120. WorkspaceApi(
  121. current_user=user,
  122. session=self.session,
  123. ).create_workspace(name, save_now=True)
  124. eq_(
  125. 1,
  126. self.session.query(Workspace).filter(
  127. Workspace.label == name
  128. ).count()
  129. )
  130. return self.session.query(Workspace).filter(
  131. Workspace.label == name
  132. ).one()
  133. def _create_content_and_test(
  134. self,
  135. name,
  136. workspace,
  137. *args,
  138. **kwargs
  139. ) -> Content:
  140. """
  141. All extra parameters (*args, **kwargs) are for Content init
  142. :return: Created Content instance
  143. """
  144. content = Content(*args, **kwargs)
  145. content.label = name
  146. content.workspace = workspace
  147. self.session.add(content)
  148. self.session.flush()
  149. content_api = ContentApi(
  150. current_user=None,
  151. session=self.session,
  152. config=self.app_config,
  153. )
  154. eq_(
  155. 1,
  156. content_api.get_canonical_query().filter(
  157. Content.label == name
  158. ).count()
  159. )
  160. return content_api.get_canonical_query().filter(
  161. Content.label == name
  162. ).one()
  163. def _create_thread_and_test(self,
  164. user,
  165. workspace_name='workspace_1',
  166. folder_name='folder_1',
  167. thread_name='thread_1') -> Content:
  168. """
  169. :return: Thread
  170. """
  171. workspace = self._create_workspace_and_test(workspace_name, user)
  172. folder = self._create_content_and_test(
  173. folder_name, workspace,
  174. type=ContentType.Folder,
  175. owner=user
  176. )
  177. thread = self._create_content_and_test(
  178. thread_name,
  179. workspace,
  180. type=ContentType.Thread,
  181. parent=folder,
  182. owner=user
  183. )
  184. return thread