script to report deprecated functions of text and their age in days.
[blender.git] / source / tests / bl_run_operators.py
1 # ##### BEGIN GPL LICENSE BLOCK #####
2 #
3 #  This program is free software; you can redistribute it and/or
4 #  modify it under the terms of the GNU General Public License
5 #  as published by the Free Software Foundation; either version 2
6 #  of the License, or (at your option) any later version.
7 #
8 #  This program is distributed in the hope that it will be useful,
9 #  but WITHOUT ANY WARRANTY; without even the implied warranty of
10 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 #  GNU General Public License for more details.
12 #
13 #  You should have received a copy of the GNU General Public License
14 #  along with this program; if not, write to the Free Software Foundation,
15 #  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 #
17 # ##### END GPL LICENSE BLOCK #####
18
19 # <pep8 compliant>
20
21 # semi-useful script, runs all operators in a number of different
22 # contexts, cheap way to find misc small bugs but is in no way a complete test.
23 #
24 # only error checked for here is a segfault.
25
26 import bpy
27 import sys
28
29 op_blacklist = (
30     "script.reload",
31     "export*.*",
32     "import*.*",
33     "*.save_*",
34     "*.read_*",
35     "*.open_*",
36     "*.link_append",
37     "render.render",
38     "*.*_export",
39     "*.*_import",
40     "wm.url_open",
41     "wm.doc_view",
42     "wm.path_open",
43     "help.operator_cheat_sheet",
44     )
45
46
47 def filter_op_list(operators):
48     from fnmatch import fnmatchcase
49
50     def is_op_ok(op):
51         for op_match in op_blacklist:
52             if fnmatchcase(op, op_match):
53                 print("    skipping: %s (%s)" % (op, op_match))
54                 return False
55         return True
56
57     operators[:] = [op for op in operators if is_op_ok(op[0])]
58
59
60 def run_ops(operators, setup_func=None):
61     print("\ncontext:", setup_func.__name__)
62     # first invoke
63     for op_id, op in operators:
64         if op.poll():
65             print("    operator:", op_id)
66             sys.stdout.flush()  # incase of crash
67
68             # disable will get blender in a bad state and crash easy!
69             bpy.ops.wm.read_factory_settings()
70
71             setup_func()
72
73             for mode in ('EXEC_DEFAULT', 'INVOKE_DEFAULT'):
74                 try:
75                     op(mode)
76                 except:
77                     #import traceback
78                     #traceback.print_exc()
79                     pass
80
81
82 # contexts
83 def ctx_clear_scene():  # copied from batch_import.py
84     unique_obs = set()
85     for scene in bpy.data.scenes:
86         for obj in scene.objects[:]:
87             scene.objects.unlink(obj)
88             unique_obs.add(obj)
89
90     # remove obdata, for now only worry about the startup scene
91     for bpy_data_iter in (bpy.data.objects, bpy.data.meshes, bpy.data.lamps, bpy.data.cameras):
92         for id_data in bpy_data_iter:
93             bpy_data_iter.remove(id_data)
94
95
96 def ctx_editmode_mesh():
97     bpy.ops.object.mode_set(mode='EDIT')
98     bpy.ops.object.vertex_group_add()
99
100
101 def ctx_editmode_curves():
102     bpy.ops.curve.primitive_nurbs_circle_add()
103     bpy.ops.object.mode_set(mode='EDIT')
104
105
106 def ctx_editmode_surface():
107     bpy.ops.surface.primitive_nurbs_surface_torus_add()
108     bpy.ops.object.mode_set(mode='EDIT')
109
110
111 def ctx_editmode_mball():
112     bpy.ops.object.metaball_add()
113     bpy.ops.object.mode_set(mode='EDIT')
114
115
116 def ctx_editmode_text():
117     bpy.ops.object.text_add()
118     bpy.ops.object.mode_set(mode='EDIT')
119
120
121 def ctx_editmode_armature():
122     bpy.ops.object.armature_add()
123     bpy.ops.object.mode_set(mode='EDIT')
124
125
126 def ctx_editmode_lattice():
127     bpy.ops.object.add(type='LATTICE')
128     bpy.ops.object.mode_set(mode='EDIT')
129     # bpy.ops.object.vertex_group_add()
130
131
132 def ctx_object_empty():
133     bpy.ops.object.add(type='EMPTY')
134
135
136 def ctx_weightpaint():
137     bpy.ops.object.mode_set(mode='WEIGHT_PAINT')
138
139
140 def main():
141     # bpy.ops.wm.read_factory_settings()
142     import bpy
143     operators = []
144     for mod_name in dir(bpy.ops):
145         mod = getattr(bpy.ops, mod_name)
146         for submod_name in dir(mod):
147             op = getattr(mod, submod_name)
148             operators.append(("%s.%s" % (mod_name, submod_name), op))
149
150     operators.sort(key=lambda op: op[0])
151
152     filter_op_list(operators)
153
154     # for testing, mix the list up.
155     #operators.reverse()
156
157     #import random
158     #random.shuffle(operators)
159
160     # Run the operator tests in different contexts
161     run_ops(operators, setup_func=lambda: None)
162     run_ops(operators, setup_func=ctx_editmode_surface)
163     run_ops(operators, setup_func=ctx_object_empty)
164     run_ops(operators, setup_func=ctx_editmode_armature)
165     run_ops(operators, setup_func=ctx_editmode_mesh)
166     run_ops(operators, setup_func=ctx_clear_scene)
167     run_ops(operators, setup_func=ctx_editmode_curves)
168     run_ops(operators, setup_func=ctx_editmode_mball)
169     run_ops(operators, setup_func=ctx_editmode_text)
170     run_ops(operators, setup_func=ctx_weightpaint)
171     run_ops(operators, setup_func=ctx_editmode_lattice)
172
173     print("finished")
174
175 if __name__ == "__main__":
176     main()