No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_fieldgroups.py 8.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. import os
  2. import logging
  3. import datetime
  4. from django.conf import settings
  5. from unittest import TestCase
  6. import unittest
  7. from EditorialModel.components import EmComponent, EmComponentNotExistError
  8. from EditorialModel.fieldgroups import EmFieldGroup
  9. from EditorialModel.classes import EmClass
  10. from EditorialModel.classtypes import EmClassType
  11. from Database.sqlsetup import SQLSetup
  12. from Database import sqlutils
  13. import sqlalchemy as sqla
  14. os.environ.setdefault("DJANGO_SETTINGS_MODULE", "Lodel.settings")
  15. #=###########=#
  16. # TESTS SETUP #
  17. #=###########=#
  18. def setUpModule():
  19. #Overwritting db confs to make tests
  20. settings.LODEL2SQLWRAPPER['db'] = {
  21. 'default': {
  22. 'ENGINE': 'sqlite',
  23. 'NAME': '/tmp/testdb.sqlite'
  24. }
  25. }
  26. logging.basicConfig(level=logging.CRITICAL)
  27. class FieldGroupTestCase(TestCase):
  28. def setUp(self):
  29. sqls = SQLSetup()
  30. sqls.initDb()
  31. #Samples values insertion
  32. #Classes creation
  33. EmClass.create("entity1", EmClassType.entity)
  34. EmClass.create("entity2", EmClassType.entity)
  35. EmClass.create("entry1", EmClassType.entry)
  36. EmClass.create("entry2", EmClassType.entry)
  37. EmClass.create("person1", EmClassType.person)
  38. EmClass.create("person2", EmClassType.person)
  39. pass
  40. #======================#
  41. # EmFielgroup.__init__ #
  42. #======================#
  43. class TestInit(FieldGroupTestCase):
  44. def setUp(self):
  45. super(TestInit, self).setUp()
  46. conn = sqlutils.getEngine().connect()
  47. ent1 = EmClass('entity1')
  48. idx1 = EmClass('entry1')
  49. self.creadate = datetime.datetime.utcnow()
  50. #Test fieldgroup
  51. self.tfg = [
  52. { 'uid': EmFieldGroup.newUid(), 'name': 'fg1', 'string': '{"fr":"Super Fieldgroup"}', 'help': '{"en":"help"}', 'rank': 0 , 'class_id': ent1.uid, 'date_create' : self.creadate, 'date_update': self.creadate},
  53. { 'uid': EmFieldGroup.newUid(), 'name': 'fg2', 'string': '{"fr":"Super Fieldgroup"}', 'help': '{"en":"help"}', 'rank': 1 , 'class_id': ent1.uid, 'date_create': self.creadate, 'date_update': self.creadate},
  54. { 'uid': EmFieldGroup.newUid(), 'name': 'fg3', 'string': '{"fr":"Super Fieldgroup"}', 'help': '{"en":"help"}', 'rank': 2 , 'class_id': idx1.uid, 'date_create': self.creadate, 'date_update': self.creadate},
  55. ]
  56. req = sqla.Table('em_fieldgroup', sqlutils.meta(sqlutils.getEngine())).insert(self.tfg)
  57. conn.execute(req)
  58. conn.close()
  59. pass
  60. def test_init(self):
  61. """ Test that EmFieldgroup are correctly instanciated compare to self.tfg """
  62. with self.subTest("Call __init__ with name"):
  63. for tfg in self.tfg:
  64. fg = EmFieldGroup(tfg['name'])
  65. if attr in tfg:
  66. self.assertEqual(getattr(fg, attr), tfg[attr], "The propertie '"+attr+"' fetched from Db don't match excepted value")
  67. with self.subTest("Call __init__ with id"):
  68. for tfg in self.tfg:
  69. fg = EmFieldGroup(tfg['uid'])
  70. if attr in tfg:
  71. self.assertEqual(getattr(fg, attr), tfg[attr], "The propertie '"+attr+"' fetched from Db don't match excepted value")
  72. pass
  73. def test_init_badargs(self):
  74. """ Test that EmFieldgroup fail when bad arguments are given """
  75. baduid = self.tfg[2]['uid'] + 4096
  76. badname = 'NonExistingName'
  77. with self.assertRaises(EmComponentNotExistError, msg="Should raise because fieldgroup with id "+str(baduid)+" should not exist"):
  78. fg = EmFieldGroup(baduid)
  79. with self.assertRaises(EmComponentNotExistError, msg="Should raise because fieldgroup named "+badname+" should not exist"):
  80. fg = EmFieldGroup(badname)
  81. with self.assertRaises(TypeError, msg="Should raise a TypeError when crazy arguments are given"):
  82. fg = EmFieldGroup(print)
  83. with self.assertRaises(TypeError, msg="Should raise a TypeError when crazy arguments are given"):
  84. fg = EmFieldGroup(['hello', 'world'])
  85. pass
  86. #=====================#
  87. # EmFieldgroup.create #
  88. #=====================#
  89. class TestCreate(FieldGroupTestCase):
  90. def test_create(self):
  91. """ Does create actually create a fieldgroup ? """
  92. params = { 'EmClass entity instance': EmClass('entity1'),
  93. 'EmClass entry instance': EmClass('entry1'),
  94. 'EmClass person instance': EmClass('person1'),
  95. 'EmClass id': EmClass('entity1').uid,
  96. 'EmClass name': 'entity2',
  97. }
  98. for i,param_name in enumerate(params):
  99. with self.subTest("Create from an "+param_name):
  100. arg = params[param_name]
  101. if isinstance(arg, EmClass):
  102. cl = arg
  103. else:
  104. cl = EmClass(arg)
  105. fgname = 'new_fg'+i
  106. fg = EmFieldGroup.create(fgname, arg)
  107. self.assertEqual(fg.name, fgname, "EmFieldGroup.create() dont instanciate name correctly")
  108. self.assertEqual(fg.class_id, cl.uid, "EmFieldGroup.create() dont instanciate class_id correctly")
  109. nfg = EmFieldGroup(fgname)
  110. #Checking object property
  111. for fname in EmFieldGroup._fields:
  112. self.assertEqual(nfg.fname, fg.fname, "Msg inconsistency when a created fieldgroup is fecthed from Db (in "+fname+" property)")
  113. pass
  114. def test_create_badargs(self):
  115. """ Does create fails when badargs given ? """
  116. with self.subTest("With badarg as second argument"):
  117. badargs = { 'EmClass type (not an instance)': EmClass,
  118. 'Non Existing name': 'fooClassThatDontExist',
  119. 'Non Existing Id': 4042, #Hope that it didnt exist ;)
  120. 'Another component instance': EmType.create('fooType', EmClass('entity1')),
  121. 'A function': print
  122. }
  123. for i,badarg_name in enumerate(badargs):
  124. with self.assertRaises(TypeError, msg="Should raise because trying to give "+badarg_name+" as em_class"):
  125. fg = EmFieldGroup('new_fg'+i, badargs[badarg_name])
  126. with self.subTest("With badarg as first argument"):
  127. #Creating a fieldgroup to test duplicate name
  128. exfg = FieldGroup.create('existingfg', EmClass('entity1'))
  129. badargs = { 'a duplicate name': 'existingfg',
  130. 'an integer': 42,
  131. 'a function': print,
  132. 'an EmClass': EmClass('entry1'),
  133. }
  134. for badarg_name in badargs:
  135. with self.assertRaises(TypeError, msg="Should raise because trying to give "+badarg_name+" as first argument"):
  136. fg = EmFieldGroup(badargs[badarg_name])
  137. class TestFields(FieldGroupTestCase):
  138. def setUp(self):
  139. self.fg1 = EmFieldGroup.create('testfg', EmClass('entity1'))
  140. self.fg2 = EmFieldGroup.create('testfg2', EmClass('entry1'))
  141. self.fg3 = EmFieldGroup.create('testfg3', EmClass('entry1'))
  142. def test_fields(self):
  143. """ Does it returns actually associated fields ? """
  144. #Creating fields
  145. test_fields1 = [
  146. { 'name': 'field1', 'em_fieldgroup': self.fg1, 'em_fieldtype': EmField_integer() },
  147. { 'name': 'field2', 'em_fieldgroup': self.fg1, 'em_fieldtype': EmField_integer() },
  148. { 'name': 'field4', 'em_fieldgroup': self.fg1, 'em_fieldtype': EmField_integer() },
  149. ]
  150. test_fields2 = [
  151. { 'name': 'field3', 'em_fieldgroup': self.fg2, 'em_fieldtype': EmField_integer() },
  152. ]
  153. excepted1 = []
  154. for finfo in test_fields1:
  155. f = EmField.create(**finfo)
  156. excepted1.append(f.uid)
  157. for finfo in test_fields2:
  158. f = EmField.create(**finfo)
  159. excepted1 = set(excepted1)
  160. tests = {
  161. 'newly': EmFieldGroup('testfg'),
  162. 'old' : self.fg1
  163. }
  164. for name in tests:
  165. with self.subTest("Testing on "+name+" instanciated EmFieldGroups"):
  166. fg = test[name]
  167. flist = fg.fields()
  168. res = []
  169. for f in flist:
  170. res.append(f.uid)
  171. self.assertEqual(set(res), set(excepted1))
  172. with self.subTest("Testing empty fieldgroup"):
  173. fg = self.fg3
  174. flist = fg.fields()
  175. self.assertEqual(len(flist), 0)
  176. pass