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,102 @@
|
|
|
1
|
+
[holado]
|
|
2
|
+
level=INFO
|
|
3
|
+
#level=DEBUG
|
|
4
|
+
log_on_console=False
|
|
5
|
+
log_in_file=True
|
|
6
|
+
|
|
7
|
+
[loggers_levels]
|
|
8
|
+
common=DEBUG
|
|
9
|
+
config=DEBUG
|
|
10
|
+
context=DEBUG
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
# Set HolAdo modules levels
|
|
14
|
+
# In case default level is set to DEBUG to debug KSC testing solution but not HolAdo, level is defined for each HolAdo module (usually: INFO)
|
|
15
|
+
holado=INFO
|
|
16
|
+
holado.common.context=INFO
|
|
17
|
+
holado.common.context.session_context=DEBUG
|
|
18
|
+
holado.common.handlers.object=DEBUG
|
|
19
|
+
holado_ais=INFO
|
|
20
|
+
#holado_ais.ais=DEBUG
|
|
21
|
+
holado_binary=INFO
|
|
22
|
+
holado_context=INFO
|
|
23
|
+
# Note: set DEBUG level in SessionContext in order to analyze a bug in feature context lifecycle resulting randomly to hook errors until end of session
|
|
24
|
+
holado_context.common.context.session_context=DEBUG
|
|
25
|
+
|
|
26
|
+
#holado_core=INFO
|
|
27
|
+
holado_core=DEBUG
|
|
28
|
+
#holado_core.common.tables.comparators=DEBUG
|
|
29
|
+
holado_core.common.tools=DEBUG
|
|
30
|
+
holado_core.common.tools.comparators=INFO
|
|
31
|
+
#holado_crypto.crypto.transport=DEBUG
|
|
32
|
+
holado_core.scenario=DEBUG
|
|
33
|
+
|
|
34
|
+
holado_data=INFO
|
|
35
|
+
holado_db=INFO
|
|
36
|
+
holado_db.tools=DEBUG
|
|
37
|
+
holado_docker=INFO
|
|
38
|
+
holado_docker.sdk=DEBUG
|
|
39
|
+
holado_grpc=INFO
|
|
40
|
+
holado_grpc.ipc=DEBUG
|
|
41
|
+
holado_helper=INFO
|
|
42
|
+
holado_json=INFO
|
|
43
|
+
holado_keycloak=INFO
|
|
44
|
+
holado_keycloak.tools=DEBUG
|
|
45
|
+
holado_logging=DEBUG
|
|
46
|
+
#holado_logging.common.logging.log_manager=DEBUG
|
|
47
|
+
holado_multitask=INFO
|
|
48
|
+
holado_multitask.multithreading.threadsmanager=DEBUG
|
|
49
|
+
holado_protobuf=INFO
|
|
50
|
+
holado_protobuf.ipc=DEBUG
|
|
51
|
+
#holado_protobuf.ipc.protobuf.protobuf_converter=TRACE
|
|
52
|
+
#holado_protobuf.ipc.protobuf.protobuf_messages=TRACE
|
|
53
|
+
holado_python=INFO
|
|
54
|
+
holado_rabbitmq=INFO
|
|
55
|
+
holado_rabbitmq.tools=DEBUG
|
|
56
|
+
holado_redis=INFO
|
|
57
|
+
holado_redis.tools=DEBUG
|
|
58
|
+
holado_report=INFO
|
|
59
|
+
holado_rest=INFO
|
|
60
|
+
#holado_rest.api=DEBUG
|
|
61
|
+
holado_s3=INFO
|
|
62
|
+
holado_s3.tools=DEBUG
|
|
63
|
+
#holado_s3.tools.s3.minio_client=DEBUG
|
|
64
|
+
#holado_s3.tools.s3.minio_client.trace=DEBUG
|
|
65
|
+
|
|
66
|
+
holado_scripting=INFO
|
|
67
|
+
#holado_scripting.common.tools=DEBUG
|
|
68
|
+
#holado_scripting.common.tools.expression_evaluator=INFO
|
|
69
|
+
holado_scripting.common.tools.expression_evaluator=DEBUG
|
|
70
|
+
#holado_scripting.common.tools.expression_evaluator=TRACE
|
|
71
|
+
#holado_scripting.common.tools.variable_manager=DEBUG
|
|
72
|
+
#holado_scripting.common.tools.variable_manager=TRACE
|
|
73
|
+
#holado_scripting.interpreter=TRACE
|
|
74
|
+
#holado_scripting.interpreter.functions=DEBUG
|
|
75
|
+
|
|
76
|
+
holado_sftp=INFO
|
|
77
|
+
holado_sftp.tools=DEBUG
|
|
78
|
+
holado_swagger=INFO
|
|
79
|
+
holado_system=INFO
|
|
80
|
+
holado_system.system.global_system=DEBUG
|
|
81
|
+
#holado_test=INFO
|
|
82
|
+
holado_test=DEBUG
|
|
83
|
+
|
|
84
|
+
# UI modules are not operational yet
|
|
85
|
+
holado_ui=ERROR
|
|
86
|
+
holado_ui_mss=ERROR
|
|
87
|
+
holado_ui_selenium=ERROR
|
|
88
|
+
holado_ui_selenium_angular=ERROR
|
|
89
|
+
holado_ui_selenium_html=ERROR
|
|
90
|
+
|
|
91
|
+
holado_value=DEBUG
|
|
92
|
+
#holado_value.common.tables.converters.value_table_converter=TRACE
|
|
93
|
+
holado_ws=ERROR
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
# External libraries
|
|
97
|
+
chardet=WARNING
|
|
98
|
+
docker=INFO
|
|
99
|
+
grpc_requests=DEBUG
|
|
100
|
+
pika=WARN
|
|
101
|
+
psycopg=INFO
|
|
102
|
+
urllib3=INFO
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
|
|
2
|
+
import logging
|
|
3
|
+
import os
|
|
4
|
+
from holado_core.common.tools.path_manager import PathManager
|
|
5
|
+
|
|
6
|
+
logger = logging.getLogger(__name__)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class TSPathManager(PathManager):
|
|
10
|
+
|
|
11
|
+
def __init__(self):
|
|
12
|
+
super().__init__()
|
|
13
|
+
|
|
14
|
+
def initialize(self):
|
|
15
|
+
pass
|
|
16
|
+
|
|
17
|
+
def __get_root_path(self):
|
|
18
|
+
here = os.path.abspath(os.path.dirname(__file__))
|
|
19
|
+
return os.path.join(here, "..", "..", "..")
|
|
20
|
+
|
|
21
|
+
def get_reports_path(self, name=None):
|
|
22
|
+
if os.getenv('TESTING_SOLUTION_REPORTS_PATH') is not None:
|
|
23
|
+
reports_root = os.getenv('TESTING_SOLUTION_REPORTS_PATH')
|
|
24
|
+
elif os.getenv('TEST_OUTPUT_BASEDIR') is not None:
|
|
25
|
+
reports_root = os.path.join(os.getenv('TEST_OUTPUT_BASEDIR'), "reports")
|
|
26
|
+
else:
|
|
27
|
+
reports_root = super().get_reports_path()
|
|
28
|
+
|
|
29
|
+
if name is not None:
|
|
30
|
+
return os.path.join(reports_root, name)
|
|
31
|
+
else:
|
|
32
|
+
return reports_root
|
|
33
|
+
|
|
34
|
+
def get_static_files_path(self, name=None):
|
|
35
|
+
root_path = self.__get_root_path()
|
|
36
|
+
res = os.path.normpath(os.path.join(root_path, "resources", "static_files"))
|
|
37
|
+
if name is not None:
|
|
38
|
+
res = os.path.join(res, name)
|
|
39
|
+
return res
|
|
40
|
+
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
import logging
|
|
4
|
+
from holado_test.behave.behave import execute_steps
|
|
5
|
+
|
|
6
|
+
logger = logging.getLogger(__name__)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
class TSConfigManager:
|
|
10
|
+
|
|
11
|
+
def __init__(self):
|
|
12
|
+
self.__func_path_manager = None
|
|
13
|
+
|
|
14
|
+
def initialize(self, func_path_manager):
|
|
15
|
+
self.__func_path_manager = func_path_manager
|
|
16
|
+
|
|
17
|
+
@property
|
|
18
|
+
def __path_manager(self):
|
|
19
|
+
return self.__func_path_manager()
|
|
20
|
+
|
|
21
|
+
def configure_system_with_default_settings(self):
|
|
22
|
+
# Remove possible side effects of previous execution
|
|
23
|
+
execute_steps(u"""
|
|
24
|
+
# Given ensure XXX
|
|
25
|
+
""")
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
from builtins import super
|
|
2
|
+
from holado.common.context.session_context import SessionContext
|
|
3
|
+
import logging
|
|
4
|
+
|
|
5
|
+
logger = logging.getLogger(__name__)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class TSSessionContext(SessionContext):
|
|
9
|
+
|
|
10
|
+
def __init__(self):
|
|
11
|
+
super().__init__("TSSession")
|
|
12
|
+
|
|
13
|
+
def configure(self, session_kwargs=None):
|
|
14
|
+
logger.info("Configuring TSSessionContext")
|
|
15
|
+
|
|
16
|
+
super().configure(session_kwargs)
|
|
17
|
+
|
|
18
|
+
# Override default registered modules
|
|
19
|
+
|
|
20
|
+
from common.tools.path_manager import TSPathManager # @UnresolvedImport
|
|
21
|
+
self.services.register_service_type("path_manager", TSPathManager,
|
|
22
|
+
lambda m: m.initialize(),
|
|
23
|
+
raise_if_exist=False )
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
# Register new modules
|
|
27
|
+
|
|
28
|
+
from config.config_manager import TSConfigManager # @UnresolvedImport
|
|
29
|
+
self.services.register_service_type("config_manager", TSConfigManager,
|
|
30
|
+
lambda m: m.initialize(lambda: self.path_manager) )
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
def initialize(self, session_kwargs=None):
|
|
34
|
+
if session_kwargs is None:
|
|
35
|
+
session_kwargs = {}
|
|
36
|
+
raise_if_not_exist = session_kwargs.get("raise_if_not_exist", True)
|
|
37
|
+
|
|
38
|
+
# Call default initialization
|
|
39
|
+
super().initialize(session_kwargs)
|
|
40
|
+
|
|
41
|
+
# Initialize testing solution
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
import logging
|
|
4
|
+
from holado_test.behave.behave import * # @UnusedWildImport
|
|
5
|
+
from holado.common.context.session_context import SessionContext
|
|
6
|
+
from config.config_manager import TSConfigManager # @UnresolvedImport
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
logger = logging.getLogger(__name__)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
def __get_config_manager() -> TSConfigManager:
|
|
13
|
+
return SessionContext.instance().config_manager
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
@Given(r"ensure system is configured with default settings")
|
|
17
|
+
def step_impl(context):
|
|
18
|
+
__get_config_manager().configure_system_with_default_settings()
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
from test_holado.steps.public_steps import *
|
|
5
|
+
|
|
6
|
+
# Note: following lines are commented since, with this example files architecture, these steps are automatically found and imported by behave
|
|
7
|
+
# from steps.config_steps import *
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
holado_grpc/TODO
ADDED
holado_grpc/__init__.py
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
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
|
+
import logging
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
def configure_module():
|
|
19
|
+
from holado.holado_config import Config
|
|
20
|
+
|
|
21
|
+
# Default log level
|
|
22
|
+
Config.log_level_grpc_request = logging.INFO
|
|
23
|
+
|
|
24
|
+
def dependencies():
|
|
25
|
+
return ["holado_multitask", "holado_protobuf"]
|
|
26
|
+
|
|
27
|
+
def register():
|
|
28
|
+
from holado.common.context.session_context import SessionContext
|
|
29
|
+
from holado_multitask.multiprocessing.context.process_context import ProcessContext
|
|
30
|
+
|
|
31
|
+
from holado_grpc.ipc.rpc.grpc_services import GRpcServices
|
|
32
|
+
if GRpcServices.is_available():
|
|
33
|
+
SessionContext.instance().services.register_service_type("grpc_services", GRpcServices)
|
|
34
|
+
|
|
35
|
+
from holado_grpc.api.rpc.grpc_manager import GRpcManager
|
|
36
|
+
SessionContext.instance().services.register_service_type("grpc_manager", GRpcManager,
|
|
37
|
+
lambda m: m.initialize(lambda: SessionContext.instance().grpc_services,
|
|
38
|
+
lambda: SessionContext.instance().protobuf_converter,
|
|
39
|
+
lambda: SessionContext.instance().protobuf_messages),
|
|
40
|
+
context_types=[ProcessContext], shortcut_in_types=[SessionContext] )
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
|
|
2
|
+
#################################################
|
|
3
|
+
# HolAdo (Holistic Automation do)
|
|
4
|
+
#
|
|
5
|
+
# (C) Copyright 2021-2025 by Eric Klumpp
|
|
6
|
+
#
|
|
7
|
+
# 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:
|
|
8
|
+
#
|
|
9
|
+
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
10
|
+
|
|
11
|
+
# 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.
|
|
12
|
+
#################################################
|
|
13
|
+
|
|
14
|
+
import logging
|
|
15
|
+
from holado_core.common.exceptions.technical_exception import TechnicalException, TimeoutTechnicalException
|
|
16
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
17
|
+
from holado_value.common.tables.converters.value_table_converter import ValueTableConverter
|
|
18
|
+
from holado_core.common.tools.tools import Tools
|
|
19
|
+
import time
|
|
20
|
+
from holado.holado_config import Config
|
|
21
|
+
from holado.common.handlers.object import Object
|
|
22
|
+
from holado.common.handlers.undefined import undefined_argument, undefined_value
|
|
23
|
+
|
|
24
|
+
logger = logging.getLogger(__name__)
|
|
25
|
+
|
|
26
|
+
try:
|
|
27
|
+
import grpc_requests
|
|
28
|
+
import grpc
|
|
29
|
+
with_grpc_requests = True
|
|
30
|
+
except Exception as exc:
|
|
31
|
+
if Tools.do_log(logger, logging.DEBUG):
|
|
32
|
+
logger.debug(f"GRpcClient is not available. Initialization failed on error: {exc}")
|
|
33
|
+
with_grpc_requests = False
|
|
34
|
+
|
|
35
|
+
# Activation of logs in gRPC library (activated logs are thrown in stdout, it doesn't follow logging settings)
|
|
36
|
+
# os.environ["GRPC_VERBOSITY"] = "DEBUG"
|
|
37
|
+
# os.environ["GRPC_TRACE"] = "http"
|
|
38
|
+
# os.environ["GRPC_TRACE"] = "all"
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
class GRpcClient(Object):
|
|
42
|
+
"""
|
|
43
|
+
gRPC client
|
|
44
|
+
|
|
45
|
+
It is implemented internally with grpc_requests, that manages reflection clients and stub clients.
|
|
46
|
+
"""
|
|
47
|
+
|
|
48
|
+
@classmethod
|
|
49
|
+
def is_available(cls):
|
|
50
|
+
return with_grpc_requests
|
|
51
|
+
|
|
52
|
+
if with_grpc_requests:
|
|
53
|
+
def __init__(self, name, endpoint, **kwargs):
|
|
54
|
+
super().__init__(name)
|
|
55
|
+
self.__endpoint = endpoint
|
|
56
|
+
self.__kwargs = kwargs
|
|
57
|
+
self.__client = grpc_requests.client.get_by_endpoint(endpoint, **kwargs)
|
|
58
|
+
|
|
59
|
+
self.__func_grpc_services = None
|
|
60
|
+
self.__func_protobuf_converter = None
|
|
61
|
+
self.__func_protobuf_messages = None
|
|
62
|
+
|
|
63
|
+
self.__request_log_level = Config.log_level_grpc_request
|
|
64
|
+
|
|
65
|
+
def initialize(self, func_grpc_services, func_protobuf_converter, func_protobuf_messages):
|
|
66
|
+
self.__func_grpc_services = func_grpc_services
|
|
67
|
+
self.__func_protobuf_converter = func_protobuf_converter
|
|
68
|
+
self.__func_protobuf_messages = func_protobuf_messages
|
|
69
|
+
|
|
70
|
+
@property
|
|
71
|
+
def __grpc_services(self):
|
|
72
|
+
return self.__func_grpc_services()
|
|
73
|
+
|
|
74
|
+
@property
|
|
75
|
+
def __protobuf_converter(self):
|
|
76
|
+
return self.__func_protobuf_converter()
|
|
77
|
+
|
|
78
|
+
@property
|
|
79
|
+
def __protobuf_messages(self):
|
|
80
|
+
return self.__func_protobuf_messages()
|
|
81
|
+
|
|
82
|
+
@property
|
|
83
|
+
def internal_client(self) -> grpc_requests.client.Client:
|
|
84
|
+
return self.__client
|
|
85
|
+
|
|
86
|
+
@property
|
|
87
|
+
def request_log_level(self):
|
|
88
|
+
return self.__request_log_level
|
|
89
|
+
|
|
90
|
+
@request_log_level.setter
|
|
91
|
+
def request_log_level(self, log_level):
|
|
92
|
+
self.__request_log_level = log_level
|
|
93
|
+
|
|
94
|
+
def request(self, service, method, request, raw_output=False, result_on_statuses=undefined_argument, **kwargs):
|
|
95
|
+
"""
|
|
96
|
+
:param request: request data in json or proto format
|
|
97
|
+
:param raw_output: if method should return a proto object or a json oject (default: False)
|
|
98
|
+
:param kwargs: other arguments for underlying grpc_requests method, or further underlying grpc method (ex: 'timeout')
|
|
99
|
+
:returns: if raw_output==True, returns a proto object, else returns a json object with proto data
|
|
100
|
+
"""
|
|
101
|
+
if Tools.do_log(logger, logging.DEBUG):
|
|
102
|
+
logger.debug(f"Requesting {service}.{method} with data [{request}] (raw_output: {raw_output} ; kwargs:{kwargs})")
|
|
103
|
+
res = undefined_value
|
|
104
|
+
|
|
105
|
+
# Set a default timeout
|
|
106
|
+
raise_on_timeout = False
|
|
107
|
+
if kwargs is None:
|
|
108
|
+
kwargs = {}
|
|
109
|
+
if 'timeout' not in kwargs:
|
|
110
|
+
kwargs['timeout'] = Config.join_timeout_seconds
|
|
111
|
+
raise_on_timeout = True
|
|
112
|
+
timeout = kwargs['timeout'] if 'timeout' in kwargs else None
|
|
113
|
+
|
|
114
|
+
success = False
|
|
115
|
+
last_exc = None
|
|
116
|
+
for try_nb in range(1,4):
|
|
117
|
+
try:
|
|
118
|
+
# Ask always raw_output=True, so that we get a Protobuf instance, and then conversion is done if needed
|
|
119
|
+
res_proto = self.internal_client.request(service, method, request, raw_output=True, **kwargs)
|
|
120
|
+
except Exception as exc:
|
|
121
|
+
last_exc = exc
|
|
122
|
+
exc_str = str(exc)
|
|
123
|
+
|
|
124
|
+
# Manage result on statuses
|
|
125
|
+
if result_on_statuses is not undefined_argument:
|
|
126
|
+
for status, status_result in result_on_statuses.items():
|
|
127
|
+
if f"status = StatusCode.{status.name}" in exc_str:
|
|
128
|
+
res = status_result
|
|
129
|
+
break
|
|
130
|
+
if res is not undefined_value:
|
|
131
|
+
success = True
|
|
132
|
+
break
|
|
133
|
+
|
|
134
|
+
msg_list = [
|
|
135
|
+
f"Request failed (try {try_nb}):",
|
|
136
|
+
f" method: {service}.{method}",
|
|
137
|
+
f" data:",
|
|
138
|
+
Tools.indent_string(8, str(request)),
|
|
139
|
+
f" raw_output: {raw_output}",
|
|
140
|
+
f" kwargs: {kwargs}",
|
|
141
|
+
f" error:",
|
|
142
|
+
Tools.indent_string(8, exc_str) ]
|
|
143
|
+
exc_msg = "\n".join(msg_list)
|
|
144
|
+
if "status = StatusCode.UNAVAILABLE" in exc_str:
|
|
145
|
+
logger.warning("Service temporarily unavailable:\n" + exc_msg)
|
|
146
|
+
time.sleep(1)
|
|
147
|
+
continue
|
|
148
|
+
elif "status = StatusCode.DEADLINE_EXCEEDED" in exc_str:
|
|
149
|
+
if raise_on_timeout:
|
|
150
|
+
raise TimeoutTechnicalException(exc_msg)
|
|
151
|
+
else:
|
|
152
|
+
logger.warning(f"Timeout ({timeout} s) occured while requesting:\n" + exc_msg)
|
|
153
|
+
time.sleep(1)
|
|
154
|
+
continue
|
|
155
|
+
elif "status = " in exc_str:
|
|
156
|
+
raise FunctionalException(exc_msg) from exc
|
|
157
|
+
else:
|
|
158
|
+
raise TechnicalException(exc_msg) from exc
|
|
159
|
+
else:
|
|
160
|
+
success = True
|
|
161
|
+
break
|
|
162
|
+
|
|
163
|
+
# If still in error after all tries, raise an exception with last exception message
|
|
164
|
+
if not success:
|
|
165
|
+
if "status = " in exc_msg:
|
|
166
|
+
raise FunctionalException(exc_msg) from last_exc
|
|
167
|
+
else:
|
|
168
|
+
raise TechnicalException(exc_msg) from last_exc
|
|
169
|
+
|
|
170
|
+
# Manage result conversion if needed
|
|
171
|
+
# Note: this step is done manually since grpc_requests has some limitations when raw_output=False:
|
|
172
|
+
# - Field with default values are not set in json result
|
|
173
|
+
# - Some field types are badly managed (ex: uint64 fields appear as string in json)
|
|
174
|
+
if res is undefined_value:
|
|
175
|
+
if raw_output == True:
|
|
176
|
+
if isinstance(res_proto, grpc._channel._MultiThreadedRendezvous):
|
|
177
|
+
res = list(res_proto)
|
|
178
|
+
else:
|
|
179
|
+
res = res_proto
|
|
180
|
+
else:
|
|
181
|
+
if isinstance(res_proto, grpc._channel._MultiThreadedRendezvous):
|
|
182
|
+
res = [self.__protobuf_converter.convert_protobuf_object_to_json_object(cur_res) for cur_res in res_proto]
|
|
183
|
+
else:
|
|
184
|
+
res = self.__protobuf_converter.convert_protobuf_object_to_json_object(res_proto)
|
|
185
|
+
if Tools.do_log(logger, self.request_log_level):
|
|
186
|
+
logger.log(self.request_log_level, f"Request {service}.{method} with data [{request}] (raw_output: {raw_output} ; kwargs:{kwargs}) => {res}")
|
|
187
|
+
return res
|
|
188
|
+
|
|
189
|
+
def get_request_data_type_fullname(self, service, method):
|
|
190
|
+
method_descriptor = self.__grpc_services.get_method_descriptor(service, method)
|
|
191
|
+
return method_descriptor.input_type.full_name
|
|
192
|
+
|
|
193
|
+
def build_request_data(self, service, method, params_table=None, params_dict=None, as_proto=False):
|
|
194
|
+
if Tools.do_log(logger, logging.TRACE): # @UndefinedVariable
|
|
195
|
+
logger.trace(f"Building request data for service method '{service}.{method}'")
|
|
196
|
+
if as_proto is not None and as_proto:
|
|
197
|
+
method_descriptor = self.__grpc_services.get_method_descriptor(service, method)
|
|
198
|
+
res = self.__protobuf_messages.new_message(method_descriptor.input_type.full_name, fields_table=params_table, fields_dict=params_dict)
|
|
199
|
+
else:
|
|
200
|
+
if params_table is not None:
|
|
201
|
+
res = ValueTableConverter.convert_name_value_table_2_json_object(params_table)
|
|
202
|
+
elif params_dict is not None:
|
|
203
|
+
res = params_dict
|
|
204
|
+
else:
|
|
205
|
+
res = {}
|
|
206
|
+
|
|
207
|
+
return res
|
|
208
|
+
|
|
209
|
+
|
|
210
|
+
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
|
|
2
|
+
#################################################
|
|
3
|
+
# HolAdo (Holistic Automation do)
|
|
4
|
+
#
|
|
5
|
+
# (C) Copyright 2021-2025 by Eric Klumpp
|
|
6
|
+
#
|
|
7
|
+
# 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:
|
|
8
|
+
#
|
|
9
|
+
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
10
|
+
|
|
11
|
+
# 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.
|
|
12
|
+
#################################################
|
|
13
|
+
|
|
14
|
+
import logging
|
|
15
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
16
|
+
from holado.common.context.session_context import SessionContext
|
|
17
|
+
from holado_grpc.api.rpc.grpc_client import GRpcClient
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
logger = logging.getLogger(__name__)
|
|
21
|
+
|
|
22
|
+
# Activation of logs in gRPC library (activated logs are thrown in stdout, it doesn't follow logging settings)
|
|
23
|
+
# os.environ["GRPC_VERBOSITY"] = "DEBUG"
|
|
24
|
+
# os.environ["GRPC_TRACE"] = "http"
|
|
25
|
+
# os.environ["GRPC_TRACE"] = "all"
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
class GRpcManager(object):
|
|
29
|
+
"""
|
|
30
|
+
Manage gRPC features, agnostic to internal gRPC library.
|
|
31
|
+
"""
|
|
32
|
+
|
|
33
|
+
def __init__(self):
|
|
34
|
+
self.__func_grpc_services = None
|
|
35
|
+
self.__func_protobuf_converter = None
|
|
36
|
+
self.__func_protobuf_messages = None
|
|
37
|
+
|
|
38
|
+
def initialize(self, func_grpc_services, func_protobuf_converter, func_protobuf_messages):
|
|
39
|
+
self.__func_grpc_services = func_grpc_services
|
|
40
|
+
self.__func_protobuf_converter = func_protobuf_converter
|
|
41
|
+
self.__func_protobuf_messages = func_protobuf_messages
|
|
42
|
+
|
|
43
|
+
@property
|
|
44
|
+
def __grpc_services(self):
|
|
45
|
+
return self.__func_grpc_services()
|
|
46
|
+
|
|
47
|
+
def new_client(self, name, **kwargs):
|
|
48
|
+
if name is None:
|
|
49
|
+
name = "Undefined"
|
|
50
|
+
endpoint = kwargs.pop("endpoint")
|
|
51
|
+
|
|
52
|
+
service_fullname = kwargs.pop("service") if "service" in kwargs else None
|
|
53
|
+
services_fullnames = kwargs.pop("services") if "services" in kwargs else None
|
|
54
|
+
if service_fullname is not None:
|
|
55
|
+
service_descriptors = [self.__grpc_services.get_service_descriptor(service_fullname)]
|
|
56
|
+
elif services_fullnames is not None:
|
|
57
|
+
service_descriptors = [self.__grpc_services.get_service_descriptor(sfn) for sfn in services_fullnames]
|
|
58
|
+
else:
|
|
59
|
+
service_descriptors = None
|
|
60
|
+
|
|
61
|
+
# Proxy settings
|
|
62
|
+
#kwargs['channel_options'] = (('grpc.enable_http_proxy', 0),('grpc.enable_https_proxy', 0),)
|
|
63
|
+
|
|
64
|
+
if service_descriptors is not None:
|
|
65
|
+
res = GRpcClient(name, endpoint=endpoint, service_descriptors=service_descriptors, **kwargs)
|
|
66
|
+
else:
|
|
67
|
+
import grpc
|
|
68
|
+
try:
|
|
69
|
+
res = GRpcClient(name, endpoint=endpoint, **kwargs)
|
|
70
|
+
except grpc.RpcError as exc:
|
|
71
|
+
if hasattr(exc, "details"):
|
|
72
|
+
details = str(exc.details)
|
|
73
|
+
if "status = StatusCode.UNIMPLEMENTED" in details and 'details = "Method not found: grpc.reflection.v1alpha.ServerReflection/ServerReflectionInfo"' in details:
|
|
74
|
+
raise FunctionalException(f"Endpoint '{endpoint}' doesn't manage reflection, thus step parameter 'service' or 'services' has to be specified")
|
|
75
|
+
raise exc
|
|
76
|
+
|
|
77
|
+
res.initialize(self.__func_grpc_services, self.__func_protobuf_converter, self.__func_protobuf_messages)
|
|
78
|
+
|
|
79
|
+
return res
|
|
80
|
+
|
|
81
|
+
|
|
File without changes
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
|
|
2
|
+
#################################################
|
|
3
|
+
# HolAdo (Holistic Automation do)
|
|
4
|
+
#
|
|
5
|
+
# (C) Copyright 2021-2025 by Eric Klumpp
|
|
6
|
+
#
|
|
7
|
+
# 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:
|
|
8
|
+
#
|
|
9
|
+
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
10
|
+
|
|
11
|
+
# 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.
|
|
12
|
+
#################################################
|
|
13
|
+
|
|
14
|
+
from holado_core.common.exceptions.technical_exception import TechnicalException
|
|
15
|
+
import logging
|
|
16
|
+
from holado_protobuf.ipc.protobuf.protobuf_compiler import ProtobufCompiler
|
|
17
|
+
from holado_core.common.tools.tools import Tools
|
|
18
|
+
|
|
19
|
+
logger = logging.getLogger(__name__)
|
|
20
|
+
|
|
21
|
+
try:
|
|
22
|
+
import grpc_tools # @UnusedImport
|
|
23
|
+
with_grpc_tools = True
|
|
24
|
+
except Exception as exc:
|
|
25
|
+
if Tools.do_log(logger, logging.DEBUG):
|
|
26
|
+
logger.debug(f"GRpcCompiler is not available. Initialization failed on error: {exc}")
|
|
27
|
+
with_grpc_tools = False
|
|
28
|
+
|
|
29
|
+
class GRpcCompiler(ProtobufCompiler):
|
|
30
|
+
@classmethod
|
|
31
|
+
def is_available(cls):
|
|
32
|
+
return with_grpc_tools
|
|
33
|
+
|
|
34
|
+
def __init__(self):
|
|
35
|
+
super().__init__()
|
|
36
|
+
ProtobufCompiler.protoc_exe_path.fset(self, "python -m grpc_tools.protoc") # @UndefinedVariable
|
|
37
|
+
|
|
38
|
+
@ProtobufCompiler.protoc_exe_path.setter # @UndefinedVariable
|
|
39
|
+
def protoc_exe_path(self, path):
|
|
40
|
+
raise TechnicalException("An internal compiler is used for gRPC")
|
|
41
|
+
|
|
42
|
+
def _build_compile_proto_command(self, proto_path, destination_path, proto_file_path):
|
|
43
|
+
return f'{self.protoc_exe_path} --proto_path="{proto_path}" --python_out="{destination_path}" --grpc_python_out="{destination_path}" "{proto_file_path}"'
|
|
44
|
+
|
|
45
|
+
|