File: TestGhost.py

package info (click to toggle)
vtk7 7.1.1%2Bdfsg2-8
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 127,396 kB
  • sloc: cpp: 1,539,584; ansic: 124,382; python: 78,038; tcl: 47,013; xml: 8,142; yacc: 5,040; java: 4,439; perl: 3,132; lex: 1,926; sh: 1,500; makefile: 126; objc: 83
file content (59 lines) | stat: -rw-r--r-- 1,823 bytes parent folder | download | duplicates (9)
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
"""Test ghost object support in VTK-Python

When PyVTKObject is destroyed, the vtkObjectBase that it
contained often continues to exist because references to
it still exist within VTK.  When that vtkObjectBase is
returned to python, a new PyVTKObject is created.

If the PyVTKObject has a custom class or a custom dict,
then we make a "ghost" of the PyVTKObject when it is
destroyed, so that if its vtkObjectBase returns to python,
the PyVTKObject can be restored with the proper class and
dict.  Each ghost has a weak pointer to its vtkObjectBase
so that it can be erased if the vtkObjectBase is destroyed.

To be tested:
 - make sure custom dicts are restored
 - make sure custom classes are restored

Created on Aug 19, 2010 by David Gobbi

"""

import sys
import vtk
from vtk.test import Testing

class vtkCustomObject(vtk.vtkObject):
    pass

class TestGhost(Testing.vtkTest):
    def testGhostForDict(self):
        """Ghost an object to save the dict"""
        o = vtk.vtkObject()
        o.customattr = 'hello'
        a = vtk.vtkVariantArray()
        a.InsertNextValue(o)
        i = id(o)
        del o
        o = vtk.vtkObject()
        o = a.GetValue(0).ToVTKObject()
        # make sure the id has changed, but dict the same
        self.assertEqual(o.customattr, 'hello')
        self.assertNotEqual(i, id(o))

    def testGhostForClass(self):
        """Ghost an object to save the class"""
        o = vtkCustomObject()
        a = vtk.vtkVariantArray()
        a.InsertNextValue(o)
        i = id(o)
        del o
        o = vtk.vtkObject()
        o = a.GetValue(0).ToVTKObject()
        # make sure the id has changed, but class the same
        self.assertEqual(o.__class__, vtkCustomObject)
        self.assertNotEqual(i, id(o))

if __name__ == "__main__":
    Testing.main([(TestGhost, 'test')])