ansys-fluent-core 0.28.dev0__py3-none-any.whl → 0.28.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of ansys-fluent-core might be problematic. Click here for more details.

Files changed (63) hide show
  1. ansys/fluent/core/__init__.py +15 -16
  2. ansys/fluent/core/_version.py +1 -1
  3. ansys/fluent/core/codegen/allapigen.py +0 -3
  4. ansys/fluent/core/codegen/builtin_settingsgen.py +5 -20
  5. ansys/fluent/core/codegen/print_fluent_version.py +9 -14
  6. ansys/fluent/core/codegen/walk_api.py +57 -0
  7. ansys/fluent/core/fluent_connection.py +26 -22
  8. ansys/fluent/core/generated/api_tree/api_objects.json +1 -1
  9. ansys/fluent/core/generated/datamodel_252/meshing.py +21 -0
  10. ansys/fluent/core/generated/datamodel_252/preferences.py +7 -0
  11. ansys/fluent/core/generated/fluent_version_252.py +3 -3
  12. ansys/fluent/core/generated/meshing/tui_252.py +1183 -1133
  13. ansys/fluent/core/generated/solver/settings_252.py +8944 -6572
  14. ansys/fluent/core/generated/solver/settings_252.pyi +6357 -5352
  15. ansys/fluent/core/generated/solver/tui_252.py +3039 -2473
  16. ansys/fluent/core/journaling.py +4 -4
  17. ansys/fluent/core/launcher/fluent_container.py +31 -7
  18. ansys/fluent/core/launcher/launcher.py +3 -2
  19. ansys/fluent/core/launcher/launcher_utils.py +9 -0
  20. ansys/fluent/core/launcher/process_launch_string.py +8 -6
  21. ansys/fluent/core/launcher/pyfluent_enums.py +6 -3
  22. ansys/fluent/core/launcher/server_info.py +25 -2
  23. ansys/fluent/core/launcher/slurm_launcher.py +6 -3
  24. ansys/fluent/core/launcher/standalone_launcher.py +11 -9
  25. ansys/fluent/core/post_objects/post_helper.py +16 -10
  26. ansys/fluent/core/services/__init__.py +2 -0
  27. ansys/fluent/core/services/api_upgrade.py +11 -9
  28. ansys/fluent/core/services/app_utilities.py +408 -0
  29. ansys/fluent/core/services/datamodel_se.py +42 -5
  30. ansys/fluent/core/services/datamodel_tui.py +5 -2
  31. ansys/fluent/core/services/field_data.py +1 -0
  32. ansys/fluent/core/services/reduction.py +2 -0
  33. ansys/fluent/core/services/settings.py +5 -2
  34. ansys/fluent/core/session.py +27 -4
  35. ansys/fluent/core/session_pure_meshing.py +1 -1
  36. ansys/fluent/core/session_solver.py +0 -1
  37. ansys/fluent/core/solver/__init__.py +6 -0
  38. ansys/fluent/core/solver/flobject.py +15 -27
  39. ansys/fluent/core/solver/function/reduction.py +3 -0
  40. ansys/fluent/core/solver/settings_builtin_data.py +1 -1
  41. ansys/fluent/core/streaming_services/datamodel_event_streaming.py +5 -5
  42. ansys/fluent/core/streaming_services/events_streaming.py +336 -52
  43. ansys/fluent/tests/conftest.py +30 -0
  44. ansys/fluent/tests/test_builtin_settings.py +1 -1
  45. ansys/fluent/tests/test_codegen.py +0 -410
  46. ansys/fluent/tests/test_datamodel_api.py +449 -0
  47. ansys/fluent/tests/test_datamodel_service.py +64 -64
  48. ansys/fluent/tests/test_events_manager.py +24 -6
  49. ansys/fluent/tests/test_field_data.py +32 -0
  50. ansys/fluent/tests/test_launcher.py +30 -2
  51. ansys/fluent/tests/test_mapped_api.py +774 -0
  52. ansys/fluent/tests/test_reduction.py +30 -0
  53. ansys/fluent/tests/test_session.py +16 -1
  54. ansys/fluent/tests/test_settings_api.py +21 -0
  55. ansys/fluent/tests/test_solution_variables.py +27 -0
  56. ansys/fluent/tests/util/__init__.py +36 -0
  57. {ansys_fluent_core-0.28.dev0.dist-info → ansys_fluent_core-0.28.1.dist-info}/METADATA +4 -3
  58. {ansys_fluent_core-0.28.dev0.dist-info → ansys_fluent_core-0.28.1.dist-info}/RECORD +61 -58
  59. {ansys_fluent_core-0.28.dev0.dist-info → ansys_fluent_core-0.28.1.dist-info}/WHEEL +1 -1
  60. ansys/fluent/core/codegen/settingsgen_old.py +0 -535
  61. ansys/fluent/tests/fluent/test_version/test.py +0 -2
  62. {ansys_fluent_core-0.28.dev0.dist-info → ansys_fluent_core-0.28.1.dist-info}/AUTHORS +0 -0
  63. {ansys_fluent_core-0.28.dev0.dist-info → ansys_fluent_core-0.28.1.dist-info}/LICENSE +0 -0
