1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
|
# Author: Prabhu Ramachandran
# License: BSD style
# Copyright (c) 2004, Enthought, Inc.
"""Tests class_tree.py. Uses the vtk module to test the code. Also
tests if the tree generation works for the builtins module.
"""
import builtins
import unittest
from contextlib import contextmanager
from tvtk import class_tree
import vtk
# This computation can be expensive, so we cache it.
_cache = class_tree.ClassTree(vtk)
_cache.create()
def get_level(klass):
"""Gets the inheritance level of a given class."""
if not klass.__bases__:
return 0
else:
return max([get_level(b) for b in klass.__bases__]) + 1
class TestClassTree(unittest.TestCase):
def setUp(self):
self.t = _cache
@contextmanager
def _remove_loader_from_builtin(self):
self._loader = None
if hasattr(builtins, '__loader__'):
self._loader = builtins.__loader__
del builtins.__loader__
try:
yield
finally:
if self._loader:
builtins.__loader__ = self._loader
def test_basic_vtk(self):
"""Basic tests for the VTK module."""
t = self.t
self.assertEqual(t.get_node('vtkObject').name, 'vtkObject')
self.assertEqual(t.get_node('vtkObject').parents[0].name,
'vtkObjectBase')
if (hasattr(vtk, 'vtkTuple')):
names = [x.name for x in t.tree[0]]
names.sort()
expect = ['object']
self.assertEqual(names, expect)
elif (hasattr(vtk, 'vtkVector')):
self.assertEqual(len(t.tree[0]), 11)
names = [x.name for x in t.tree[0]]
names.sort()
expect = ['object', 'vtkColor3', 'vtkColor4', 'vtkDenseArray',
'vtkObjectBase', 'vtkRect', 'vtkSparseArray',
'vtkTypedArray', 'vtkVector', 'vtkVector2',
'vtkVector3']
self.assertEqual(names, expect)
elif (hasattr(vtk, 'vtkArrayCoordinates')
and issubclass(vtk.vtkArrayCoordinates, object)):
self.assertEqual(len(t.tree[0]), 2)
names = [x.name for x in t.tree[0]]
names.sort()
self.assertEqual(names, ['object', 'vtkObjectBase'])
else:
self.assertEqual(len(t.tree[0]), 1)
self.assertEqual(t.tree[0][0].name, 'vtkObjectBase')
def test_ancestors(self):
"""Check if get_ancestors is OK."""
# The parent child information is already tested so this test
# needs to ensure that the method works for a few known
# examples.
# Simple VTK test.
t = self.t
n = t.get_node('vtkDataArray')
x = vtk.vtkDataArray
ancestors = []
while x.__name__ != 'vtkObjectBase':
x = x.__bases__[0]
ancestors.append(x.__name__)
if len(vtk.vtkObjectBase.__bases__) > 0:
ancestors.append('object')
self.assertEqual([x.name for x in n.get_ancestors()], ancestors)
def _get_ancestors(klass):
bases = []
for base in klass.__bases__:
bases.append(base)
bases.extend(_get_ancestors(base))
return bases
# Simple builtins test.
with self._remove_loader_from_builtin():
t = class_tree.ClassTree(builtins)
t.create()
n = t.get_node('TabError')
bases = [x.__name__ for x in _get_ancestors(TabError)]
self.assertEqual([x.name for x in n.get_ancestors()],
bases)
def test_parent_child(self):
"""Check if the node's parent and children are correct."""
t = self.t
for node in t:
n_class = t.get_class(node.name)
base_names = [x.__name__ for x in n_class.__bases__]
base_names.sort()
parent_names = [x.name for x in node.parents]
parent_names.sort()
self.assertEqual(base_names, parent_names)
for c in node.children:
c_class = t.get_class(c.name)
base_names = [x.__name__ for x in c_class.__bases__]
self.assertEqual(node.name in base_names, True)
def test_level(self):
"""Check the node levels."""
t = self.t
for node in t:
self.assertEqual(get_level(t.get_class(node.name)), node.level)
def test_tree(self):
"""Check the tree structure."""
t = self.t
n = sum([len(x) for x in t.tree])
self.assertEqual(n, len(t.nodes))
for level, nodes in enumerate(t.tree):
for n in nodes:
self.assertEqual(n.level, level)
def test_builtin(self):
"""Check if tree structure for builtins works."""
# This tests to see if the tree structure generation works for
# the builtins module.
with self._remove_loader_from_builtin():
t = class_tree.ClassTree(builtins)
t.create()
self.t = t
self.test_parent_child()
self.test_level()
self.test_tree()
if __name__ == "__main__":
unittest.main()
|