File: TestGraphWriterReader.py

package info (click to toggle)
vtk9 9.5.2%2Bdfsg4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 206,616 kB
  • sloc: cpp: 2,340,827; ansic: 327,116; python: 114,881; yacc: 4,104; java: 3,977; sh: 3,032; xml: 2,771; perl: 2,189; lex: 1,787; javascript: 1,261; makefile: 189; objc: 153; tcl: 59
file content (90 lines) | stat: -rw-r--r-- 2,254 bytes parent folder | download | duplicates (4)
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
from vtkmodules import vtkCommonCore as cc
from vtkmodules import vtkCommonDataModel as dm
from vtkmodules import vtkCommonExecutionModel as em
from vtkmodules import vtkIOLegacy as il

from vtkmodules.test import Testing
from vtkmodules.util.misc import vtkGetTempDir

import os

class TestGraphWriterReader(Testing.vtkTest):

    def test(self):

        mdgTree = dm.vtkMutableDirectedGraph()
        mug = dm.vtkMutableUndirectedGraph()

        for i in range(10):
            mdgTree.AddVertex()
            mug.AddVertex()

        mdgTree.AddEdge(0, 1)
        mdgTree.AddEdge(0, 2)
        mdgTree.AddEdge(0, 3)
        mdgTree.AddEdge(1, 4)
        mdgTree.AddEdge(1, 5)
        mdgTree.AddEdge(2, 6)
        mdgTree.AddEdge(2, 7)
        mdgTree.AddEdge(3, 8)
        mdgTree.AddEdge(3, 9)

        # Undirected graph with parallel edges
        # and self-loops.
        mug.AddEdge(0, 0)
        mug.AddEdge(0, 1)
        mug.AddEdge(1, 0)
        mug.AddEdge(1, 2)
        mug.AddEdge(1, 3)
        mug.AddEdge(4, 5)
        mug.AddEdge(4, 5)
        mug.AddEdge(6, 7)
        mug.AddEdge(7, 7)

        w = il.vtkGraphWriter()

        tmpdir = vtkGetTempDir()
        fname = tmpdir+"/testgrapwriread.vtk"

        w.SetFileName(fname)
        w.SetInputData(mdgTree)
        w.Write()

        r = il.vtkGraphReader()
        r.SetFileName(fname)
        r.Update()

        g = r.GetOutput()

        self.assertTrue(g.IsA("vtkDirectedGraph"))
        self.assertTrue(g.GetNumberOfVertices() == 10)
        self.assertTrue(g.GetNumberOfEdges() == 9)
        self.assertTrue(g.GetTargetVertex(0) == 1)

        del(r)
        import gc
        gc.collect()
        os.remove(fname)

        w.SetFileName(fname)
        w.SetInputData(mug)
        w.Write()

        r = il.vtkGraphReader()
        r.SetFileName(fname)
        r.Update()

        g = r.GetOutput()

        self.assertTrue(g.IsA("vtkUndirectedGraph"))
        self.assertTrue(g.GetNumberOfVertices() == 10)
        self.assertTrue(g.GetNumberOfEdges() == 9)
        self.assertTrue(g.GetTargetVertex(0) == 0)

        del(r)
        import gc
        gc.collect()
        os.remove(fname)

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