@@ -0,0 +1,449 @@
1
+ import time
2
+
3
+ import pytest
4
+ from util import create_datamodel_root_in_server, create_root_using_datamodelgen
5
+
6
+ from ansys.fluent.core.services.datamodel_se import (
7
+ SubscribeEventError,
8
+ convert_path_to_se_path,
9
+ )
10
+ from ansys.fluent.core.utils.execution import timeout_loop
11
+
12
+ rule_str = (
13
+ "RULES:\n"
14
+ " STRING: X\n"
15
+ " default = ijk\n"
16
+ " END\n"
17
+ " SINGLETON: ROOT\n"
18
+ " members = A, B, D, G\n"
19
+ " commands= C\n"
20
+ " SINGLETON: A\n"
21
+ " members = X\n"
22
+ " x = $./X\n"
23
+ " END\n"
24
+ " OBJECT: B\n"
25
+ " members = X\n"
26
+ " END\n"
27
+ " SINGLETON: D\n"
28
+ " members = E, F, X\n"
29
+ " SINGLETON: E\n"
30
+ " members = X\n"
31
+ " END\n"
32
+ " SINGLETON: F\n"
33
+ " members = X\n"
34
+ " END\n"
35
+ " END\n"
36
+ " SINGLETON: G\n"
37
+ " members = H\n"
38
+ " DICT: H\n"
39
+ " END\n"
40
+ " END\n"
41
+ " COMMAND: C\n"
42
+ " arguments = X\n"
43
+ " x = $/A/X\n"
44
+ " END\n"
45
+ " END\n"
46
+ "END\n"
47
+ )
48
+
49
+
50
+ @pytest.mark.fluent_version(">=25.2")
51
+ def test_env_var_setting(datamodel_api_version_all, request, new_solver_session):
52
+ solver = new_solver_session
53
+ test_name = request.node.name
54
+ for var in ["REMOTING_NEW_DM_API", "REMOTING_MAPPED_NEW_DM_API"]:
55
+ # TODO: It might be possible to check the param value in the fixture
56
+ # instead of checking the test name here.
57
+ if test_name.endswith("[old]"):
58
+ assert solver.scheme_eval.scheme_eval(f'(getenv "{var}")') is None
59
+ elif test_name.endswith("[new]"):
60
+ assert solver.scheme_eval.scheme_eval(f'(getenv "{var}")') == "1"
61
+
62
+
63
+ @pytest.mark.fluent_version(">=25.2")
64
+ def test_datamodel_api_on_child_created(datamodel_api_version_all, new_solver_session):
65
+ solver = new_solver_session
66
+ app_name = "test"
67
+ create_datamodel_root_in_server(solver, rule_str, app_name)
68
+ service = solver._se_service
69
+ root = create_root_using_datamodelgen(service, app_name)
70
+
71
+ called = 0
72
+ created = []
73
+
74
+ def cb(obj):
75
+ nonlocal called
76
+ nonlocal created
77
+ called += 1
78
+ created.append(convert_path_to_se_path(obj.path))
79
+
80
+ subscription = service.add_on_child_created(app_name, "/", "B", root, cb)
81
+ assert called == 0
82
+ assert created == []
83
+ service.set_state(app_name, "/", {"B:b": {"_name_": "b"}})
84
+ timeout_loop(lambda: called == 1, timeout=5)
85
+ assert called == 1
86
+ assert created == ["/B:b"]
87
+ subscription.unsubscribe()
88
+
89
+
90
+ @pytest.mark.fluent_version(">=25.2")
91
+ def test_datamodel_api_on_changed(datamodel_api_version_all, new_solver_session):
92
+ solver = new_solver_session
93
+ app_name = "test"
94
+ create_datamodel_root_in_server(solver, rule_str, app_name)
95
+ service = solver._se_service
96
+ root = create_root_using_datamodelgen(service, app_name)
97
+ called = 0
98
+ state = None
99
+ called_obj = 0
100
+ state_obj = None
101
+
102
+ def cb(obj):
103
+ nonlocal called
104
+ nonlocal state
105
+ state = obj()
106
+ called += 1
107
+
108
+ def cb_obj(obj):
109
+ nonlocal called_obj
110
+ nonlocal state_obj
111
+ state_obj = obj()
112
+ called_obj += 1
113
+
114
+ subscription = service.add_on_changed(app_name, "/A/X", root.A.X, cb)
115
+ subscription_obj = service.add_on_changed(app_name, "/A", root.A, cb_obj)
116
+ assert called == 0
117
+ assert state is None
118
+ assert called_obj == 0
119
+ assert state_obj is None
120
+ service.set_state(app_name, "/A/X", "lmn")
121
+ timeout_loop(lambda: called == 1, timeout=5)
122
+ assert called == 1
123
+ assert state == "lmn"
124
+ assert called_obj == 1
125
+ assert state_obj == {"X": "lmn"}
126
+ service.set_state(app_name, "/A/X", "abc")
127
+ timeout_loop(lambda: called == 2, timeout=5)
128
+ assert called == 2
129
+ assert state == "abc"
130
+ assert called_obj == 2
131
+ assert state_obj == {"X": "abc"}
132
+ subscription.unsubscribe()
133
+ subscription_obj.unsubscribe()
134
+ service.set_state(app_name, "/A/X", "xyz")
135
+ time.sleep(5)
136
+ assert called == 2
137
+ assert state == "abc"
138
+ assert called_obj == 2
139
+ assert state_obj == {"X": "abc"}
140
+
141
+
142
+ @pytest.mark.fluent_version(">=25.2")
143
+ def test_datamodel_api_on_affected(datamodel_api_version_all, new_solver_session):
144
+ solver = new_solver_session
145
+ app_name = "test"
146
+ create_datamodel_root_in_server(solver, rule_str, app_name)
147
+ service = solver._se_service
148
+ root = create_root_using_datamodelgen(service, app_name)
149
+ called = 0
150
+
151
+ def cb(obj):
152
+ nonlocal called
153
+ called += 1
154
+
155
+ subscription = service.add_on_affected(app_name, "/D", root.D, cb)
156
+ assert called == 0
157
+ service.set_state(app_name, "/D/X", "lmn")
158
+ timeout_loop(lambda: called == 1, timeout=5)
159
+ assert called == 1
160
+ service.set_state(app_name, "/D/E/X", "lmn")
161
+ timeout_loop(lambda: called == 2, timeout=5)
162
+ assert called == 2
163
+ service.set_state(app_name, "/A/X", "lmn")
164
+ time.sleep(5)
165
+ assert called == 2
166
+ subscription.unsubscribe()
167
+ service.set_state(app_name, "/D/E/X", "pqr")
168
+ time.sleep(5)
169
+ assert called == 2
170
+
171
+
172
+ @pytest.mark.fluent_version(">=25.2")
173
+ def test_datamodel_api_on_affected_at_type_path(
174
+ datamodel_api_version_all, new_solver_session
175
+ ):
176
+ solver = new_solver_session
177
+ app_name = "test"
178
+ create_datamodel_root_in_server(solver, rule_str, app_name)
179
+ service = solver._se_service
180
+ root = create_root_using_datamodelgen(service, app_name)
181
+ called = 0
182
+
183
+ def cb(obj):
184
+ nonlocal called
185
+ called += 1
186
+
187
+ subscription = service.add_on_affected_at_type_path(
188
+ app_name, "/D", "E", root.D.E, cb
189
+ )
190
+ assert called == 0
191
+ service.set_state(app_name, "/D/X", "lmn")
192
+ time.sleep(5)
193
+ assert called == 0
194
+ service.set_state(app_name, "/D/E/X", "lmn")
195
+ timeout_loop(lambda: called == 1, timeout=5)
196
+ assert called == 1
197
+ service.set_state(app_name, "/D/F/X", "lmn")
198
+ time.sleep(5)
199
+ assert called == 1
200
+ subscription.unsubscribe()
201
+ service.set_state(app_name, "/D/E/X", "pqr")
202
+ time.sleep(5)
203
+ assert called == 1
204
+
205
+
206
+ @pytest.mark.fluent_version(">=25.2")
207
+ def test_datamodel_api_on_deleted(
208
+ datamodel_api_version_all, request, new_solver_session
209
+ ):
210
+ solver = new_solver_session
211
+ app_name = "test"
212
+ create_datamodel_root_in_server(solver, rule_str, app_name)
213
+ service = solver._se_service
214
+ root = create_root_using_datamodelgen(service, app_name)
215
+ called = False
216
+ called_obj = False
217
+
218
+ def cb():
219
+ nonlocal called
220
+ called = True
221
+
222
+ def cb_obj():
223
+ nonlocal called_obj
224
+ called_obj = True
225
+
226
+ service.set_state(app_name, "/", {"B:b": {"_name_": "b"}})
227
+ subscription = service.add_on_deleted(app_name, "/B:b/X", root.B["b"].X, cb)
228
+ subscription_obj = service.add_on_deleted(app_name, "/B:b", root.B["b"], cb_obj)
229
+ assert not called
230
+ assert not called_obj
231
+ service.delete_object(app_name, "/B:b")
232
+ time.sleep(5)
233
+ test_name = request.node.name
234
+ # TODO: Note comment in StateEngine test testDataModelAPIOnDeleted
235
+ if test_name.endswith("[old]"):
236
+ assert called
237
+ elif test_name.endswith("[new]"):
238
+ assert not called
239
+ assert called_obj
240
+ subscription.unsubscribe()
241
+ subscription_obj.unsubscribe()
242
+
243
+
244
+ @pytest.mark.fluent_version(">=25.2")
245
+ def test_datamodel_api_on_attribute_changed(
246
+ datamodel_api_version_all, new_solver_session
247
+ ):
248
+ solver = new_solver_session
249
+ app_name = "test"
250
+ create_datamodel_root_in_server(solver, rule_str, app_name)
251
+ service = solver._se_service
252
+ root = create_root_using_datamodelgen(service, app_name)
253
+ called = 0
254
+ value = None
255
+
256
+ def cb(val):
257
+ nonlocal called
258
+ nonlocal value
259
+ value = val
260
+ called += 1
261
+
262
+ subscription = service.add_on_attribute_changed(app_name, "/A", "x", root.A, cb)
263
+ assert called == 0
264
+ assert value is None
265
+ service.set_state(app_name, "/A/X", "cde")
266
+ timeout_loop(lambda: called == 1, timeout=5)
267
+ assert called == 1
268
+ assert value == "cde"
269
+ service.set_state(app_name, "/A/X", "xyz")
270
+ timeout_loop(lambda: called == 2, timeout=5)
271
+ assert called == 2
272
+ assert value == "xyz"
273
+ subscription.unsubscribe()
274
+ service.set_state(app_name, "/A/X", "abc")
275
+ time.sleep(5)
276
+ assert called == 2
277
+ assert value == "xyz"
278
+
279
+
280
+ @pytest.mark.fluent_version(">=25.2")
281
+ def test_datamodel_api_on_command_attribute_changed(
282
+ datamodel_api_version_all, new_solver_session
283
+ ):
284
+ solver = new_solver_session
285
+ app_name = "test"
286
+ create_datamodel_root_in_server(solver, rule_str, app_name)
287
+ service = solver._se_service
288
+ root = create_root_using_datamodelgen(service, app_name)
289
+ called = 0
290
+ value = None
291
+
292
+ def cb(val):
293
+ nonlocal called
294
+ nonlocal value
295
+ value = val
296
+ called += 1
297
+
298
+ subscription = service.add_on_command_attribute_changed(
299
+ app_name, "/", "C", "x", root.C, cb
300
+ )
301
+ assert called == 0
302
+ assert value is None
303
+ service.set_state(app_name, "/A/X", "cde")
304
+ timeout_loop(lambda: called == 1, timeout=5)
305
+ assert called == 1
306
+ assert value == "cde"
307
+ service.set_state(app_name, "/A/X", "xyz")
308
+ timeout_loop(lambda: called == 2, timeout=5)
309
+ assert called == 2
310
+ # TODO: value is still "cde" in both old and new API
311
+ # assert value == "xyz"
312
+ subscription.unsubscribe()
313
+ service.set_state(app_name, "/A/X", "abc")
314
+ time.sleep(5)
315
+ assert called == 2
316
+ # Commented out because of the issue above
317
+ # assert value == "xyz"
318
+
319
+
320
+ @pytest.mark.fluent_version(">=25.2")
321
+ def test_datamodel_api_on_command_executed(
322
+ datamodel_api_version_all, new_solver_session
323
+ ):
324
+ solver = new_solver_session
325
+ app_name = "test"
326
+ create_datamodel_root_in_server(solver, rule_str, app_name)
327
+ service = solver._se_service
328
+ root = create_root_using_datamodelgen(service, app_name)
329
+ executed = 0
330
+ command = None
331
+ arguments = None
332
+
333
+ def cb(obj, cmd, args):
334
+ nonlocal executed
335
+ nonlocal command
336
+ nonlocal arguments
337
+ command = cmd
338
+ arguments = args
339
+ executed += 1
340
+
341
+ # TODO: In C++ API, we don't need to pass the command name
342
+ subscription = service.add_on_command_executed(app_name, "/", root, cb)
343
+ assert executed == 0
344
+ assert command is None
345
+ assert arguments is None
346
+ service.execute_command(app_name, "/", "C", dict(X="abc"))
347
+ timeout_loop(lambda: executed == 1, timeout=5)
348
+ assert executed == 1
349
+ assert command == "C"
350
+ assert arguments == {"X": "abc"}
351
+ subscription.unsubscribe()
352
+ service.execute_command(app_name, "/", "C", dict(X="uvw"))
353
+ time.sleep(5)
354
+ assert executed == 1
355
+ assert command == "C"
356
+ assert arguments == {"X": "abc"}
357
+
358
+
359
+ @pytest.mark.fluent_version(">=25.2")
360
+ def test_datamodel_api_get_state(datamodel_api_version_all, new_solver_session):
361
+ solver = new_solver_session
362
+ app_name = "test"
363
+ create_datamodel_root_in_server(solver, rule_str, app_name)
364
+ service = solver._se_service
365
+ assert service.get_state(app_name, "/A/X") == "ijk"
366
+
367
+
368
+ @pytest.mark.fluent_version(">=25.2")
369
+ def test_datamodel_api_set_state(datamodel_api_version_all, new_solver_session):
370
+ solver = new_solver_session
371
+ app_name = "test"
372
+ create_datamodel_root_in_server(solver, rule_str, app_name)
373
+ service = solver._se_service
374
+ service.set_state(app_name, "/A/X", "new_val")
375
+ assert service.get_state(app_name, "/A/X") == "new_val"
376
+
377
+
378
+ @pytest.mark.fluent_version(">=25.2")
379
+ def test_datamodel_api_update_dict(datamodel_api_version_all, new_solver_session):
380
+ solver = new_solver_session
381
+ app_name = "test"
382
+ create_datamodel_root_in_server(solver, rule_str, app_name)
383
+ service = solver._se_service
384
+ service.update_dict(app_name, "/G/H", {"X": "abc"})
385
+ assert service.get_state(app_name, "/G/H") == {"X": "abc"}
386
+
387
+
388
+ @pytest.mark.fluent_version(">=25.2")
389
+ def test_datamodel_api_on_bad_input(
390
+ datamodel_api_version_all, request, new_solver_session
391
+ ):
392
+ solver = new_solver_session
393
+ app_name = "test"
394
+ create_datamodel_root_in_server(solver, rule_str, app_name)
395
+ service = solver._se_service
396
+ root = create_root_using_datamodelgen(service, app_name)
397
+ test_name = request.node.name
398
+ new_api = test_name.endswith("[new]")
399
+ with pytest.raises(SubscribeEventError):
400
+ service.add_on_child_created(app_name, "", "", root, lambda _: None)
401
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
402
+ service.add_on_child_created(app_name, "/BB", "B", root, lambda _: None)
403
+ with pytest.raises(SubscribeEventError):
404
+ service.add_on_child_created(app_name, "/", "A", root, lambda _: None)
405
+ with pytest.raises(SubscribeEventError):
406
+ service.add_on_child_created(app_name, "/", "BB", root, lambda _: None)
407
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
408
+ service.add_on_changed(app_name, "/BB", root, lambda _: None)
409
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
410
+ service.add_on_deleted(app_name, "/BB", root, lambda: None)
411
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
412
+ service.add_on_affected(app_name, "/BB", root, lambda _: None)
413
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
414
+ service.add_on_affected_at_type_path(app_name, "/BB", "B", root, lambda: None)
415
+ # TODO: not raised in the old API - issue
416
+ if new_api:
417
+ with pytest.raises(SubscribeEventError):
418
+ service.add_on_affected_at_type_path(
419
+ app_name, "/", "BB", root, lambda: None
420
+ )
421
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
422
+ service.add_on_attribute_changed(
423
+ app_name, "/BB", "isActive", root, lambda _: None
424
+ )
425
+ with pytest.raises(SubscribeEventError):
426
+ service.add_on_attribute_changed(app_name, "/A", "", root, lambda _: None)
427
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
428
+ service.add_on_command_attribute_changed(
429
+ app_name, "/BB", "C", "isActive", root, lambda _: None
430
+ )
431
+ with pytest.raises(SubscribeEventError):
432
+ service.add_on_command_attribute_changed(
433
+ app_name, "/A", "CC", "", root, lambda _: None
434
+ )
435
+ with pytest.raises(SubscribeEventError):
436
+ service.add_on_command_attribute_changed(
437
+ app_name, "/", "CC", "isActive", root, lambda _: None
438
+ )
439
+ with pytest.raises(RuntimeError if new_api else SubscribeEventError): # TODO: issue
440
+ service.add_on_command_executed(app_name, "/BB", root, lambda _: None)
441
+
442
+
443
+ @pytest.mark.fluent_version(">=25.2")
444
+ def test_datamodel_api_static_info(datamodel_api_version_all, new_solver_session):
445
+ solver = new_solver_session
446
+ app_name = "test"
447
+ create_datamodel_root_in_server(solver, rule_str, app_name)
448
+ service = solver._se_service
449
+ assert service.get_static_info(app_name)
@@ -3,17 +3,14 @@ from time import sleep
3
3
 
