test_generate_datasets.py 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694
  1. # -*- coding: utf-8 -*-
  2. '''
  3. Test to make sure generated datasets are sane.
  4. '''
  5. # needed for python 3 compatibility
  6. from __future__ import absolute_import, division
  7. try:
  8. import unittest2 as unittest
  9. except ImportError:
  10. import unittest
  11. from datetime import datetime
  12. import numpy as np
  13. import quantities as pq
  14. from neo.core import (class_by_name, Block, Segment,
  15. ChannelIndex, Unit,
  16. AnalogSignal,
  17. IrregularlySampledSignal, SpikeTrain,
  18. Event, Epoch)
  19. from neo.test.generate_datasets import (generate_one_simple_block,
  20. generate_one_simple_segment,
  21. generate_from_supported_objects,
  22. get_fake_value, get_fake_values,
  23. fake_neo, TEST_ANNOTATIONS)
  24. from neo.test.tools import assert_arrays_equal, assert_neo_object_is_compliant
  25. class Test__generate_one_simple_segment(unittest.TestCase):
  26. def test_defaults(self):
  27. res = generate_one_simple_segment()
  28. self.assertTrue(isinstance(res, Segment))
  29. assert_neo_object_is_compliant(res)
  30. self.assertEqual(len(res.analogsignals), 0)
  31. self.assertEqual(len(res.irregularlysampledsignals), 0)
  32. self.assertEqual(len(res.spiketrains), 0)
  33. self.assertEqual(len(res.events), 0)
  34. self.assertEqual(len(res.epochs), 0)
  35. def test_all_supported(self):
  36. objects = [Block, Segment,
  37. ChannelIndex, Unit,
  38. AnalogSignal,
  39. IrregularlySampledSignal, SpikeTrain,
  40. Event, Epoch]
  41. res = generate_one_simple_segment(supported_objects=objects)
  42. self.assertTrue(isinstance(res, Segment))
  43. assert_neo_object_is_compliant(res)
  44. self.assertEqual(len(res.analogsignals), 4)
  45. self.assertEqual(len(res.irregularlysampledsignals), 0)
  46. self.assertEqual(len(res.spiketrains), 6)
  47. self.assertEqual(len(res.events), 3)
  48. self.assertEqual(len(res.epochs), 2)
  49. def test_half_supported(self):
  50. objects = [Segment,
  51. IrregularlySampledSignal, SpikeTrain,
  52. Epoch]
  53. res = generate_one_simple_segment(supported_objects=objects)
  54. self.assertTrue(isinstance(res, Segment))
  55. assert_neo_object_is_compliant(res)
  56. self.assertEqual(len(res.analogsignals), 0)
  57. self.assertEqual(len(res.irregularlysampledsignals), 0)
  58. self.assertEqual(len(res.spiketrains), 6)
  59. self.assertEqual(len(res.events), 0)
  60. self.assertEqual(len(res.epochs), 2)
  61. def test_all_without_block(self):
  62. objects = [Segment,
  63. ChannelIndex, Unit,
  64. AnalogSignal,
  65. IrregularlySampledSignal, SpikeTrain,
  66. Event, Epoch]
  67. res = generate_one_simple_segment(supported_objects=objects)
  68. self.assertTrue(isinstance(res, Segment))
  69. assert_neo_object_is_compliant(res)
  70. self.assertEqual(len(res.analogsignals), 4)
  71. self.assertEqual(len(res.irregularlysampledsignals), 0)
  72. self.assertEqual(len(res.spiketrains), 6)
  73. self.assertEqual(len(res.events), 3)
  74. self.assertEqual(len(res.epochs), 2)
  75. def test_all_without_segment_valueerror(self):
  76. objects = [Block,
  77. ChannelIndex, Unit,
  78. AnalogSignal,
  79. IrregularlySampledSignal, SpikeTrain,
  80. Event, Epoch]
  81. self.assertRaises(ValueError, generate_one_simple_segment,
  82. supported_objects=objects)
  83. class Test__generate_one_simple_block(unittest.TestCase):
  84. def test_defaults(self):
  85. res = generate_one_simple_block()
  86. self.assertTrue(isinstance(res, Block))
  87. assert_neo_object_is_compliant(res)
  88. self.assertEqual(len(res.segments), 0)
  89. def test_all_supported(self):
  90. objects = [Block, Segment,
  91. ChannelIndex, Unit,
  92. AnalogSignal,
  93. IrregularlySampledSignal, SpikeTrain,
  94. Event, Epoch]
  95. res = generate_one_simple_block(supported_objects=objects)
  96. self.assertTrue(isinstance(res, Block))
  97. assert_neo_object_is_compliant(res)
  98. self.assertEqual(len(res.segments), 3)
  99. seg1, seg2, seg3 = res.segments
  100. self.assertEqual(len(seg1.analogsignals), 4)
  101. self.assertEqual(len(seg1.irregularlysampledsignals), 0)
  102. self.assertEqual(len(seg1.spiketrains), 6)
  103. self.assertEqual(len(seg1.events), 3)
  104. self.assertEqual(len(seg1.epochs), 2)
  105. self.assertEqual(len(seg2.analogsignals), 4)
  106. self.assertEqual(len(seg2.irregularlysampledsignals), 0)
  107. self.assertEqual(len(seg2.spiketrains), 6)
  108. self.assertEqual(len(seg2.events), 3)
  109. self.assertEqual(len(seg2.epochs), 2)
  110. self.assertEqual(len(seg3.analogsignals), 4)
  111. self.assertEqual(len(seg3.irregularlysampledsignals), 0)
  112. self.assertEqual(len(seg3.spiketrains), 6)
  113. self.assertEqual(len(seg3.events), 3)
  114. self.assertEqual(len(seg3.epochs), 2)
  115. def test_half_supported(self):
  116. objects = [Block, Segment,
  117. IrregularlySampledSignal, SpikeTrain,
  118. Epoch]
  119. res = generate_one_simple_block(supported_objects=objects)
  120. self.assertTrue(isinstance(res, Block))
  121. assert_neo_object_is_compliant(res)
  122. self.assertEqual(len(res.segments), 3)
  123. seg1, seg2, seg3 = res.segments
  124. self.assertEqual(len(seg1.analogsignals), 0)
  125. self.assertEqual(len(seg1.irregularlysampledsignals), 0)
  126. self.assertEqual(len(seg1.spiketrains), 6)
  127. self.assertEqual(len(seg1.events), 0)
  128. self.assertEqual(len(seg1.epochs), 2)
  129. self.assertEqual(len(seg2.analogsignals), 0)
  130. self.assertEqual(len(seg2.irregularlysampledsignals), 0)
  131. self.assertEqual(len(seg2.spiketrains), 6)
  132. self.assertEqual(len(seg2.events), 0)
  133. self.assertEqual(len(seg2.epochs), 2)
  134. self.assertEqual(len(seg3.analogsignals), 0)
  135. self.assertEqual(len(seg3.irregularlysampledsignals), 0)
  136. self.assertEqual(len(seg3.spiketrains), 6)
  137. self.assertEqual(len(seg3.events), 0)
  138. self.assertEqual(len(seg3.epochs), 2)
  139. def test_all_without_segment(self):
  140. objects = [Block,
  141. ChannelIndex, Unit,
  142. AnalogSignal,
  143. IrregularlySampledSignal, SpikeTrain,
  144. Event, Epoch]
  145. res = generate_one_simple_block(supported_objects=objects)
  146. self.assertTrue(isinstance(res, Block))
  147. assert_neo_object_is_compliant(res)
  148. self.assertEqual(len(res.segments), 0)
  149. def test_all_without_block_valueerror(self):
  150. objects = [Segment,
  151. ChannelIndex, Unit,
  152. AnalogSignal,
  153. IrregularlySampledSignal, SpikeTrain,
  154. Event, Epoch]
  155. self.assertRaises(ValueError, generate_one_simple_block,
  156. supported_objects=objects)
  157. class Test__generate_from_supported_objects(unittest.TestCase):
  158. def test_no_object_valueerror(self):
  159. objects = []
  160. self.assertRaises(ValueError, generate_from_supported_objects, objects)
  161. def test_all(self):
  162. objects = [Block, Segment,
  163. ChannelIndex, Unit,
  164. AnalogSignal,
  165. IrregularlySampledSignal, SpikeTrain,
  166. Event, Epoch]
  167. res = generate_from_supported_objects(objects)
  168. self.assertTrue(isinstance(res, Block))
  169. assert_neo_object_is_compliant(res)
  170. self.assertEqual(len(res.segments), 3)
  171. seg1, seg2, seg3 = res.segments
  172. self.assertEqual(len(seg1.analogsignals), 4)
  173. self.assertEqual(len(seg1.irregularlysampledsignals), 0)
  174. self.assertEqual(len(seg1.spiketrains), 6)
  175. self.assertEqual(len(seg1.events), 3)
  176. self.assertEqual(len(seg1.epochs), 2)
  177. self.assertEqual(len(seg2.analogsignals), 4)
  178. self.assertEqual(len(seg2.irregularlysampledsignals), 0)
  179. self.assertEqual(len(seg2.spiketrains), 6)
  180. self.assertEqual(len(seg2.events), 3)
  181. self.assertEqual(len(seg2.epochs), 2)
  182. self.assertEqual(len(seg3.analogsignals), 4)
  183. self.assertEqual(len(seg3.irregularlysampledsignals), 0)
  184. self.assertEqual(len(seg3.spiketrains), 6)
  185. self.assertEqual(len(seg3.events), 3)
  186. self.assertEqual(len(seg3.epochs), 2)
  187. def test_block(self):
  188. objects = [Block]
  189. res = generate_from_supported_objects(objects)
  190. self.assertTrue(isinstance(res, Block))
  191. assert_neo_object_is_compliant(res)
  192. self.assertEqual(len(res.segments), 0)
  193. def test_block_segment(self):
  194. objects = [Segment, Block]
  195. res = generate_from_supported_objects(objects)
  196. self.assertTrue(isinstance(res, Block))
  197. assert_neo_object_is_compliant(res)
  198. self.assertEqual(len(res.segments), 3)
  199. seg1, seg2, seg3 = res.segments
  200. self.assertEqual(len(seg1.analogsignals), 0)
  201. self.assertEqual(len(seg1.irregularlysampledsignals), 0)
  202. self.assertEqual(len(seg1.spiketrains), 0)
  203. self.assertEqual(len(seg1.events), 0)
  204. self.assertEqual(len(seg1.epochs), 0)
  205. self.assertEqual(len(seg2.analogsignals), 0)
  206. self.assertEqual(len(seg2.irregularlysampledsignals), 0)
  207. self.assertEqual(len(seg2.spiketrains), 0)
  208. self.assertEqual(len(seg2.events), 0)
  209. self.assertEqual(len(seg2.epochs), 0)
  210. self.assertEqual(len(seg3.analogsignals), 0)
  211. self.assertEqual(len(seg3.irregularlysampledsignals), 0)
  212. self.assertEqual(len(seg3.spiketrains), 0)
  213. self.assertEqual(len(seg3.events), 0)
  214. self.assertEqual(len(seg3.epochs), 0)
  215. def test_segment(self):
  216. objects = [Segment]
  217. res = generate_from_supported_objects(objects)
  218. self.assertTrue(isinstance(res, Segment))
  219. assert_neo_object_is_compliant(res)
  220. self.assertEqual(len(res.analogsignals), 0)
  221. self.assertEqual(len(res.irregularlysampledsignals), 0)
  222. self.assertEqual(len(res.spiketrains), 0)
  223. self.assertEqual(len(res.events), 0)
  224. self.assertEqual(len(res.epochs), 0)
  225. def test_all_without_block(self):
  226. objects = [Segment,
  227. ChannelIndex, Unit,
  228. AnalogSignal,
  229. IrregularlySampledSignal, SpikeTrain,
  230. Event, Epoch]
  231. res = generate_from_supported_objects(objects)
  232. self.assertTrue(isinstance(res, Segment))
  233. assert_neo_object_is_compliant(res)
  234. self.assertEqual(len(res.analogsignals), 4)
  235. self.assertEqual(len(res.irregularlysampledsignals), 0)
  236. self.assertEqual(len(res.spiketrains), 6)
  237. self.assertEqual(len(res.events), 3)
  238. self.assertEqual(len(res.epochs), 2)
  239. def test_all_without_segment(self):
  240. objects = [Block,
  241. ChannelIndex, Unit,
  242. AnalogSignal,
  243. IrregularlySampledSignal, SpikeTrain,
  244. Event, Epoch]
  245. res = generate_from_supported_objects(supported_objects=objects)
  246. self.assertTrue(isinstance(res, Block))
  247. assert_neo_object_is_compliant(res)
  248. self.assertEqual(len(res.segments), 0)
  249. class Test__get_fake_value(unittest.TestCase):
  250. def setUp(self):
  251. np.random.seed(0)
  252. def test__t_start(self):
  253. name = 't_start'
  254. datatype = pq.Quantity
  255. targ = 0.0 * pq.millisecond
  256. res = get_fake_value(name, datatype)
  257. self.assertTrue(isinstance(res, pq.Quantity))
  258. self.assertEqual(res.units, pq.millisecond)
  259. assert_arrays_equal(targ, res)
  260. self.assertRaises(ValueError, get_fake_value, name, datatype, dim=1)
  261. self.assertRaises(ValueError, get_fake_value, name, np.ndarray)
  262. def test__t_stop(self):
  263. name = 't_stop'
  264. datatype = pq.Quantity
  265. targ = 1.0 * pq.millisecond
  266. res = get_fake_value(name, datatype)
  267. self.assertTrue(isinstance(res, pq.Quantity))
  268. self.assertEqual(res.units, pq.millisecond)
  269. assert_arrays_equal(targ, res)
  270. self.assertRaises(ValueError, get_fake_value, name, datatype, dim=1)
  271. self.assertRaises(ValueError, get_fake_value, name, np.ndarray)
  272. def test__sampling_rate(self):
  273. name = 'sampling_rate'
  274. datatype = pq.Quantity
  275. targ = 10000.0 * pq.Hz
  276. res = get_fake_value(name, datatype)
  277. self.assertTrue(isinstance(res, pq.Quantity))
  278. self.assertEqual(res.units, pq.Hz)
  279. assert_arrays_equal(targ, res)
  280. self.assertRaises(ValueError, get_fake_value, name, datatype, dim=1)
  281. self.assertRaises(ValueError, get_fake_value, name, np.ndarray)
  282. def test__str(self):
  283. name = 'test__str'
  284. datatype = str
  285. targ = str(np.random.randint(100000))
  286. res = get_fake_value(name, datatype, seed=0)
  287. self.assertTrue(isinstance(res, str))
  288. self.assertEqual(targ, res)
  289. def test__name(self):
  290. name = 'name'
  291. datatype = str
  292. obj = 'Block'
  293. targ = 'Block'+str(np.random.randint(100000))
  294. res = get_fake_value(name, datatype, seed=0, obj=obj)
  295. self.assertTrue(isinstance(res, str))
  296. self.assertEqual(targ, res)
  297. self.assertRaises(ValueError, get_fake_value, name, datatype, dim=1)
  298. self.assertRaises(ValueError, get_fake_value, name, np.ndarray)
  299. def test__description(self):
  300. name = 'description'
  301. datatype = str
  302. obj = Segment
  303. targ = 'test Segment '+str(np.random.randint(100000))
  304. res = get_fake_value(name, datatype, seed=0, obj=obj)
  305. self.assertTrue(isinstance(res, str))
  306. self.assertEqual(targ, res)
  307. self.assertRaises(ValueError, get_fake_value, name, datatype, dim=1)
  308. self.assertRaises(ValueError, get_fake_value, name, np.ndarray)
  309. def test__file_origin(self):
  310. name = 'file_origin'
  311. datatype = str
  312. targ = 'test_file.txt'
  313. res = get_fake_value(name, datatype, seed=0)
  314. self.assertTrue(isinstance(res, str))
  315. self.assertEqual(targ, res)
  316. self.assertRaises(ValueError, get_fake_value, name, datatype, dim=1)
  317. self.assertRaises(ValueError, get_fake_value, name, np.ndarray)
  318. def test__int(self):
  319. name = 'test__int'
  320. datatype = int
  321. targ = np.random.randint(100)
  322. res = get_fake_value(name, datatype, seed=0)
  323. self.assertTrue(isinstance(res, int))
  324. self.assertEqual(targ, res)
  325. def test__float(self):
  326. name = 'test__float'
  327. datatype = float
  328. targ = 1000. * np.random.random()
  329. res = get_fake_value(name, datatype, seed=0)
  330. self.assertTrue(isinstance(res, float))
  331. self.assertEqual(targ, res)
  332. def test__datetime(self):
  333. name = 'test__datetime'
  334. datatype = datetime
  335. targ = datetime.fromtimestamp(1000000000*np.random.random())
  336. res = get_fake_value(name, datatype, seed=0)
  337. self.assertTrue(isinstance(res, datetime))
  338. self.assertEqual(res, targ)
  339. def test__quantity(self):
  340. name = 'test__quantity'
  341. datatype = pq.Quantity
  342. dim = 2
  343. size = []
  344. units = np.random.choice(['nA', 'mA', 'A', 'mV', 'V'])
  345. for i in range(int(dim)):
  346. size.append(np.random.randint(5) + 1)
  347. targ = pq.Quantity(np.random.random(size)*1000, units=units)
  348. res = get_fake_value(name, datatype, dim=dim, seed=0)
  349. self.assertTrue(isinstance(res, pq.Quantity))
  350. self.assertEqual(res.units, getattr(pq, units))
  351. assert_arrays_equal(targ, res)
  352. def test__quantity_force_units(self):
  353. name = 'test__quantity'
  354. datatype = np.ndarray
  355. dim = 2
  356. units = pq.ohm
  357. size = []
  358. for i in range(int(dim)):
  359. size.append(np.random.randint(5) + 1)
  360. targ = pq.Quantity(np.random.random(size)*1000, units=units)
  361. res = get_fake_value(name, datatype, dim=dim, seed=0, units=units)
  362. self.assertTrue(isinstance(res, np.ndarray))
  363. assert_arrays_equal(targ, res)
  364. def test__ndarray(self):
  365. name = 'test__ndarray'
  366. datatype = np.ndarray
  367. dim = 2
  368. size = []
  369. for i in range(int(dim)):
  370. size.append(np.random.randint(5) + 1)
  371. targ = np.random.random(size)*1000
  372. res = get_fake_value(name, datatype, dim=dim, seed=0)
  373. self.assertTrue(isinstance(res, np.ndarray))
  374. assert_arrays_equal(targ, res)
  375. def test__list(self):
  376. name = 'test__list'
  377. datatype = list
  378. dim = 2
  379. size = []
  380. for i in range(int(dim)):
  381. size.append(np.random.randint(5) + 1)
  382. targ = (np.random.random(size)*1000).tolist()
  383. res = get_fake_value(name, datatype, dim=dim, seed=0)
  384. self.assertTrue(isinstance(res, list))
  385. self.assertEqual(targ, res)
  386. def test__other_valueerror(self):
  387. name = 'test__other_fail'
  388. datatype = set([1, 2, 3, 4])
  389. self.assertRaises(ValueError, get_fake_value, name, datatype)
  390. class Test__get_fake_values(unittest.TestCase):
  391. def setUp(self):
  392. np.random.seed(0)
  393. self.annotations = dict([(str(x), TEST_ANNOTATIONS[x]) for x in
  394. range(len(TEST_ANNOTATIONS))])
  395. self.annotations['seed'] = 0
  396. def subcheck__get_fake_values(self, cls):
  397. res1 = get_fake_values(cls, annotate=False, seed=0)
  398. res2 = get_fake_values(cls, annotate=True, seed=0)
  399. if hasattr(cls, 'lower'):
  400. cls = class_by_name[cls]
  401. attrs = cls._necessary_attrs + cls._recommended_attrs
  402. attrnames = [attr[0] for attr in attrs]
  403. attrtypes = [attr[1] for attr in attrs]
  404. attritems = zip(attrnames, attrtypes)
  405. attrannnames = attrnames + list(self.annotations.keys())
  406. self.assertEqual(sorted(attrnames), sorted(res1.keys()))
  407. self.assertEqual(sorted(attrannnames), sorted(res2.keys()))
  408. items11 = [(name, type(value)) for name, value in res1.items()]
  409. self.assertEqual(sorted(attritems), sorted(items11))
  410. for name, value in res1.items():
  411. try:
  412. self.assertEqual(res2[name], value)
  413. except ValueError:
  414. assert_arrays_equal(res2[name], value)
  415. for name, value in self.annotations.items():
  416. self.assertFalse(name in res1)
  417. self.assertEqual(res2[name], value)
  418. for attr in attrs:
  419. name = attr[0]
  420. if len(attr) < 3:
  421. continue
  422. dim = attr[2]
  423. self.assertEqual(dim, res1[name].ndim)
  424. self.assertEqual(dim, res2[name].ndim)
  425. if len(attr) < 4:
  426. continue
  427. dtype = attr[3]
  428. self.assertEqual(dtype.kind, res1[name].dtype.kind)
  429. self.assertEqual(dtype.kind, res2[name].dtype.kind)
  430. def check__get_fake_values(self, cls):
  431. self.subcheck__get_fake_values(cls)
  432. self.subcheck__get_fake_values(cls.__name__)
  433. def test__analogsignalarray(self):
  434. self.check__get_fake_values(AnalogSignal)
  435. def test__block(self):
  436. self.check__get_fake_values(Block)
  437. def test__epoch(self):
  438. self.check__get_fake_values(Epoch)
  439. def test__event(self):
  440. self.check__get_fake_values(Event)
  441. def test__irregularlysampledsignal(self):
  442. self.check__get_fake_values(IrregularlySampledSignal)
  443. def test__channelindex(self):
  444. self.check__get_fake_values(ChannelIndex)
  445. def test__segment(self):
  446. self.check__get_fake_values(Segment)
  447. def test__spiketrain(self):
  448. self.check__get_fake_values(SpikeTrain)
  449. def test__unit(self):
  450. self.check__get_fake_values(Unit)
  451. class Test__generate_datasets(unittest.TestCase):
  452. def setUp(self):
  453. self.annotations = dict([(str(x), TEST_ANNOTATIONS[x]) for x in
  454. range(len(TEST_ANNOTATIONS))])
  455. def check__generate_datasets(self, cls):
  456. clsname = cls.__name__
  457. self.subcheck__generate_datasets(cls, cascade=True)
  458. self.subcheck__generate_datasets(cls, cascade=True, seed=0)
  459. self.subcheck__generate_datasets(cls, cascade=False)
  460. self.subcheck__generate_datasets(cls, cascade=False, seed=0)
  461. self.subcheck__generate_datasets(clsname, cascade=True)
  462. self.subcheck__generate_datasets(clsname, cascade=True, seed=0)
  463. self.subcheck__generate_datasets(clsname, cascade=False)
  464. self.subcheck__generate_datasets(clsname, cascade=False, seed=0)
  465. def subcheck__generate_datasets(self, cls, cascade, seed=None):
  466. self.annotations['seed'] = seed
  467. if seed is None:
  468. res = fake_neo(obj_type=cls, cascade=cascade)
  469. else:
  470. res = fake_neo(obj_type=cls, cascade=cascade, seed=seed)
  471. if not hasattr(cls, 'lower'):
  472. self.assertTrue(isinstance(res, cls))
  473. else:
  474. self.assertEqual(res.__class__.__name__, cls)
  475. assert_neo_object_is_compliant(res)
  476. self.assertEqual(res.annotations, self.annotations)
  477. resattr = get_fake_values(cls, annotate=False, seed=0)
  478. if seed is not None:
  479. for name, value in resattr.items():
  480. if name in ['channel_names',
  481. 'channel_indexes',
  482. 'channel_index',
  483. 'coordinates']:
  484. continue
  485. try:
  486. try:
  487. resvalue = getattr(res, name)
  488. except AttributeError:
  489. if name == 'signal':
  490. continue
  491. raise
  492. try:
  493. self.assertEqual(resvalue, value)
  494. except ValueError:
  495. assert_arrays_equal(resvalue, value)
  496. except BaseException as exc:
  497. exc.args += ('from %s' % name,)
  498. raise
  499. if not getattr(res, '_child_objects', ()):
  500. pass
  501. elif not cascade:
  502. self.assertEqual(res.children, ())
  503. else:
  504. self.assertNotEqual(res.children, ())
  505. if cls in ['ChannelIndex', ChannelIndex]:
  506. for i, unit in enumerate(res.units):
  507. for sigarr in res.analogsignals:
  508. self.assertEqual(unit.get_channel_indexes()[0],
  509. sigarr.get_channel_index()[i])
  510. def test__analogsignalarray(self):
  511. self.check__generate_datasets(AnalogSignal)
  512. def test__block(self):
  513. self.check__generate_datasets(AnalogSignal)
  514. def test__epoch(self):
  515. self.check__generate_datasets(Epoch)
  516. def test__event(self):
  517. self.check__generate_datasets(Event)
  518. def test__irregularlysampledsignal(self):
  519. self.check__generate_datasets(IrregularlySampledSignal)
  520. def test__channelindex(self):
  521. self.check__generate_datasets(ChannelIndex)
  522. def test__segment(self):
  523. self.check__generate_datasets(Segment)
  524. def test__spiketrain(self):
  525. self.check__generate_datasets(SpikeTrain)
  526. def test__unit(self):
  527. self.check__generate_datasets(Unit)