test_container.py 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. # -*- coding: utf-8 -*-
  2. """
  3. Tests of the neo.core.container.Container class
  4. """
  5. import unittest
  6. import numpy as np
  7. try:
  8. from IPython.lib.pretty import pretty
  9. except ImportError as err:
  10. HAVE_IPYTHON = False
  11. else:
  12. HAVE_IPYTHON = True
  13. from neo.core.container import Container, unique_objs
  14. class Test_unique_objs(unittest.TestCase):
  15. '''
  16. TestCase for unique_objs
  17. '''
  18. def test_some(self):
  19. a = 1
  20. b = np.array([3.14159265, 3.1415])
  21. c = [1, '1', 2.3, '5 8']
  22. d = set([1, '2', 'spam'])
  23. objs = [a, b, b, b, c, b, a, d, b, b, a, d, d, d, c, d, b, d, c, a]
  24. targ = [a, b, c, d]
  25. res = unique_objs(objs)
  26. self.assertEqual(targ, res)
  27. class TestContainerNeo(unittest.TestCase):
  28. '''
  29. TestCase to make sure basic initialization and methods work
  30. '''
  31. def test_init(self):
  32. '''test to make sure initialization works properly'''
  33. container = Container(name='a container', description='this is a test')
  34. self.assertEqual(container.name, 'a container')
  35. self.assertEqual(container.description, 'this is a test')
  36. self.assertEqual(container.file_origin, None)
  37. def test__children(self):
  38. container = Container()
  39. self.assertEqual(container._single_parent_objects, ())
  40. self.assertEqual(container._multi_parent_objects, ())
  41. self.assertEqual(container._single_parent_containers, ())
  42. self.assertEqual(container._multi_parent_containers, ())
  43. self.assertEqual(container._parent_objects, ())
  44. self.assertEqual(container._parent_containers, ())
  45. self.assertEqual(container._container_child_objects, ())
  46. self.assertEqual(container._data_child_objects, ())
  47. self.assertEqual(container._multi_child_objects, ())
  48. self.assertEqual(container._child_properties, ())
  49. self.assertEqual(container._repr_pretty_containers, ())
  50. self.assertEqual(container._single_child_objects, ())
  51. self.assertEqual(container._container_child_containers, ())
  52. self.assertEqual(container._data_child_containers, ())
  53. self.assertEqual(container._single_child_containers, ())
  54. self.assertEqual(container._multi_child_containers, ())
  55. self.assertEqual(container._child_objects, ())
  56. self.assertEqual(container._child_containers, ())
  57. self.assertEqual(container._multi_children, ())
  58. self.assertEqual(container._single_children, ())
  59. self.assertEqual(container.data_children, ())
  60. self.assertEqual(container.container_children, ())
  61. self.assertEqual(container.children, ())
  62. self.assertEqual(container.parents, ())
  63. self.assertEqual(container.data_children_recur, ())
  64. self.assertEqual(container.container_children_recur, ())
  65. self.assertEqual(container.children_recur, ())
  66. self.assertEqual(container.filter(test=1), [])
  67. self.assertEqual(container.filter(data=True, container=False, test=1),
  68. [])
  69. self.assertEqual(container.filter(data=False, container=False, test=1),
  70. [])
  71. self.assertEqual(container.filter(data=True, container=True, test=1),
  72. [])
  73. self.assertEqual(container.filter(data=False, container=True, test=1),
  74. [])
  75. self.assertEqual(container.size, {})
  76. container.create_many_to_one_relationship()
  77. container.create_many_to_many_relationship()
  78. container.create_relationship()
  79. class Test_Container_merge(unittest.TestCase):
  80. '''
  81. TestCase to make sure merge method works
  82. '''
  83. def setUp(self):
  84. self.name1 = 'a container 1'
  85. self.name2 = 'a container 2'
  86. self.description1 = 'this is a test 1'
  87. self.description2 = 'this is a test 2'
  88. self.cont1 = Container(name=self.name1, description=self.description1)
  89. self.cont2 = Container(name=self.name2, description=self.description2)
  90. def test_merge__dict(self):
  91. self.cont1.annotations = {'val1': 1, 'val2': 2.2, 'val3': 'test1'}
  92. self.cont2.annotations = {'val2': 2.2, 'val3': 'test2',
  93. 'val4': [4, 4.4], 'val5': True}
  94. ann1 = self.cont1.annotations
  95. ann1c = self.cont1.annotations.copy()
  96. ann2c = self.cont2.annotations.copy()
  97. targ = {'val1': 1, 'val2': 2.2, 'val3': 'test1;test2',
  98. 'val4': [4, 4.4], 'val5': True}
  99. self.cont1.merge(self.cont2)
  100. self.assertEqual(ann1, self.cont1.annotations)
  101. self.assertNotEqual(ann1c, self.cont1.annotations)
  102. self.assertEqual(ann2c, self.cont2.annotations)
  103. self.assertEqual(targ, self.cont1.annotations)
  104. self.assertEqual(self.name1, self.cont1.name)
  105. self.assertEqual(self.name2, self.cont2.name)
  106. self.assertEqual(self.description1, self.cont1.description)
  107. self.assertEqual(self.description2, self.cont2.description)
  108. def test_merge__different_type_AssertionError(self):
  109. self.cont1.annotations = {'val1': 1, 'val2': 2.2, 'val3': 'tester'}
  110. self.cont2.annotations = {'val3': False, 'val4': [4, 4.4],
  111. 'val5': True}
  112. self.cont1.merge(self.cont2)
  113. self.assertEqual(self.cont1.annotations,
  114. {'val1': 1,
  115. 'val2': 2.2,
  116. 'val3': 'MERGE CONFLICT',
  117. 'val4': [4, 4.4],
  118. 'val5': True})
  119. def test_merge__unmergable_unequal_AssertionError(self):
  120. self.cont1.annotations = {'val1': 1, 'val2': 2.2, 'val3': True}
  121. self.cont2.annotations = {'val3': False, 'val4': [4, 4.4],
  122. 'val5': True}
  123. self.cont1.merge(self.cont2)
  124. self.assertEqual(self.cont1.annotations,
  125. {'val1': 1,
  126. 'val2': 2.2,
  127. 'val3': 'MERGE CONFLICT',
  128. 'val4': [4, 4.4],
  129. 'val5': True})
  130. @unittest.skipUnless(HAVE_IPYTHON, "requires IPython")
  131. class Test_pprint(unittest.TestCase):
  132. def test__pretty(self):
  133. name = 'an object'
  134. description = 'this is a test'
  135. obj = Container(name=name, description=description)
  136. res = pretty(obj)
  137. targ = "Container with name: '%s' description: '%s'" % (name,
  138. description)
  139. self.assertEqual(res, targ)
  140. if __name__ == "__main__":
  141. unittest.main()