holado 0.13.22__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.
- holado/__init__.py +358 -0
- holado/common/__init__.py +25 -0
- holado/common/context/__init__.py +25 -0
- holado/common/context/context.py +248 -0
- holado/common/context/service_manager.py +262 -0
- holado/common/context/session_context.py +516 -0
- holado/common/handlers/__init__.py +19 -0
- holado/common/handlers/enums.py +41 -0
- holado/common/handlers/object.py +175 -0
- holado/common/handlers/undefined.py +55 -0
- holado/common/tools/__init__.py +19 -0
- holado/common/tools/gc_manager.py +155 -0
- holado/holado_config.py +45 -0
- holado-0.13.22.dist-info/METADATA +194 -0
- holado-0.13.22.dist-info/RECORD +698 -0
- holado-0.13.22.dist-info/WHEEL +4 -0
- holado-0.13.22.dist-info/licenses/LICENSE +21 -0
- holado_ais/__init__.py +33 -0
- holado_ais/ais/MaritimeIdentificationDigits.csv +295 -0
- holado_ais/ais/ais_manager.py +151 -0
- holado_ais/ais/ais_messages.py +356 -0
- holado_ais/ais/ais_payload.py +35 -0
- holado_ais/ais/enums.py +37 -0
- holado_ais/ais/patch_pyais.py +1174 -0
- holado_ais/tests/behave/steps/__init__.py +17 -0
- holado_ais/tests/behave/steps/ais/__init__.py +0 -0
- holado_ais/tests/behave/steps/ais/ais_manager_steps.py +50 -0
- holado_ais/tests/behave/steps/ais/ais_messages_steps.py +237 -0
- holado_binary/__init__.py +17 -0
- holado_binary/ipc/binary.py +125 -0
- holado_binary/ipc/bit_series.py +307 -0
- holado_binary/tests/behave/steps/__init__.py +17 -0
- holado_binary/tests/behave/steps/ipc/binary_steps.py +57 -0
- holado_binary/tests/behave/steps/ipc/bit_series_steps.py +132 -0
- holado_context/__init__.py +16 -0
- holado_context/tests/behave/steps/__init__.py +16 -0
- holado_context/tests/behave/steps/private/__init__.py +16 -0
- holado_context/tests/behave/steps/private/common/context_steps.py +68 -0
- holado_core/__init__.py +32 -0
- holado_core/common/__init__.py +0 -0
- holado_core/common/actors/actions.py +97 -0
- holado_core/common/actors/actor.py +226 -0
- holado_core/common/actors/element_actor.py +32 -0
- holado_core/common/actors/find_actor.py +106 -0
- holado_core/common/actors/tree_actor.py +32 -0
- holado_core/common/actors/verify_actions.py +69 -0
- holado_core/common/block/base.py +122 -0
- holado_core/common/block/block_manager.py +173 -0
- holado_core/common/block/block_method.py +46 -0
- holado_core/common/block/block_steps.py +37 -0
- holado_core/common/block/function.py +42 -0
- holado_core/common/block/scope_function.py +28 -0
- holado_core/common/block/scope_manager.py +238 -0
- holado_core/common/block/scope_steps.py +141 -0
- holado_core/common/criterias/and_criteria.py +61 -0
- holado_core/common/criterias/criteria.py +78 -0
- holado_core/common/criterias/or_criteria.py +64 -0
- holado_core/common/criterias/tools/criteria_context.py +20 -0
- holado_core/common/criterias/tools/criteria_parameters.py +18 -0
- holado_core/common/drivers/driver.py +153 -0
- holado_core/common/drivers/element_driver.py +30 -0
- holado_core/common/drivers/element_internal_api.py +239 -0
- holado_core/common/drivers/internal_api.py +40 -0
- holado_core/common/drivers/tree_driver.py +30 -0
- holado_core/common/drivers/tree_internal_api.py +176 -0
- holado_core/common/exceptions/__init__.py +0 -0
- holado_core/common/exceptions/element_exception.py +28 -0
- holado_core/common/exceptions/exceptions.py +24 -0
- holado_core/common/exceptions/functional_exception.py +21 -0
- holado_core/common/exceptions/holado_exception.py +25 -0
- holado_core/common/exceptions/technical_exception.py +27 -0
- holado_core/common/exceptions/timeout_exception.py +20 -0
- holado_core/common/exceptions/verify_exception.py +20 -0
- holado_core/common/finders/after_in_tree_finder.py +87 -0
- holado_core/common/finders/element_finder.py +60 -0
- holado_core/common/finders/else_finder.py +105 -0
- holado_core/common/finders/finder.py +478 -0
- holado_core/common/finders/or_finder.py +98 -0
- holado_core/common/finders/then_finder.py +157 -0
- holado_core/common/finders/tools/enums.py +30 -0
- holado_core/common/finders/tools/find_builder.py +118 -0
- holado_core/common/finders/tools/find_context.py +405 -0
- holado_core/common/finders/tools/find_info.py +27 -0
- holado_core/common/finders/tools/find_parameters.py +240 -0
- holado_core/common/finders/tools/find_updater.py +95 -0
- holado_core/common/finders/tools/finder_info.py +26 -0
- holado_core/common/finders/tree_finder.py +146 -0
- holado_core/common/handlers/__init__.py +0 -0
- holado_core/common/handlers/abstracts/base_redo.py +702 -0
- holado_core/common/handlers/abstracts/get_or_create.py +120 -0
- holado_core/common/handlers/element_holder.py +122 -0
- holado_core/common/handlers/enums.py +23 -0
- holado_core/common/handlers/exceptions/redo_exceptions.py +28 -0
- holado_core/common/handlers/features/resource_by_name.py +187 -0
- holado_core/common/handlers/features/resource_by_type.py +174 -0
- holado_core/common/handlers/redo.py +119 -0
- holado_core/common/handlers/wait.py +127 -0
- holado_core/common/inspectors/element_inspector.py +57 -0
- holado_core/common/inspectors/inspector.py +221 -0
- holado_core/common/inspectors/tools/inspect_builder.py +169 -0
- holado_core/common/inspectors/tools/inspect_context.py +69 -0
- holado_core/common/inspectors/tools/inspect_parameters.py +181 -0
- holado_core/common/inspectors/tree_inspector.py +73 -0
- holado_core/common/resource/persisted_data_manager.py +113 -0
- holado_core/common/resource/persisted_method_to_call_manager.py +263 -0
- holado_core/common/resource/resource_manager.py +126 -0
- holado_core/common/resource/table_data_manager.py +110 -0
- holado_core/common/tables/__init__.py +1 -0
- holado_core/common/tables/comparators/__init__.py +0 -0
- holado_core/common/tables/comparators/boolean_table_cell_comparator.py +25 -0
- holado_core/common/tables/comparators/bytes_table_cell_comparator.py +25 -0
- holado_core/common/tables/comparators/datetime_table_cell_comparator.py +24 -0
- holado_core/common/tables/comparators/float_table_cell_comparator.py +31 -0
- holado_core/common/tables/comparators/integer_table_cell_comparator.py +25 -0
- holado_core/common/tables/comparators/internal_table_cell_comparator.py +30 -0
- holado_core/common/tables/comparators/string_table_cell_comparator.py +24 -0
- holado_core/common/tables/comparators/string_table_comparator.py +29 -0
- holado_core/common/tables/comparators/string_table_row_comparator.py +29 -0
- holado_core/common/tables/comparators/table_cell_comparator.py +40 -0
- holado_core/common/tables/comparators/table_comparator.py +209 -0
- holado_core/common/tables/comparators/table_comparator_manager.py +60 -0
- holado_core/common/tables/comparators/table_row_comparator.py +116 -0
- holado_core/common/tables/comparators/table_with_header_comparator.py +68 -0
- holado_core/common/tables/converters/__init__.py +0 -0
- holado_core/common/tables/converters/table_converter.py +233 -0
- holado_core/common/tables/enums.py +23 -0
- holado_core/common/tables/table.py +261 -0
- holado_core/common/tables/table_cell.py +126 -0
- holado_core/common/tables/table_manager.py +365 -0
- holado_core/common/tables/table_row.py +169 -0
- holado_core/common/tables/table_with_header.py +242 -0
- holado_core/common/tools/__init__.py +0 -0
- holado_core/common/tools/comparators/comparator.py +151 -0
- holado_core/common/tools/comparators/object_comparator.py +21 -0
- holado_core/common/tools/converters/converter.py +118 -0
- holado_core/common/tools/path_manager.py +238 -0
- holado_core/common/tools/string_tools.py +144 -0
- holado_core/common/tools/tools.py +197 -0
- holado_core/tests/behave/steps/__init__.py +20 -0
- holado_core/tests/behave/steps/common/__init__.py +0 -0
- holado_core/tests/behave/steps/common/common_steps.py +137 -0
- holado_core/tests/behave/steps/common/config_steps.py +42 -0
- holado_core/tests/behave/steps/common/resource_steps.py +62 -0
- holado_core/tests/behave/steps/common/tables_steps.py +560 -0
- holado_core/tools/__init__.py +0 -0
- holado_core/tools/abstracts/__init__.py +0 -0
- holado_core/tools/abstracts/blocking_command_service.py +64 -0
- holado_core/tools/abstracts/service.py +48 -0
- holado_crypto/__init__.py +31 -0
- holado_crypto/crypto/crypto.py +108 -0
- holado_crypto/crypto/key.py +92 -0
- holado_crypto/crypto/tcpbin.py +105 -0
- holado_crypto/crypto/transport/__init__.py +0 -0
- holado_crypto/crypto/transport/crc.py +40 -0
- holado_crypto/tests/behave/steps/__init__.py +18 -0
- holado_crypto/tests/behave/steps/crypto_steps.py +112 -0
- holado_crypto/tests/behave/steps/key_steps.py +82 -0
- holado_crypto/tests/behave/steps/tcpbin_steps.py +79 -0
- holado_data/__init__.py +31 -0
- holado_data/data/generator/base.py +93 -0
- holado_data/data/generator/generator_manager.py +27 -0
- holado_data/data/generator/python_generator.py +30 -0
- holado_data/tests/behave/steps/__init__.py +17 -0
- holado_data/tests/behave/steps/data/generator_steps.py +91 -0
- holado_data/tests/behave/steps/tools/utils_steps.py +59 -0
- holado_db/__init__.py +32 -0
- holado_db/tests/behave/steps/__init__.py +18 -0
- holado_db/tests/behave/steps/tools/db/db_client_steps.py +134 -0
- holado_db/tests/behave/steps/tools/db/postgresql_client_steps.py +59 -0
- holado_db/tests/behave/steps/tools/db/sqlite_client_steps.py +57 -0
- holado_db/tools/db/clients/base/db_audit.py +94 -0
- holado_db/tools/db/clients/base/db_client.py +344 -0
- holado_db/tools/db/clients/postgresql/postgresql_audit.py +75 -0
- holado_db/tools/db/clients/postgresql/postgresql_client.py +84 -0
- holado_db/tools/db/clients/sqlite/sqlite_audit.py +70 -0
- holado_db/tools/db/clients/sqlite/sqlite_client.py +60 -0
- holado_db/tools/db/db_manager.py +109 -0
- holado_db/tools/db/query/base/query_builder.py +138 -0
- holado_db/tools/db/query/pypika/pypika_query_builder.py +244 -0
- holado_db/tools/db/query/query_manager.py +77 -0
- holado_django/__init__.py +31 -0
- holado_django/server/HOWTO.txt +27 -0
- holado_django/server/django_projects/rest_api/db.sqlite3 +0 -0
- holado_django/server/django_projects/rest_api/manage.py +22 -0
- holado_django/server/django_projects/rest_api/rest_api/__init__.py +0 -0
- holado_django/server/django_projects/rest_api/rest_api/application/__init__.py +0 -0
- holado_django/server/django_projects/rest_api/rest_api/application/admin.py +3 -0
- holado_django/server/django_projects/rest_api/rest_api/application/apps.py +9 -0
- holado_django/server/django_projects/rest_api/rest_api/application/migrations/__init__.py +0 -0
- holado_django/server/django_projects/rest_api/rest_api/application/models.py +3 -0
- holado_django/server/django_projects/rest_api/rest_api/application/tests.py +3 -0
- holado_django/server/django_projects/rest_api/rest_api/application/views.py +6 -0
- holado_django/server/django_projects/rest_api/rest_api/asgi.py +16 -0
- holado_django/server/django_projects/rest_api/rest_api/settings.py +130 -0
- holado_django/server/django_projects/rest_api/rest_api/urls.py +35 -0
- holado_django/server/django_projects/rest_api/rest_api/wsgi.py +16 -0
- holado_django/server/django_server.py +110 -0
- holado_django/server/grpc_django_server.py +57 -0
- holado_django/server/patch_djangogrpcframework.py +46 -0
- holado_django/tests/behave/steps/__init__.py +16 -0
- holado_django/tests/behave/steps/django_server_steps.py +83 -0
- holado_docker/__init__.py +25 -0
- holado_docker/sdk/docker/container_logs.py +447 -0
- holado_docker/sdk/docker/docker_client.py +537 -0
- holado_docker/sdk/docker/docker_service.py +71 -0
- holado_docker/tests/behave/steps/__init__.py +16 -0
- holado_docker/tests/behave/steps/sdk/docker/container_logs_steps.py +47 -0
- holado_examples/projects/server_rest/server_rest_example/initialize_holado.py +72 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/db.sqlite3 +0 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/manage.py +22 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/__init__.py +0 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/__init__.py +0 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/admin.py +3 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/apps.py +7 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/migrations/__init__.py +0 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/models.py +3 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/serializers.py +15 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/tests.py +3 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/application/views.py +24 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/asgi.py +16 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/settings.py +130 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/urls.py +31 -0
- holado_examples/projects/server_rest/server_rest_example/rest_api/rest_api/wsgi.py +16 -0
- holado_examples/projects/server_rest/server_rest_example/rest_server.py +37 -0
- holado_examples/scripts/script_custom_initialization.py +16 -0
- holado_examples/scripts/script_minimal_initialization.py +23 -0
- holado_examples/tests/behave/testing_solution/__main__.py +13 -0
- holado_examples/tests/behave/testing_solution/behave_environment.py +35 -0
- holado_examples/tests/behave/testing_solution/environment.py +36 -0
- holado_examples/tests/behave/testing_solution/features/Configuration/Actions/configure_system.feature +10 -0
- holado_examples/tests/behave/testing_solution/features/NonReg/example.feature +26 -0
- holado_examples/tests/behave/testing_solution/initialize_holado.py +62 -0
- holado_examples/tests/behave/testing_solution/logging.conf +102 -0
- holado_examples/tests/behave/testing_solution/requirements.txt +5 -0
- holado_examples/tests/behave/testing_solution/run_test.sh +7 -0
- holado_examples/tests/behave/testing_solution/run_test_nonreg.sh +6 -0
- holado_examples/tests/behave/testing_solution/src/common/tools/path_manager.py +40 -0
- holado_examples/tests/behave/testing_solution/src/config/config_manager.py +30 -0
- holado_examples/tests/behave/testing_solution/src/context/session_context.py +45 -0
- holado_examples/tests/behave/testing_solution/steps/config_steps.py +21 -0
- holado_examples/tests/behave/testing_solution/steps/public_steps.py +10 -0
- holado_grpc/TODO +8 -0
- holado_grpc/__init__.py +40 -0
- holado_grpc/api/rpc/TODO.txt +4 -0
- holado_grpc/api/rpc/grpc_client.py +210 -0
- holado_grpc/api/rpc/grpc_manager.py +81 -0
- holado_grpc/ipc/rpc/__init__.py +0 -0
- holado_grpc/ipc/rpc/grpc_compiler.py +45 -0
- holado_grpc/ipc/rpc/grpc_services.py +165 -0
- holado_grpc/tests/behave/steps/__init__.py +16 -0
- holado_grpc/tests/behave/steps/api/grpc_client_steps.py +173 -0
- holado_grpc/tests/behave/steps/private/__init__.py +16 -0
- holado_grpc/tests/behave/steps/private/api/grpc_steps.py +77 -0
- holado_helper/__init__.py +35 -0
- holado_helper/debug/README.txt +32 -0
- holado_helper/debug/memory/memory_profiler.py +106 -0
- holado_helper/docker/init_user.sh +24 -0
- holado_helper/docker/logging.conf +44 -0
- holado_helper/docker/run_holado_test_nonreg_in_docker.sh +120 -0
- holado_helper/docker/run_terminal_in_docker.sh +101 -0
- holado_helper/holado_module_template/__init__.py +38 -0
- holado_helper/holado_module_template/tests/behave/steps/__init__.py +16 -0
- holado_helper/holado_module_template/tests/behave/steps/private/__init__.py +16 -0
- holado_helper/initialize_holado.py +72 -0
- holado_helper/script/action.py +130 -0
- holado_helper/script/action_script.py +477 -0
- holado_helper/script/any_action_script.py +126 -0
- holado_helper/script/behave_action_script.py +99 -0
- holado_helper/script/csv_action_script.py +142 -0
- holado_helper/script/initialize_script.py +95 -0
- holado_helper/script/input_output_script.py +136 -0
- holado_helper/script/job.py +75 -0
- holado_helper/script/json_action_script.py +104 -0
- holado_helper/script/script.py +110 -0
- holado_json/__init__.py +16 -0
- holado_json/filesystem/json_file.py +94 -0
- holado_json/filesystem/stream_json_file.py +117 -0
- holado_json/ipc/json.py +146 -0
- holado_json/ipc/json_converter.py +69 -0
- holado_json/ipc/json_types.py +183 -0
- holado_json/tests/behave/steps/__init__.py +16 -0
- holado_json/tests/behave/steps/ipc/__init__.py +0 -0
- holado_json/tests/behave/steps/ipc/json_steps.py +131 -0
- holado_keycloak/__init__.py +16 -0
- holado_keycloak/tests/behave/steps/__init__.py +16 -0
- holado_keycloak/tests/behave/steps/tools/keycloak_client_steps.py +73 -0
- holado_keycloak/tools/keycloak/__init__.py +0 -0
- holado_keycloak/tools/keycloak/keycloak_client.py +90 -0
- holado_logging/__init__.py +38 -0
- holado_logging/common/logging/holado_logger.py +71 -0
- holado_logging/common/logging/log_config.py +163 -0
- holado_logging/common/logging/log_manager.py +335 -0
- holado_multitask/__init__.py +33 -0
- holado_multitask/multiprocessing/context/process_context.py +35 -0
- holado_multitask/multiprocessing/function_process.py +102 -0
- holado_multitask/multiprocessing/periodic_function_process.py +137 -0
- holado_multitask/multiprocessing/process.py +213 -0
- holado_multitask/multiprocessing/processesmanager.py +137 -0
- holado_multitask/multitasking/multitask_manager.py +464 -0
- holado_multitask/multithreading/__init__.py +0 -0
- holado_multitask/multithreading/context/thread_context.py +86 -0
- holado_multitask/multithreading/functionthreaded.py +129 -0
- holado_multitask/multithreading/loopfunctionthreaded.py +45 -0
- holado_multitask/multithreading/loopthread.py +110 -0
- holado_multitask/multithreading/periodicfunctionthreaded.py +135 -0
- holado_multitask/multithreading/reflection/inspect.py +47 -0
- holado_multitask/multithreading/reflection/sys.py +29 -0
- holado_multitask/multithreading/reflection/traceback.py +35 -0
- holado_multitask/multithreading/thread.py +203 -0
- holado_multitask/multithreading/threadsmanager.py +167 -0
- holado_multitask/multithreading/timer.py +51 -0
- holado_multitask/tests/behave/steps/__init__.py +17 -0
- holado_multitask/tests/behave/steps/multiprocessing_steps.py +138 -0
- holado_multitask/tests/behave/steps/multithreading_steps.py +129 -0
- holado_protobuf/__init__.py +61 -0
- holado_protobuf/ipc/protobuf/__init__.py +0 -0
- holado_protobuf/ipc/protobuf/abstracts/type.py +45 -0
- holado_protobuf/ipc/protobuf/protobuf_compiler.py +118 -0
- holado_protobuf/ipc/protobuf/protobuf_converter.py +153 -0
- holado_protobuf/ipc/protobuf/protobuf_messages.py +968 -0
- holado_protobuf/ipc/protobuf/protobuf_modifier.py +65 -0
- holado_protobuf/ipc/protobuf/types/__init__.py +0 -0
- holado_protobuf/ipc/protobuf/types/google/__init__.py +0 -0
- holado_protobuf/ipc/protobuf/types/google/protobuf.py +124 -0
- holado_protobuf/tests/behave/steps/__init__.py +16 -0
- holado_protobuf/tests/behave/steps/ipc/protobuf_steps.py +297 -0
- holado_python/__init__.py +36 -0
- holado_python/common/enums.py +34 -0
- holado_python/common/iterables.py +38 -0
- holado_python/common/tools/comparators/boolean_comparator.py +37 -0
- holado_python/common/tools/comparators/bytes_comparator.py +48 -0
- holado_python/common/tools/comparators/datetime_comparator.py +74 -0
- holado_python/common/tools/comparators/float_comparator.py +97 -0
- holado_python/common/tools/comparators/integer_comparator.py +37 -0
- holado_python/common/tools/comparators/string_comparator.py +99 -0
- holado_python/common/tools/comparators/type_comparator.py +31 -0
- holado_python/common/tools/datetime.py +341 -0
- holado_python/standard_library/csv.py +207 -0
- holado_python/standard_library/hashlib.py +110 -0
- holado_python/standard_library/multiprocessing.py +62 -0
- holado_python/standard_library/queue.py +79 -0
- holado_python/standard_library/socket/blocking_socket.py +219 -0
- holado_python/standard_library/socket/echo_server.py +29 -0
- holado_python/standard_library/socket/message_socket.py +152 -0
- holado_python/standard_library/socket/non_blocking_socket.py +172 -0
- holado_python/standard_library/socket/socket.py +411 -0
- holado_python/standard_library/ssl/resources/certificates/NOTES.txt +5 -0
- holado_python/standard_library/ssl/resources/certificates/localhost.crt +19 -0
- holado_python/standard_library/ssl/resources/certificates/localhost.key +28 -0
- holado_python/standard_library/ssl/ssl.py +131 -0
- holado_python/standard_library/typing.py +192 -0
- holado_python/tests/behave/steps/__init__.py +27 -0
- holado_python/tests/behave/steps/builtins/str_steps.py +45 -0
- holado_python/tests/behave/steps/convert_steps.py +59 -0
- holado_python/tests/behave/steps/iterable_steps.py +87 -0
- holado_python/tests/behave/steps/standard_library/csv_steps.py +134 -0
- holado_python/tests/behave/steps/standard_library/datetime_steps.py +163 -0
- holado_python/tests/behave/steps/standard_library/hashlib_steps.py +57 -0
- holado_python/tests/behave/steps/standard_library/multiprocessing_steps.py +56 -0
- holado_python/tests/behave/steps/standard_library/queue_steps.py +358 -0
- holado_python/tests/behave/steps/standard_library/socket_steps.py +384 -0
- holado_python/tests/behave/steps/standard_library/ssl_steps.py +71 -0
- holado_rabbitmq/__init__.py +28 -0
- holado_rabbitmq/tests/behave/steps/__init__.py +17 -0
- holado_rabbitmq/tests/behave/steps/tools/rabbitmq_client_steps.py +565 -0
- holado_rabbitmq/tests/behave/steps/tools/rabbitmq_server_steps.py +64 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_blocking_client.py +333 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_client.py +678 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_manager.py +146 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_select_client.py +428 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_server.py +24 -0
- holado_redis/__init__.py +17 -0
- holado_redis/tests/behave/steps/__init__.py +16 -0
- holado_redis/tests/behave/steps/tools/redis_client_steps.py +101 -0
- holado_redis/tools/redis/TODO.txt +7 -0
- holado_redis/tools/redis/redis_client.py +190 -0
- holado_redis/tools/redis/redis_manager.py +38 -0
- holado_report/__init__.py +36 -0
- holado_report/campaign/campaign_manager.py +348 -0
- holado_report/report/analyze/execution_historic_manager.py +96 -0
- holado_report/report/analyze/scenario_duration_manager.py +245 -0
- holado_report/report/builders/detailed_scenario_report_builder.py +172 -0
- holado_report/report/builders/execution_historic_report_builder.py +132 -0
- holado_report/report/builders/failure_report_builder.py +150 -0
- holado_report/report/builders/report_builder.py +64 -0
- holado_report/report/builders/short_scenario_report_builder.py +94 -0
- holado_report/report/builders/summary_by_category_report_builder.py +103 -0
- holado_report/report/builders/summary_report_builder.py +110 -0
- holado_report/report/builders/summary_scenario_by_category_report_builder.py +109 -0
- holado_report/report/builders/summary_scenario_report_builder.py +81 -0
- holado_report/report/execution_historic.py +144 -0
- holado_report/report/report_manager.py +424 -0
- holado_report/report/reports/base_report.py +163 -0
- holado_report/report/reports/feature_report.py +106 -0
- holado_report/report/reports/scenario_report.py +64 -0
- holado_rest/__init__.py +32 -0
- holado_rest/api/rest/TODO.txt +2 -0
- holado_rest/api/rest/rest_client.py +200 -0
- holado_rest/api/rest/rest_manager.py +72 -0
- holado_rest/tests/behave/steps/__init__.py +16 -0
- holado_rest/tests/behave/steps/api/__init__.py +0 -0
- holado_rest/tests/behave/steps/api/rest_client_steps.py +181 -0
- holado_rest/tests/behave/steps/private/__init__.py +16 -0
- holado_rest/tests/behave/steps/private/api/__init__.py +0 -0
- holado_rest/tests/behave/steps/private/api/rest_steps.py +75 -0
- holado_s3/__init__.py +17 -0
- holado_s3/tests/behave/steps/__init__.py +17 -0
- holado_s3/tests/behave/steps/private/__init__.py +16 -0
- holado_s3/tests/behave/steps/private/tools/s3_steps.py +89 -0
- holado_s3/tests/behave/steps/tools/s3_client_steps.py +403 -0
- holado_s3/tests/behave/steps/tools/s3_server_steps.py +57 -0
- holado_s3/tools/s3/__init__.py +0 -0
- holado_s3/tools/s3/boto3_s3_client.py +59 -0
- holado_s3/tools/s3/minio_client.py +75 -0
- holado_s3/tools/s3/moto_server.py +52 -0
- holado_scripting/__init__.py +54 -0
- holado_scripting/common/tools/dynamic_text_manager.py +73 -0
- holado_scripting/common/tools/evaluate_parameters.py +228 -0
- holado_scripting/common/tools/expression_evaluator.py +389 -0
- holado_scripting/common/tools/variable_manager.py +354 -0
- holado_scripting/tests/behave/steps/__init__.py +22 -0
- holado_scripting/tests/behave/steps/common/tools/variable_convert_steps.py +159 -0
- holado_scripting/tests/behave/steps/common/tools/variable_new_steps.py +130 -0
- holado_scripting/tests/behave/steps/common/tools/variable_steps.py +108 -0
- holado_scripting/tests/behave/steps/common/tools/variable_verify_steps.py +160 -0
- holado_scripting/tests/behave/steps/scenario/function_steps.py +77 -0
- holado_scripting/tests/behave/steps/scenario/if_steps.py +87 -0
- holado_scripting/tests/behave/steps/scenario/loop_steps.py +119 -0
- holado_scripting/text/base/base_function.py +25 -0
- holado_scripting/text/base/base_verify_function.py +25 -0
- holado_scripting/text/base/text_inspecter.py +204 -0
- holado_scripting/text/interpreter/exceptions/interpreter_exception.py +25 -0
- holado_scripting/text/interpreter/functions/function_apply_function.py +60 -0
- holado_scripting/text/interpreter/functions/function_cast.py +60 -0
- holado_scripting/text/interpreter/functions/function_convert.py +57 -0
- holado_scripting/text/interpreter/functions/function_dynamic_value.py +40 -0
- holado_scripting/text/interpreter/functions/function_escape_all_bytes.py +35 -0
- holado_scripting/text/interpreter/functions/function_exists_variable.py +39 -0
- holado_scripting/text/interpreter/functions/function_hex_to_bytes.py +49 -0
- holado_scripting/text/interpreter/functions/function_hex_to_int.py +53 -0
- holado_scripting/text/interpreter/functions/function_to_base_64.py +41 -0
- holado_scripting/text/interpreter/functions/function_to_bytes.py +50 -0
- holado_scripting/text/interpreter/functions/function_to_hex.py +42 -0
- holado_scripting/text/interpreter/functions/function_to_string.py +50 -0
- holado_scripting/text/interpreter/text_interpreter.py +219 -0
- holado_scripting/text/verifier/exceptions/verifier_exception.py +21 -0
- holado_scripting/text/verifier/functions/verify_function_extract_in.py +35 -0
- holado_scripting/text/verifier/functions/verify_function_match_pattern.py +63 -0
- holado_scripting/text/verifier/text_verifier.py +103 -0
- holado_sftp/__init__.py +16 -0
- holado_sftp/tests/behave/steps/__init__.py +17 -0
- holado_sftp/tests/behave/steps/private/__init__.py +16 -0
- holado_sftp/tests/behave/steps/private/tools/sftp_steps.py +78 -0
- holado_sftp/tests/behave/steps/tools/sftp_client_steps.py +94 -0
- holado_sftp/tests/behave/steps/tools/sftp_server_steps.py +82 -0
- holado_sftp/tools/sftp/__init__.py +0 -0
- holado_sftp/tools/sftp/sftp_client.py +103 -0
- holado_sftp/tools/sftp/sftp_server.py +39 -0
- holado_swagger/__init__.py +31 -0
- holado_swagger/swagger_hub/mockserver/mockserver_client.py +82 -0
- holado_swagger/swagger_hub/mockserver/mockserver_manager.py +33 -0
- holado_swagger/tests/behave/steps/__init__.py +16 -0
- holado_swagger/tests/behave/steps/swagger_hub/mockserver_steps.py +74 -0
- holado_system/system/command/command.py +247 -0
- holado_system/system/command/command_result.py +128 -0
- holado_system/system/command/curl_command.py +101 -0
- holado_system/system/command/exceptions.py +59 -0
- holado_system/system/filesystem/file.py +150 -0
- holado_system/system/global_system.py +187 -0
- holado_system/tests/behave/steps/__init__.py +18 -0
- holado_system/tests/behave/steps/system/commands_steps.py +92 -0
- holado_system/tests/behave/steps/system/file_steps.py +231 -0
- holado_system/tests/behave/steps/system/system_steps.py +84 -0
- holado_test/__init__.py +30 -0
- holado_test/behave/__init__.py +0 -0
- holado_test/behave/behave.py +400 -0
- holado_test/behave/behave_environment.py +169 -0
- holado_test/behave/behave_function.py +33 -0
- holado_test/behave/behave_manager.py +558 -0
- holado_test/behave/independant_runner.py +66 -0
- holado_test/behave/scenario/__init__.py +0 -0
- holado_test/behave/scenario/behave_step_tools.py +157 -0
- holado_test/common/context/feature_context.py +81 -0
- holado_test/common/context/scenario_context.py +169 -0
- holado_test/common/context/step_context.py +66 -0
- holado_test/common/exceptions/undefined_step_exception.py +21 -0
- holado_test/scenario/step_tools.py +547 -0
- holado_test/scenario/tester_tools.py +57 -0
- holado_test/test_config.py +26 -0
- holado_test/tests/behave/steps/__init__.py +18 -0
- holado_test/tests/behave/steps/scenario/exception_steps.py +87 -0
- holado_test/tests/behave/steps/scenario/scenario_steps.py +100 -0
- holado_test/tests/behave/steps/scenario/tester_steps.py +65 -0
- holado_test/tools/test_server/client/rest/test_server_client.py +150 -0
- holado_test/tools/test_server/server/Dockerfile +60 -0
- holado_test/tools/test_server/server/core/server_context.py +42 -0
- holado_test/tools/test_server/server/core/server_manager.py +41 -0
- holado_test/tools/test_server/server/requirements.txt +2 -0
- holado_test/tools/test_server/server/rest/README +2 -0
- holado_test/tools/test_server/server/rest/api/__init__.py +24 -0
- holado_test/tools/test_server/server/rest/api/campaign/__init__.py +32 -0
- holado_test/tools/test_server/server/rest/api/campaign/scenario.py +40 -0
- holado_test/tools/test_server/server/rest/initialize_holado.py +72 -0
- holado_test/tools/test_server/server/rest/logging.conf +51 -0
- holado_test/tools/test_server/server/rest/openapi.yaml +57 -0
- holado_test/tools/test_server/server/rest/run.py +41 -0
- holado_test/tools/test_server/server/run.sh +6 -0
- holado_test/tools/test_server/server/run_test_server_in_docker.sh +104 -0
- holado_tools/__init__.py +38 -0
- holado_tools/scripts/execute_persisted_post_processes/execute_persisted_post_processes.py +36 -0
- holado_tools/scripts/execute_persisted_post_processes/execute_persisted_post_processes.sh +6 -0
- holado_tools/scripts/execute_persisted_post_processes/initialize_holado.py +62 -0
- holado_tools/tests/behave/steps/__init__.py +16 -0
- holado_tools/tests/behave/steps/tools/host_controller/client_steps.py +97 -0
- holado_tools/tools/host_controller/client/rest/host_controller_client.py +275 -0
- holado_tools/tools/host_controller/server/Dockerfile +60 -0
- holado_tools/tools/host_controller/server/requirements.txt +2 -0
- holado_tools/tools/host_controller/server/rest/README +2 -0
- holado_tools/tools/host_controller/server/rest/api/__init__.py +24 -0
- holado_tools/tools/host_controller/server/rest/api/config.py +88 -0
- holado_tools/tools/host_controller/server/rest/api/docker/__init__.py +66 -0
- holado_tools/tools/host_controller/server/rest/api/docker/container.py +144 -0
- holado_tools/tools/host_controller/server/rest/api/docker/logs.py +66 -0
- holado_tools/tools/host_controller/server/rest/api/os.py +58 -0
- holado_tools/tools/host_controller/server/rest/initialize_holado.py +72 -0
- holado_tools/tools/host_controller/server/rest/openapi.yaml +561 -0
- holado_tools/tools/host_controller/server/rest/run.py +31 -0
- holado_tools/tools/host_controller/server/run_host_controller_in_docker.sh +107 -0
- holado_tools/tools/host_viewer/client/rest/host_viewer_client.py +190 -0
- holado_tools/tools/host_viewer/server/Dockerfile +60 -0
- holado_tools/tools/host_viewer/server/requirements.txt +2 -0
- holado_tools/tools/host_viewer/server/rest/README +2 -0
- holado_tools/tools/host_viewer/server/rest/api/__init__.py +24 -0
- holado_tools/tools/host_viewer/server/rest/api/docker/__init__.py +65 -0
- holado_tools/tools/host_viewer/server/rest/api/docker/container.py +87 -0
- holado_tools/tools/host_viewer/server/rest/api/os.py +58 -0
- holado_tools/tools/host_viewer/server/rest/initialize_holado.py +72 -0
- holado_tools/tools/host_viewer/server/rest/openapi.yaml +301 -0
- holado_tools/tools/host_viewer/server/rest/run.py +31 -0
- holado_tools/tools/host_viewer/server/run_host_viewer_in_docker.sh +107 -0
- holado_value/__init__.py +24 -0
- holado_value/common/tables/comparators/table_2_value_table_cell_comparator.py +196 -0
- holado_value/common/tables/comparators/table_2_value_table_comparator.py +27 -0
- holado_value/common/tables/comparators/table_2_value_table_row_comparator.py +27 -0
- holado_value/common/tables/comparators/table_2_value_table_with_header_comparator.py +27 -0
- holado_value/common/tables/converters/value_table_converter.py +267 -0
- holado_value/common/tables/value_table.py +29 -0
- holado_value/common/tables/value_table_cell.py +76 -0
- holado_value/common/tables/value_table_manager.py +48 -0
- holado_value/common/tables/value_table_row.py +43 -0
- holado_value/common/tables/value_table_with_header.py +28 -0
- holado_value/common/tools/unique_value_manager.py +109 -0
- holado_value/common/tools/value.py +191 -0
- holado_value/common/tools/value_types.py +41 -0
- holado_value/tests/behave/steps/__init__.py +16 -0
- holado_value/tests/behave/steps/private/__init__.py +16 -0
- holado_ws/__init__.py +16 -0
- holado_ws/api/ws/TODO.txt +2 -0
- holado_ws/tests/behave/steps/__init__.py +16 -0
- holado_ws/tests/behave/steps/api/web_service_steps.py +189 -0
- holado_xml/__init__.py +38 -0
- holado_xml/tests/behave/steps/__init__.py +16 -0
- holado_xml/tests/behave/steps/private/__init__.py +16 -0
- holado_xml/xml/stream_xml_file.py +181 -0
- holado_xml/xml/xml_file.py +97 -0
- holado_xml/xml/xml_manager.py +35 -0
- holado_yaml/__init__.py +31 -0
- holado_yaml/tests/behave/steps/__init__.py +16 -0
- holado_yaml/tests/behave/steps/yaml_steps.py +161 -0
- holado_yaml/yaml/enums.py +28 -0
- holado_yaml/yaml/pyyaml/pyyaml_client.py +72 -0
- holado_yaml/yaml/ruamel/ruamel_yaml_client.py +80 -0
- holado_yaml/yaml/yaml_client.py +203 -0
- holado_yaml/yaml/yaml_manager.py +94 -0
- test_holado/Dockerfile_test_holado +82 -0
- test_holado/__init__.py +4 -0
- test_holado/__main__.py +25 -0
- test_holado/build_docker_image_to_test_holado_in_docker.sh +7 -0
- test_holado/environment.py +60 -0
- test_holado/features/Configuration/Actions/execute_persisted_post_processes.feature +13 -0
- test_holado/features/NonReg/api/REST.feature +26 -0
- test_holado/features/NonReg/api/gRPC.feature +116 -0
- test_holado/features/NonReg/common/multiprocessing/simple.feature +60 -0
- test_holado/features/NonReg/common/system/commands.feature +43 -0
- test_holado/features/NonReg/common/system/system.feature +20 -0
- test_holado/features/NonReg/common/tables/table.feature +245 -0
- test_holado/features/NonReg/common/tables/value_table_conversion.feature +29 -0
- test_holado/features/NonReg/common/tools/DateTime.feature +88 -0
- test_holado/features/NonReg/common/tools/UniqueValueManager.feature +43 -0
- test_holado/features/NonReg/holado_ais/ais_message-bitarray_to_nmea.feature +135 -0
- test_holado/features/NonReg/holado_ais/ais_message-nmea_raw_to_dict.feature +93 -0
- test_holado/features/NonReg/holado_ais/message_types/type-10.feature +38 -0
- test_holado/features/NonReg/holado_ais/message_types/type-12.feature +37 -0
- test_holado/features/NonReg/holado_ais/message_types/type-14.feature +36 -0
- test_holado/features/NonReg/holado_ais/message_types/type-15.feature +36 -0
- test_holado/features/NonReg/holado_ais/message_types/type-16.feature +38 -0
- test_holado/features/NonReg/holado_ais/message_types/type-17.feature +46 -0
- test_holado/features/NonReg/holado_ais/message_types/type-18.feature +37 -0
- test_holado/features/NonReg/holado_ais/message_types/type-19.feature +38 -0
- test_holado/features/NonReg/holado_ais/message_types/type-1_2_3.feature +42 -0
- test_holado/features/NonReg/holado_ais/message_types/type-20.feature +38 -0
- test_holado/features/NonReg/holado_ais/message_types/type-21.feature +37 -0
- test_holado/features/NonReg/holado_ais/message_types/type-22.feature +84 -0
- test_holado/features/NonReg/holado_ais/message_types/type-23.feature +49 -0
- test_holado/features/NonReg/holado_ais/message_types/type-24.feature +72 -0
- test_holado/features/NonReg/holado_ais/message_types/type-25.feature +143 -0
- test_holado/features/NonReg/holado_ais/message_types/type-26.feature +144 -0
- test_holado/features/NonReg/holado_ais/message_types/type-27.feature +36 -0
- test_holado/features/NonReg/holado_ais/message_types/type-4_11.feature +39 -0
- test_holado/features/NonReg/holado_ais/message_types/type-5.feature +33 -0
- test_holado/features/NonReg/holado_ais/message_types/type-6.feature +37 -0
- test_holado/features/NonReg/holado_ais/message_types/type-7_13.feature +43 -0
- test_holado/features/NonReg/holado_ais/message_types/type-8.feature +37 -0
- test_holado/features/NonReg/holado_ais/message_types/type-9.feature +37 -0
- test_holado/features/NonReg/holado_binary/bit_series.error.feature +33 -0
- test_holado/features/NonReg/holado_binary/bit_series.feature +144 -0
- test_holado/features/NonReg/holado_protobuf/protobuf.feature +291 -0
- test_holado/features/NonReg/holado_python/convert.feature +20 -0
- test_holado/features/NonReg/holado_python/iterable.feature +61 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/local_echo_server/socket_reset.feature +191 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/local_echo_server/socket_with_tls_and_verify.feature +279 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/local_echo_server/socket_with_tls_without_verify.feature +299 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/local_echo_server/socket_without_tls.feature +163 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/tcpbin.com/socket_with_mtls.feature +214 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/tcpbin.com/socket_with_tls.feature +184 -0
- test_holado/features/NonReg/holado_python/standard_library/socket/tcpbin.com/socket_without_tls.feature +169 -0
- test_holado/features/NonReg/holado_scripting/common/tools/dynamic_text_manager.feature +18 -0
- test_holado/features/NonReg/holado_scripting/common/tools/expression_evaluator.feature +185 -0
- test_holado/features/NonReg/holado_scripting/common/tools/variable_manager.feature +71 -0
- test_holado/features/NonReg/holado_scripting/text/interpreter/interpreter.error.feature +21 -0
- test_holado/features/NonReg/holado_scripting/text/interpreter/interpreter.feature +120 -0
- test_holado/features/NonReg/holado_yaml/yaml.feature +514 -0
- test_holado/features/NonReg/ipc/json.feature +20 -0
- test_holado/features/NonReg/scenario/scenario.feature +183 -0
- test_holado/features/NonReg/test_steps/behave.feature +275 -0
- test_holado/features/NonReg/test_steps/common.feature +100 -0
- test_holado/features/NonReg/tools/RabbitMQ.feature +445 -0
- test_holado/features/NonReg/tools/RabbitMQ_steps.feature +276 -0
- test_holado/features/NonReg/tools/S3/boto3_client.feature +73 -0
- test_holado/features/NonReg/tools/S3/minio_client.feature +75 -0
- test_holado/features/NonReg/tools/db_sqlite3.feature +41 -0
- test_holado/features/NonReg/tools/sFTP.feature +25 -0
- test_holado/features/Test/logger.feature +28 -0
- test_holado/features/Test/test_host_controller.feature +13 -0
- test_holado/features/Test/test_parameter.feature +15 -0
- test_holado/features/__init__.py +0 -0
- test_holado/initialize_holado.py +62 -0
- test_holado/logging.conf +53 -0
- test_holado/resources/proto/definitions/protobuf/custom_types/field_types.proto +24 -0
- test_holado/resources/proto/definitions/protobuf/protobuf.dev/tutorial/addressbook.proto +56 -0
- test_holado/resources/proto/generated/protobuf/custom_types/field_types_pb2.py +34 -0
- test_holado/resources/proto/generated/protobuf/protobuf/dev/tutorial/addressbook_pb2.py +34 -0
- test_holado/resources/scripts/list_tags.sh +2 -0
- test_holado/resources/scripts/update_resources_proto_generated.py +70 -0
- test_holado/steps/__init__.py +0 -0
- test_holado/steps/private_steps.py +20 -0
- test_holado/steps/public_steps.py +23 -0
- test_holado/test_holado_session_context.py +43 -0
- test_holado/tools/connexion/api_rest/openapi.yaml +16 -0
- test_holado/tools/connexion/api_rest/run.py +19 -0
- test_holado/tools/django/README.txt +3 -0
- test_holado/tools/django/api_grpc/api_grpc/__init__.py +0 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/__init__.py +0 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/admin.py +3 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/apps.py +6 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/migrations/__init__.py +0 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/models.py +3 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/proto/__init__.py +0 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/proto/account.proto +27 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/proto/account_pb2.py +33 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/proto/account_pb2_grpc.py +199 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/serializers.py +12 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/services.py +11 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/tests.py +3 -0
- test_holado/tools/django/api_grpc/api_grpc/api1/views.py +3 -0
- test_holado/tools/django/api_grpc/api_grpc/asgi.py +16 -0
- test_holado/tools/django/api_grpc/api_grpc/settings.py +126 -0
- test_holado/tools/django/api_grpc/api_grpc/urls.py +27 -0
- test_holado/tools/django/api_grpc/api_grpc/wsgi.py +16 -0
- test_holado/tools/django/api_grpc/db.sqlite3 +0 -0
- test_holado/tools/django/api_grpc/manage.py +29 -0
- test_holado/tools/django/api_grpc/manual_test_commands.txt +25 -0
- test_holado/tools/django/api_grpc/patch_djangogrpcframework.py +42 -0
- test_holado/tools/django/api_rest/api_rest/__init__.py +0 -0
- test_holado/tools/django/api_rest/api_rest/api1/__init__.py +0 -0
- test_holado/tools/django/api_rest/api_rest/api1/admin.py +3 -0
- test_holado/tools/django/api_rest/api_rest/api1/apps.py +6 -0
- test_holado/tools/django/api_rest/api_rest/api1/migrations/__init__.py +0 -0
- test_holado/tools/django/api_rest/api_rest/api1/models.py +3 -0
- test_holado/tools/django/api_rest/api_rest/api1/serializers.py +15 -0
- test_holado/tools/django/api_rest/api_rest/api1/tests.py +3 -0
- test_holado/tools/django/api_rest/api_rest/api1/views.py +24 -0
- test_holado/tools/django/api_rest/api_rest/asgi.py +16 -0
- test_holado/tools/django/api_rest/api_rest/settings.py +133 -0
- test_holado/tools/django/api_rest/api_rest/urls.py +32 -0
- test_holado/tools/django/api_rest/api_rest/wsgi.py +16 -0
- test_holado/tools/django/api_rest/db.sqlite3 +0 -0
- test_holado/tools/django/api_rest/manage.py +22 -0
|
@@ -0,0 +1,358 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
#################################################
|
|
4
|
+
# HolAdo (Holistic Automation do)
|
|
5
|
+
#
|
|
6
|
+
# (C) Copyright 2021-2025 by Eric Klumpp
|
|
7
|
+
#
|
|
8
|
+
# Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
9
|
+
#
|
|
10
|
+
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
11
|
+
|
|
12
|
+
# The Software is provided “as is”, without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the Software.
|
|
13
|
+
#################################################
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
from holado_test.behave.behave import * # @UnusedWildImport
|
|
17
|
+
from holado.common.context.session_context import SessionContext
|
|
18
|
+
from holado_test.scenario.step_tools import StepTools
|
|
19
|
+
import logging
|
|
20
|
+
import queue
|
|
21
|
+
from typing import Iterable
|
|
22
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
23
|
+
from holado_core.common.tools.tools import Tools
|
|
24
|
+
from holado_system.system.global_system import GlobalSystem
|
|
25
|
+
from holado_system.system.filesystem.file import File
|
|
26
|
+
from holado_python.standard_library.queue import IterableQueue,\
|
|
27
|
+
IterableLifoQueue
|
|
28
|
+
from holado_test.behave.scenario.behave_step_tools import BehaveStepTools
|
|
29
|
+
from holado_scripting.common.tools.evaluate_parameters import EvaluateParameters
|
|
30
|
+
from holado_python.standard_library.typing import Typing
|
|
31
|
+
|
|
32
|
+
logger = logging.getLogger(__name__)
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
def __get_scenario_context():
|
|
36
|
+
return SessionContext.instance().get_scenario_context()
|
|
37
|
+
|
|
38
|
+
def __get_variable_manager():
|
|
39
|
+
return __get_scenario_context().get_variable_manager()
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
@Given(r"(?P<var_name>{Variable}) = new FIFO queue(?: of size (?P<size>{Int}))?(?: \((?:block on get: (?P<block_on_get>{Boolean}))?(?: ; )?(?:block on get timeout: (?P<block_on_get_timeout>{Float} s))?(?: ; )?(?:block on put: (?P<block_on_put>{Boolean}))?(?: ; )?(?:block on put timeout: (?P<block_on_put_timeout>{Float}) s)?\))?")
|
|
44
|
+
def step_impl(context, var_name, size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout):
|
|
45
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
46
|
+
size = StepTools.evaluate_scenario_parameter(size)
|
|
47
|
+
block_on_get = StepTools.evaluate_scenario_parameter(block_on_get)
|
|
48
|
+
block_on_get_timeout = StepTools.evaluate_scenario_parameter(block_on_get_timeout)
|
|
49
|
+
block_on_put = StepTools.evaluate_scenario_parameter(block_on_put)
|
|
50
|
+
block_on_put_timeout = StepTools.evaluate_scenario_parameter(block_on_put_timeout)
|
|
51
|
+
|
|
52
|
+
res = IterableQueue(size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout)
|
|
53
|
+
|
|
54
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
55
|
+
|
|
56
|
+
@Given(r"(?P<var_name>{Variable}) = new LIFO queue(?: of size (?P<size>{Int}))?(?: \((?:block on get: (?P<block_on_get>{Boolean}))?(?: ; )?(?:block on get timeout: (?P<block_on_get_timeout>{Float} s))?(?: ; )?(?:block on put: (?P<block_on_put>{Boolean}))?(?: ; )?(?:block on put timeout: (?P<block_on_put_timeout>{Float}) s)?\))?")
|
|
57
|
+
def step_impl(context, var_name, size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout):
|
|
58
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
59
|
+
size = StepTools.evaluate_scenario_parameter(size)
|
|
60
|
+
block_on_get = StepTools.evaluate_scenario_parameter(block_on_get)
|
|
61
|
+
block_on_get_timeout = StepTools.evaluate_scenario_parameter(block_on_get_timeout)
|
|
62
|
+
block_on_put = StepTools.evaluate_scenario_parameter(block_on_put)
|
|
63
|
+
block_on_put_timeout = StepTools.evaluate_scenario_parameter(block_on_put_timeout)
|
|
64
|
+
|
|
65
|
+
res = IterableLifoQueue(size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout)
|
|
66
|
+
|
|
67
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
68
|
+
|
|
69
|
+
@Step(r"put (?!all )(?P<value>{Any}) \(Queue: (?P<var_queue>{Variable})\)")
|
|
70
|
+
def step_impl(context, value, var_queue):
|
|
71
|
+
value = StepTools.evaluate_scenario_parameter(value)
|
|
72
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
73
|
+
|
|
74
|
+
q.put(value)
|
|
75
|
+
|
|
76
|
+
@Step(r"(?P<var_name>{Variable}) = get \(Queue: (?P<var_queue>{Variable})\)")
|
|
77
|
+
def step_impl(context, var_name, var_queue):
|
|
78
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
79
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
80
|
+
|
|
81
|
+
res = q.get()
|
|
82
|
+
|
|
83
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
84
|
+
|
|
85
|
+
@Step(r"task is done \(Queue: (?P<var_queue>{Variable})\)")
|
|
86
|
+
def step_impl(context, var_queue):
|
|
87
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
88
|
+
|
|
89
|
+
q.task_done()
|
|
90
|
+
|
|
91
|
+
@Step(r"join \(Queue: (?P<var_queue>{Variable})\)")
|
|
92
|
+
def step_impl(context, var_queue):
|
|
93
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
94
|
+
|
|
95
|
+
q.join()
|
|
96
|
+
|
|
97
|
+
@Step(r"(?P<var_name>{Variable}) = size \(Queue: (?P<var_queue>{Variable})\)")
|
|
98
|
+
def step_impl(context, var_name, var_queue):
|
|
99
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
100
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
101
|
+
|
|
102
|
+
res = q.qsize()
|
|
103
|
+
|
|
104
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
105
|
+
|
|
106
|
+
@Step(r"close queue \(Queue: (?P<var_queue>{Variable})\)")
|
|
107
|
+
def step_impl(context, var_queue):
|
|
108
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
109
|
+
q.close()
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
@Step(r"put all of (?P<iterable_str>{Variable}) \(Queue: (?P<var_queue>{Variable})(?: ; nb of repeat: (?P<repeat_nb>{Int}))?(?: ; rate log period: (?P<rate_period_s>{Int}) s)?\)")
|
|
114
|
+
def step_impl(context, iterable_str, var_queue, repeat_nb, rate_period_s):
|
|
115
|
+
iterable = StepTools.evaluate_scenario_parameter(iterable_str)
|
|
116
|
+
it_name = StepTools.evaluate_variable_name(iterable_str)
|
|
117
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
118
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
119
|
+
repeat_nb = StepTools.evaluate_scenario_parameter(repeat_nb)
|
|
120
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
121
|
+
|
|
122
|
+
if not isinstance(iterable, Iterable):
|
|
123
|
+
raise FunctionalException(f"Parameter [{iterable_str}] (type: {Typing.get_object_class_fullname(iterable)}) is not iterable")
|
|
124
|
+
|
|
125
|
+
if repeat_nb is None:
|
|
126
|
+
repeat_nb = 1
|
|
127
|
+
nb_elements = len(iterable)
|
|
128
|
+
|
|
129
|
+
beg = Tools.timer_s()
|
|
130
|
+
s_end, t_end = 0, beg
|
|
131
|
+
for num in range(1, repeat_nb+1):
|
|
132
|
+
s_beg, t_beg = is_beg, it_beg = s_end, t_end
|
|
133
|
+
ind_beg = 0
|
|
134
|
+
|
|
135
|
+
for ind, value in enumerate(iterable):
|
|
136
|
+
q.put(value)
|
|
137
|
+
|
|
138
|
+
if rate_period_s and ind > 0 and ind % 10 == 0:
|
|
139
|
+
it_end = Tools.timer_s()
|
|
140
|
+
if it_end > it_beg + rate_period_s:
|
|
141
|
+
is_end = q.qsize()
|
|
142
|
+
rate = (is_beg + ind - ind_beg - is_end) / (it_end - it_beg)
|
|
143
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Current rate: {round(rate,2)} item/s ; Queue size: {is_end}")
|
|
144
|
+
ind_beg, is_beg, it_beg = ind, is_end, it_end
|
|
145
|
+
|
|
146
|
+
# Yield processor in case of multithreading
|
|
147
|
+
if ind % 10 == 0:
|
|
148
|
+
GlobalSystem.yield_processor()
|
|
149
|
+
|
|
150
|
+
if rate_period_s:
|
|
151
|
+
s_end, t_end = q.qsize(), Tools.timer_s()
|
|
152
|
+
rate = (s_beg + nb_elements - s_end) / (t_end - t_beg)
|
|
153
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Mean rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
154
|
+
|
|
155
|
+
if rate_period_s:
|
|
156
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
157
|
+
rate = (nb_elements * repeat_nb - s_end) / (end - beg)
|
|
158
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s")
|
|
159
|
+
|
|
160
|
+
@Step(r"put all of (?P<iterable_str>{Variable}) by batch of (?P<batch_size>{Int}) items \(Queue: (?P<var_queue>{Variable})(?: ; nb of repeat: (?P<repeat_nb>{Int}))?(?: ; rate log period: (?P<rate_period_s>{Int}) s)?\)")
|
|
161
|
+
def step_impl(context, iterable_str, batch_size, var_queue, repeat_nb, rate_period_s):
|
|
162
|
+
iterable = StepTools.evaluate_scenario_parameter(iterable_str)
|
|
163
|
+
it_name = StepTools.evaluate_variable_name(iterable_str)
|
|
164
|
+
batch_size = StepTools.evaluate_scenario_parameter(batch_size)
|
|
165
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
166
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
167
|
+
repeat_nb = StepTools.evaluate_scenario_parameter(repeat_nb)
|
|
168
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
169
|
+
|
|
170
|
+
if not isinstance(iterable, Iterable):
|
|
171
|
+
raise FunctionalException(f"Parameter [{iterable_str}] (type: {Typing.get_object_class_fullname(iterable)}) is not iterable")
|
|
172
|
+
|
|
173
|
+
if repeat_nb is None:
|
|
174
|
+
repeat_nb = 1
|
|
175
|
+
nb_elements = len(iterable)
|
|
176
|
+
|
|
177
|
+
beg = Tools.timer_s()
|
|
178
|
+
s_end, t_end = 0, beg
|
|
179
|
+
for num in range(1, repeat_nb+1):
|
|
180
|
+
s_beg, t_beg = is_beg, it_beg = s_end, t_end
|
|
181
|
+
batch_counter_beg = batch_counter = 0
|
|
182
|
+
batch = []
|
|
183
|
+
|
|
184
|
+
for value in iterable:
|
|
185
|
+
batch.append(value)
|
|
186
|
+
if len(batch) >= batch_size:
|
|
187
|
+
batch_counter += 1
|
|
188
|
+
q.put(batch)
|
|
189
|
+
batch = []
|
|
190
|
+
|
|
191
|
+
if rate_period_s and batch_counter > 0 and batch_counter % 10 == 0:
|
|
192
|
+
it_end = Tools.timer_s()
|
|
193
|
+
if it_end > it_beg + rate_period_s:
|
|
194
|
+
is_end = q.qsize()
|
|
195
|
+
rate = (is_beg + batch_counter - batch_counter_beg - is_end) / (it_end - it_beg)
|
|
196
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Current rate: {round(rate,2)} item/s ; Queue size: {is_end}")
|
|
197
|
+
batch_counter_beg, is_beg, it_beg = batch_counter, is_end, it_end
|
|
198
|
+
|
|
199
|
+
# Yield processor in case of multithreading
|
|
200
|
+
if batch_counter % 10 == 0:
|
|
201
|
+
GlobalSystem.yield_processor()
|
|
202
|
+
|
|
203
|
+
if rate_period_s:
|
|
204
|
+
s_end, t_end = q.qsize(), Tools.timer_s()
|
|
205
|
+
rate = (s_beg + nb_elements - s_end) / (t_end - t_beg)
|
|
206
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Mean rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
207
|
+
|
|
208
|
+
if rate_period_s:
|
|
209
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
210
|
+
rate = (nb_elements * repeat_nb - s_end) / (end - beg)
|
|
211
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s")
|
|
212
|
+
|
|
213
|
+
@Step(r"put all lines of file (?P<file_str>{Variable})(?: \(offset: (?P<offset>{Int}) ; size: (?P<size>{Int})\))? \(Queue: (?P<var_queue>{Variable})(?: ; rate log period: (?P<rate_period_s>{Int}) s)?\)")
|
|
214
|
+
def step_impl(context, file_str, offset, size, var_queue, rate_period_s):
|
|
215
|
+
file = StepTools.evaluate_scenario_parameter(file_str)
|
|
216
|
+
file_name = StepTools.evaluate_variable_name(file_str)
|
|
217
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
218
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
219
|
+
offset = StepTools.evaluate_scenario_parameter(offset)
|
|
220
|
+
size = StepTools.evaluate_scenario_parameter(size)
|
|
221
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
222
|
+
|
|
223
|
+
if not isinstance(file, File):
|
|
224
|
+
raise FunctionalException(f"Parameter [{file_str}] is not a file object")
|
|
225
|
+
|
|
226
|
+
beg = Tools.timer_s()
|
|
227
|
+
s_beg, t_beg = s_end, t_end = 0, beg
|
|
228
|
+
ind_beg = 0
|
|
229
|
+
|
|
230
|
+
for ind, line in enumerate(file.internal_file):
|
|
231
|
+
if ind < offset:
|
|
232
|
+
continue
|
|
233
|
+
elif size > 0 and ind >= offset + size:
|
|
234
|
+
break
|
|
235
|
+
|
|
236
|
+
q.put(line.strip('\n'))
|
|
237
|
+
|
|
238
|
+
if rate_period_s and ind > 0 and ind % 10 == 0:
|
|
239
|
+
t_end = Tools.timer_s()
|
|
240
|
+
if t_end > t_beg + rate_period_s:
|
|
241
|
+
s_end = q.qsize()
|
|
242
|
+
rate = (s_beg + ind - ind_beg - s_end) / (t_end - t_beg)
|
|
243
|
+
logger.print(f"[File {file_name} -> Queue {q_name}] Current rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
244
|
+
ind_beg, s_beg, t_beg = ind, s_end, t_end
|
|
245
|
+
|
|
246
|
+
# Yield processor in case of multithreading
|
|
247
|
+
if ind > 0 and ind % 10 == 0:
|
|
248
|
+
GlobalSystem.yield_processor()
|
|
249
|
+
|
|
250
|
+
if rate_period_s:
|
|
251
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
252
|
+
rate = (ind + 1 - s_end) / (end - beg)
|
|
253
|
+
logger.print(f"[File {file_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s")
|
|
254
|
+
|
|
255
|
+
|
|
256
|
+
|
|
257
|
+
@Step(r"for (?P<item_var_name>{VariableName}) in (?P<iterable_str>{Variable}), call steps, and put (?P<result_var_name>{VariableName}) \(Queue: (?P<var_queue>{Variable})(?: ; rate log period: (?P<rate_period_s>{Int}) s)?(?: ; format with: (?P<format_with>{Variable}(?:, {Variable})*))?\)")
|
|
258
|
+
def step_impl(context, item_var_name, iterable_str, result_var_name, var_queue, rate_period_s, format_with):
|
|
259
|
+
item_var_name = StepTools.evaluate_variable_name(item_var_name)
|
|
260
|
+
iterable = StepTools.evaluate_variable_value(iterable_str)
|
|
261
|
+
it_name = StepTools.evaluate_variable_name(iterable_str)
|
|
262
|
+
result_var_name = StepTools.evaluate_variable_name(result_var_name)
|
|
263
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
264
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
265
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
266
|
+
format_with = StepTools.evaluate_variable_name(format_with)
|
|
267
|
+
steps = BehaveStepTools.get_step_multiline_text(context, eval_params=EvaluateParameters.nothing())
|
|
268
|
+
|
|
269
|
+
if format_with is not None:
|
|
270
|
+
steps = StepTools.format_steps_with(steps, format_with.split(', '))
|
|
271
|
+
|
|
272
|
+
beg = Tools.timer_s()
|
|
273
|
+
t_beg = t_end = beg
|
|
274
|
+
ind_beg = 0
|
|
275
|
+
|
|
276
|
+
for ind, item in enumerate(iterable):
|
|
277
|
+
__get_variable_manager().register_variable(item_var_name, item)
|
|
278
|
+
execute_steps(steps)
|
|
279
|
+
result = __get_variable_manager().get_variable_value(result_var_name)
|
|
280
|
+
|
|
281
|
+
q.put(result)
|
|
282
|
+
|
|
283
|
+
if rate_period_s and ind > 0 and ind % 10 == 0:
|
|
284
|
+
t_end = Tools.timer_s()
|
|
285
|
+
if t_end > t_beg + rate_period_s:
|
|
286
|
+
s_end = q.qsize()
|
|
287
|
+
rate = (ind - ind_beg) / (t_end - t_beg)
|
|
288
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Current rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
289
|
+
ind_beg, t_beg = ind, t_end
|
|
290
|
+
|
|
291
|
+
# Yield processor in case of multithreading
|
|
292
|
+
if ind > 0 and ind % 10 == 0:
|
|
293
|
+
GlobalSystem.yield_processor()
|
|
294
|
+
|
|
295
|
+
if rate_period_s:
|
|
296
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
297
|
+
rate = (ind + 1) / (end - beg)
|
|
298
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
299
|
+
|
|
300
|
+
|
|
301
|
+
@Step(r"for (?P<item_var_name>{VariableName}) in queue, call steps \(Queue: (?P<var_queue>{Variable})(?: ; rate log period: (?P<rate_period_s>{Int}) s)?(?: ; format with: (?P<format_with>{Variable}(?:, {Variable})*))?\)")
|
|
302
|
+
def step_impl(context, item_var_name, var_queue, rate_period_s, format_with):
|
|
303
|
+
item_var_name = StepTools.evaluate_variable_name(item_var_name)
|
|
304
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
305
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
306
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
307
|
+
format_with = StepTools.evaluate_variable_name(format_with)
|
|
308
|
+
steps = BehaveStepTools.get_step_multiline_text(context, eval_params=EvaluateParameters.nothing())
|
|
309
|
+
|
|
310
|
+
if format_with is not None:
|
|
311
|
+
steps = StepTools.format_steps_with(steps, format_with.split(', '))
|
|
312
|
+
|
|
313
|
+
counter = 0
|
|
314
|
+
beg = Tools.timer_s()
|
|
315
|
+
c_beg, t_beg = counter, beg
|
|
316
|
+
log_counter = 0
|
|
317
|
+
|
|
318
|
+
try:
|
|
319
|
+
while True:
|
|
320
|
+
# Get next item
|
|
321
|
+
item = q.get()
|
|
322
|
+
if q.is_sentinel(item):
|
|
323
|
+
break
|
|
324
|
+
counter += 1
|
|
325
|
+
|
|
326
|
+
__get_variable_manager().register_variable(item_var_name, item)
|
|
327
|
+
try:
|
|
328
|
+
execute_steps(steps)
|
|
329
|
+
except Exception as exc:
|
|
330
|
+
logger.warning(f"[Queue {q_name}] Failed to execute steps with {counter}'th item: [{Typing.get_object_class_fullname(exc)}] {str(exc)}")
|
|
331
|
+
finally:
|
|
332
|
+
q.task_done()
|
|
333
|
+
|
|
334
|
+
# Log rate if needed
|
|
335
|
+
if rate_period_s and counter % 10 == 0:
|
|
336
|
+
t_end = Tools.timer_s()
|
|
337
|
+
if t_end > t_beg + rate_period_s:
|
|
338
|
+
c_end, s_end = counter, q.qsize()
|
|
339
|
+
rate = (c_end - c_beg) / (t_end - t_beg)
|
|
340
|
+
log_counter += 1
|
|
341
|
+
logger.print(f"[Queue {q_name}] Rate: {int(rate)} msg/s ; Nb items: {counter} ; Queue size: {s_end}")
|
|
342
|
+
c_beg, t_beg = c_end, t_end
|
|
343
|
+
|
|
344
|
+
# Yield processor in case of multithreading
|
|
345
|
+
if counter % 10 == 0:
|
|
346
|
+
GlobalSystem.yield_processor()
|
|
347
|
+
except queue.Empty:
|
|
348
|
+
# Without block, or with timeout, this exception occurs when queue is empty
|
|
349
|
+
pass
|
|
350
|
+
|
|
351
|
+
if rate_period_s:
|
|
352
|
+
end = Tools.timer_s()
|
|
353
|
+
rate = counter / (end - beg)
|
|
354
|
+
logger.print(f"[Queue {q_name}] Mean rate: {int(rate)} msg/s ; Nb messages: {counter}")
|
|
355
|
+
|
|
356
|
+
|
|
357
|
+
|
|
358
|
+
|