4
4
  from google.protobuf.json_format import MessageToDict
5
5
  import pytest
6
+ from util import create_datamodel_root_in_server, create_root_using_datamodelgen
6
7
 
7
8
  from ansys.api.fluent.v0 import datamodel_se_pb2
8
9
  from ansys.api.fluent.v0.variant_pb2 import Variant
9
10
  import ansys.fluent.core as pyfluent
10
11
  from ansys.fluent.core import examples
11
12
  from ansys.fluent.core.services.datamodel_se import (
12
- PyCommand,
13
- PyMenu,
14
13
  PyMenuGeneric,
15
- PyNamedObjectContainer,
16
- PyTextual,
17
14
  ReadOnlyObjectError,
18
15
  _convert_value_to_variant,
19
16
  _convert_variant_to_value,
@@ -21,6 +18,7 @@ from ansys.fluent.core.services.datamodel_se import (
21
18
  )
22
19
  from ansys.fluent.core.streaming_services.datamodel_streaming import DatamodelStream
23
20
  from ansys.fluent.core.utils.execution import timeout_loop
21
+ from ansys.fluent.core.utils.fluent_version import FluentVersion
24
22
 
25
23
 
26
24
  @pytest.mark.parametrize(
@@ -58,8 +56,13 @@ def test_event_subscription(new_meshing_session):
58
56
  "/workflow/affected/TaskObject",
59
57
  "/workflow/attribute_changed/TaskObject:TaskObject1/TaskList/isActive",
60
58
  "/workflow/command_attribute_changed/InitializeWorkflow/arguments",
61
- "/workflow/command_executed/InitializeWorkflow",
62
59
  ]
60
+ version = session.get_fluent_version()
61
+ if version < FluentVersion.v252:
62
+ tags.append("/workflow/command_executed/InitializeWorkflow")
63
+ else:
64
+ # TODO: path should be appended to the tag
65
+ tags.append("/workflow/command_executed")
63
66
  request = datamodel_se_pb2.SubscribeEventsRequest()
64
67
  e1 = request.eventrequest.add(rules="workflow")
65
68
  e1.createdEventRequest.parentpath = ""
@@ -125,7 +128,7 @@ def test_add_on_deleted(new_meshing_session):
125
128
  meshing.workflow.InitializeWorkflow(WorkflowType="Watertight Geometry")
126
129
  data = []
127
130
  _ = meshing.workflow.TaskObject["Import Geometry"].add_on_deleted(
128
- lambda obj: data.append(convert_path_to_se_path(obj.path))
131
+ lambda: data.append(True)
129
132
  )
130
133
  assert data == []
131
134
  meshing.workflow.InitializeWorkflow(WorkflowType="Fault-tolerant Meshing")
@@ -233,9 +236,15 @@ def test_add_on_affected_at_type_path(new_meshing_session):
233
236
  def test_add_on_command_executed(new_meshing_session):
234
237
  meshing = new_meshing_session
235
238
  data = []
236
- subscription = meshing.meshing.add_on_command_executed(
237
- "ImportGeometry", lambda obj, command, args: data.append(True)
238
- )
239
+ version = meshing.get_fluent_version()
240
+ if version < FluentVersion.v252:
241
+ subscription = meshing.meshing.add_on_command_executed_old(
242
+ "ImportGeometry", lambda obj, command, args: data.append(True)
243
+ )
244
+ else:
245
+ subscription = meshing.meshing.add_on_command_executed(
246
+ lambda obj, command, args: data.append(True)
247
+ )
239
248
  assert data == []
240
249
  meshing.workflow.InitializeWorkflow(WorkflowType="Watertight Geometry")
241
250
  import_file_name = examples.download_file(
@@ -543,47 +552,12 @@ test_rules = (
543
552
  )
544
553
 
545
554
 
546
- class test_root(PyMenu):
547
- def __init__(self, service, rules, path):
548
- self.A = self.__class__.A(service, rules, path + [("A", "")])
549
- super().__init__(service, rules, path)
550
-
551
- class A(PyNamedObjectContainer):
552
- class _A(PyMenu):
553
- def __init__(self, service, rules, path):
554
- self.B = self.__class__.B(service, rules, path + [("B", "")])
555
- self.X = self.__class__.X(service, rules, path + [("X", "")])
556
- self.C = self.__class__.C(service, rules, "C", path)
557
- super().__init__(service, rules, path)
558
-
559
- class B(PyNamedObjectContainer):
560
- class _B(PyMenu):
561
- pass
562
-
563
- class X(PyTextual):
564
- pass
565
-
566
- class C(PyCommand):
567
- pass
568
-
569
-
570
- def _create_datamodel_root(session, rules_str) -> PyMenu:
571
- rules_file_name = "test.fdl"
572
- session.scheme_eval.scheme_eval(
573
- f'(with-output-to-file "{rules_file_name}" (lambda () (format "~a" "{rules_str}")))'
574
- )
575
- session.scheme_eval.scheme_eval(
576
- '(state/register-new-state-engine "test" "test.fdl")'
577
- )
578
- session.scheme_eval.scheme_eval(f'(remove-file "{rules_file_name}")')
579
- assert session.scheme_eval.scheme_eval('(state/find-root "test")') > 0
580
- return test_root(session._se_service, "test", [])
581
-
582
-
583
555
  @pytest.mark.fluent_version(">=24.2")
584
556
  def test_on_child_created_lifetime(new_solver_session):
585
557
  solver = new_solver_session
586
- root = _create_datamodel_root(solver, test_rules)
558
+ app_name = "test"
559
+ create_datamodel_root_in_server(solver, test_rules, app_name)
560
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
587
561
  root.A["A1"] = {}
588
562
  data = []
589
563
  _ = root.A["A1"].add_on_child_created("B", lambda _: data.append(1))
@@ -601,11 +575,13 @@ def test_on_child_created_lifetime(new_solver_session):
601
575
  @pytest.mark.fluent_version(">=24.2")
602
576
  def test_on_deleted_lifetime(new_solver_session):
603
577
  solver = new_solver_session
604
- root = _create_datamodel_root(solver, test_rules)
578
+ app_name = "test"
579
+ create_datamodel_root_in_server(solver, test_rules, app_name)
580
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
605
581
  root.A["A1"] = {}
606
582
  data = []
607
- _ = root.A["A1"].add_on_deleted(lambda _: data.append(1))
608
- root.A["A1"].add_on_deleted(lambda _: data.append(2))
583
+ _ = root.A["A1"].add_on_deleted(lambda: data.append(1))
584
+ root.A["A1"].add_on_deleted(lambda: data.append(2))
609
585
  gc.collect()
610
586
  assert "/test/deleted/A:A1" in solver._se_service.subscriptions
611
587
  assert "/test/deleted/A:A1-1" in solver._se_service.subscriptions
@@ -622,7 +598,9 @@ def test_on_deleted_lifetime(new_solver_session):
622
598
  @pytest.mark.fluent_version(">=24.2")
623
599
  def test_on_changed_lifetime(new_solver_session):
624
600
  solver = new_solver_session
625
- root = _create_datamodel_root(solver, test_rules)
601
+ app_name = "test"
602
+ create_datamodel_root_in_server(solver, test_rules, app_name)
603
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
626
604
  root.A["A1"] = {}
627
605
  data = []
628
606
  _ = root.A["A1"].X.add_on_changed(lambda _: data.append(1))
@@ -640,7 +618,9 @@ def test_on_changed_lifetime(new_solver_session):
640
618
  @pytest.mark.fluent_version(">=24.2")
641
619
  def test_on_affected_lifetime(new_solver_session):
642
620
  solver = new_solver_session
643
- root = _create_datamodel_root(solver, test_rules)
621
+ app_name = "test"
622
+ create_datamodel_root_in_server(solver, test_rules, app_name)
623
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
644
624
  root.A["A1"] = {}
645
625
  data = []
646
626
  _ = root.A["A1"].add_on_affected(lambda _: data.append(1))
@@ -658,7 +638,9 @@ def test_on_affected_lifetime(new_solver_session):
658
638
  @pytest.mark.fluent_version(">=24.2")
659
639
  def test_on_affected_at_type_path_lifetime(new_solver_session):
660
640
  solver = new_solver_session
661
- root = _create_datamodel_root(solver, test_rules)
641
+ app_name = "test"
642
+ create_datamodel_root_in_server(solver, test_rules, app_name)
643
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
662
644
  root.A["A1"] = {}
663
645
  data = []
664
646
  _ = root.A["A1"].add_on_affected_at_type_path("B", lambda _: data.append(1))
@@ -676,25 +658,37 @@ def test_on_affected_at_type_path_lifetime(new_solver_session):
676
658
  @pytest.mark.fluent_version(">=24.2")
677
659
  def test_on_command_executed_lifetime(new_solver_session):
678
660
  solver = new_solver_session
679
- root = _create_datamodel_root(solver, test_rules)
661
+ app_name = "test"
662
+ create_datamodel_root_in_server(solver, test_rules, app_name)
663
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
680
664
  root.A["A1"] = {}
681
665
  data = []
682
- _ = root.A["A1"].add_on_command_executed("C", lambda *args: data.append(1))
683
- root.A["A1"].add_on_command_executed("C", lambda *args: data.append(2))
666
+ version = solver.get_fluent_version()
667
+ if version < FluentVersion.v252:
668
+ _ = root.A["A1"].add_on_command_executed_old("C", lambda *args: data.append(1))
669
+ root.A["A1"].add_on_command_executed_old("C", lambda *args: data.append(2))
670
+ tags = ["/test/command_executed/A:A1/C", "/test/command_executed/A:A1/C-1"]
671
+ else:
672
+ _ = root.A["A1"].add_on_command_executed(lambda *args: data.append(1))
673
+ root.A["A1"].add_on_command_executed(lambda *args: data.append(2))
674
+ # TODO: path should be appended to the tag
675
+ tags = ["/test/command_executed", "/test/command_executed-1"]
684
676
  gc.collect()
685
- assert "/test/command_executed/A:A1/C" in solver._se_service.subscriptions
686
- assert "/test/command_executed/A:A1/C-1" in solver._se_service.subscriptions
677
+ for tag in tags:
678
+ assert tag in solver._se_service.subscriptions
687
679
  root.A["A1"].C()
688
680
  assert timeout_loop(lambda: data == [1, 2], 5)
689
681
  del root.A["A1"]
690
- assert "/test/command_executed/A:A1/C" not in solver._se_service.subscriptions
691
- assert "/test/command_executed/A:A1/C-1" not in solver._se_service.subscriptions
682
+ for tag in tags:
683
+ assert tag not in solver._se_service.subscriptions
692
684
 
693
685
 
694
686
  @pytest.mark.fluent_version(">=24.2")
695
687
  def test_on_attribute_changed_lifetime(new_solver_session):
696
688
  solver = new_solver_session
697
- root = _create_datamodel_root(solver, test_rules)
689
+ app_name = "test"
690
+ create_datamodel_root_in_server(solver, test_rules, app_name)
691
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
698
692
  root.A["A1"] = {}
699
693
  data = []
700
694
  _ = root.A["A1"].add_on_attribute_changed("isABC", lambda _: data.append(1))
@@ -714,7 +708,9 @@ def test_on_attribute_changed_lifetime(new_solver_session):
714
708
  @pytest.mark.fluent_version(">=24.2")
715
709
  def test_on_command_attribute_changed_lifetime(new_solver_session):
716
710
  solver = new_solver_session
717
- root = _create_datamodel_root(solver, test_rules)
711
+ app_name = "test"
712
+ create_datamodel_root_in_server(solver, test_rules, app_name)
713
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
718
714
  root.A["A1"] = {}
719
715
  data = []
720
716
  _ = root.A["A1"].add_on_command_attribute_changed(
@@ -748,7 +744,9 @@ def test_on_command_attribute_changed_lifetime(new_solver_session):
748
744
  @pytest.mark.fluent_version(">=24.2")
749
745
  def test_on_affected_lifetime_with_delete_child_objects(new_solver_session):
750
746
  solver = new_solver_session
751
- root = _create_datamodel_root(solver, test_rules)
747
+ app_name = "test"
748
+ create_datamodel_root_in_server(solver, test_rules, app_name)
749
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
752
750
  pyfluent.logging.enable()
753
751
  root.A["A1"] = {}
754
752
  data = []
@@ -767,7 +765,9 @@ def test_on_affected_lifetime_with_delete_child_objects(new_solver_session):
767
765
  @pytest.mark.fluent_version(">=24.2")
768
766
  def test_on_affected_lifetime_with_delete_all_child_objects(new_solver_session):
769
767
  solver = new_solver_session
770
- root = _create_datamodel_root(solver, test_rules)
768
+ app_name = "test"
769
+ create_datamodel_root_in_server(solver, test_rules, app_name)
770
+ root = create_root_using_datamodelgen(solver._se_service, app_name)
771
771
  pyfluent.logging.enable()
772
772
  root.A["A1"] = {}
773
773
  data = []