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,84 @@
|
|
|
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.scenario.step_tools import StepTools
|
|
17
|
+
from holado.common.context.session_context import SessionContext
|
|
18
|
+
from holado_test.behave.behave import * # @UnusedWildImport
|
|
19
|
+
import tempfile
|
|
20
|
+
import logging
|
|
21
|
+
import os
|
|
22
|
+
from holado_system.system.global_system import GlobalSystem, OSTypes
|
|
23
|
+
import time
|
|
24
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
25
|
+
|
|
26
|
+
logger = logging.getLogger(__name__)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
def __get_scenario_context():
|
|
30
|
+
return SessionContext.instance().get_scenario_context()
|
|
31
|
+
|
|
32
|
+
def __get_text_interpreter():
|
|
33
|
+
return __get_scenario_context().get_text_interpreter()
|
|
34
|
+
|
|
35
|
+
def __get_variable_manager():
|
|
36
|
+
return __get_scenario_context().get_variable_manager()
|
|
37
|
+
|
|
38
|
+
def __get_report_manager():
|
|
39
|
+
return SessionContext.instance().report_manager
|
|
40
|
+
|
|
41
|
+
def __get_path_manager():
|
|
42
|
+
return SessionContext.instance().path_manager
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
@Given(r"(?P<var_name>{Variable}) = new temporary directory with prefix (?P<prefix>{Str})")
|
|
46
|
+
def step_impl(context, var_name, prefix):
|
|
47
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
48
|
+
pref = StepTools.evaluate_scenario_parameter(prefix)
|
|
49
|
+
tmp_dir = tempfile.mkdtemp(prefix=pref)
|
|
50
|
+
__get_variable_manager().register_variable(var_name, tmp_dir)
|
|
51
|
+
|
|
52
|
+
@Given(r"(?P<var_name>{Variable}) = scenario report directory (?P<path>{Str})")
|
|
53
|
+
def step_impl(context, var_name, path):
|
|
54
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
55
|
+
path = StepTools.evaluate_scenario_parameter(path)
|
|
56
|
+
rd_path = __get_report_manager().current_scenario_report.get_path(path)
|
|
57
|
+
__get_variable_manager().register_variable(var_name, rd_path)
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
@Given(r"(?P<var_name>{Variable}) = value of environment variable (?P<env_var_name>{Str})")
|
|
61
|
+
def step_impl(context, var_name, env_var_name):
|
|
62
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
63
|
+
env_var_name = StepTools.evaluate_scenario_parameter(env_var_name)
|
|
64
|
+
res = os.getenv(env_var_name)
|
|
65
|
+
if res is None:
|
|
66
|
+
raise EnvironmentError(f"Environment variable {env_var_name} is not defined")
|
|
67
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
68
|
+
|
|
69
|
+
@Step(r"yield processor")
|
|
70
|
+
def step_impl(context):
|
|
71
|
+
GlobalSystem.yield_processor()
|
|
72
|
+
|
|
73
|
+
@Step(r"(?P<var_name>{Variable}) = first available anonymous port")
|
|
74
|
+
def step_impl(context, var_name):
|
|
75
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
76
|
+
|
|
77
|
+
res = GlobalSystem.get_first_available_anonymous_port()
|
|
78
|
+
|
|
79
|
+
if res is None:
|
|
80
|
+
raise FunctionalException(f"No port is available")
|
|
81
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
|
holado_test/__init__.py
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
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
|
+
|
|
17
|
+
def dependencies():
|
|
18
|
+
return None
|
|
19
|
+
|
|
20
|
+
def register():
|
|
21
|
+
from holado.common.context.session_context import SessionContext
|
|
22
|
+
|
|
23
|
+
from holado_test.behave.behave_manager import BehaveManager
|
|
24
|
+
SessionContext.instance().services.register_service_type("behave_manager", BehaveManager)
|
|
25
|
+
|
|
26
|
+
from holado_test.tools.test_server.client.rest.test_server_client import TestServerClient
|
|
27
|
+
SessionContext.instance().services.register_service_type("test_server_client", TestServerClient.new_client)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
File without changes
|
|
@@ -0,0 +1,400 @@
|
|
|
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 behave import given, when, then, step, Given, When, Then, Step # @UnusedImport @UnresolvedImport
|
|
16
|
+
import behave
|
|
17
|
+
import re
|
|
18
|
+
from holado_core.common.exceptions.verify_exception import VerifyException
|
|
19
|
+
from holado_core.common.tools.tools import Tools
|
|
20
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
21
|
+
from holado_core.common.exceptions.technical_exception import TechnicalException
|
|
22
|
+
from holado.common.context.session_context import SessionContext
|
|
23
|
+
from behave.model_core import Status
|
|
24
|
+
from behave.model_describe import escape_cell
|
|
25
|
+
from behave.textutil import indent
|
|
26
|
+
from holado_core.common.exceptions.holado_exception import HAException
|
|
27
|
+
from holado_test.scenario.step_tools import SRE # @UnusedImport
|
|
28
|
+
from holado_multitask.multitasking.multitask_manager import MultitaskManager
|
|
29
|
+
from holado_python.standard_library.typing import Typing
|
|
30
|
+
from holado import is_in_steps_catalog
|
|
31
|
+
|
|
32
|
+
# limit import *
|
|
33
|
+
# pylint: disable=undefined-all-variable
|
|
34
|
+
__all__ = [
|
|
35
|
+
"Given", "When", "Then", "Step",# "For",
|
|
36
|
+
"format_step_with_context", "execute_steps", "SRE"
|
|
37
|
+
]
|
|
38
|
+
|
|
39
|
+
# Import and expose step parameter types
|
|
40
|
+
# from BehaveStepTools import SRE
|
|
41
|
+
# var_names = BehaveStepTools.import_types(sys.modules[__name__])
|
|
42
|
+
# if len(var_names) == 0:
|
|
43
|
+
# raise TechnicalException(f"Module '{__name__}' is imported before registration of step parameter types")
|
|
44
|
+
# __all__.extend(var_names)
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
logger = logging.getLogger(__name__)
|
|
48
|
+
|
|
49
|
+
is_steps_catalog = is_in_steps_catalog()
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
def __get_report_manager():
|
|
53
|
+
return SessionContext.instance().report_manager
|
|
54
|
+
|
|
55
|
+
def __has_scenario_context():
|
|
56
|
+
return SessionContext.instance().has_scenario_context()
|
|
57
|
+
|
|
58
|
+
def __has_step_context():
|
|
59
|
+
return SessionContext.instance().has_step_context()
|
|
60
|
+
|
|
61
|
+
def __get_step_context():
|
|
62
|
+
return SessionContext.instance().get_step_context()
|
|
63
|
+
|
|
64
|
+
def __get_block_manager():
|
|
65
|
+
if __has_scenario_context():
|
|
66
|
+
return SessionContext.instance().get_scenario_context().block_manager
|
|
67
|
+
else:
|
|
68
|
+
return None
|
|
69
|
+
|
|
70
|
+
def __get_scope_manager():
|
|
71
|
+
if __has_scenario_context():
|
|
72
|
+
return SessionContext.instance().get_scenario_context().scope_manager
|
|
73
|
+
else:
|
|
74
|
+
return None
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
def format_step(step, with_keyword=True, with_table=True, with_text=True):
|
|
80
|
+
from behave.model_describe import ModelDescriptor
|
|
81
|
+
|
|
82
|
+
step_str = step.name.strip()
|
|
83
|
+
|
|
84
|
+
if with_keyword:
|
|
85
|
+
res = u"{keyword} {step_str}".format(keyword=step.keyword, step_str=step_str)
|
|
86
|
+
else:
|
|
87
|
+
res = step_str
|
|
88
|
+
|
|
89
|
+
if with_table and hasattr(step, "table") and step.table is not None:
|
|
90
|
+
rendered_table = render_step_table(step.table, " ")
|
|
91
|
+
res = u"{res}\n{table}".format(res=res, table=rendered_table)
|
|
92
|
+
elif with_text and hasattr(step, "text") and step.text is not None:
|
|
93
|
+
rendered_text = ModelDescriptor.describe_docstring(step.text, "")
|
|
94
|
+
# rendered_text = Tools.indent_string(4, rendered_text)
|
|
95
|
+
res = u"{res}\n{text}".format(res=res, text=rendered_text)
|
|
96
|
+
|
|
97
|
+
return res
|
|
98
|
+
|
|
99
|
+
def format_step_with_context(context, step_str, with_keyword=True, with_table=True, with_text=True):
|
|
100
|
+
from behave.model_describe import ModelDescriptor
|
|
101
|
+
|
|
102
|
+
step_str = step_str.strip()
|
|
103
|
+
|
|
104
|
+
if with_keyword:
|
|
105
|
+
res = u"{keyword} {step_str}".format(keyword=context.step.keyword, step_str=step_str)
|
|
106
|
+
else:
|
|
107
|
+
res = step_str
|
|
108
|
+
|
|
109
|
+
if with_table and hasattr(context, "table") and context.table is not None:
|
|
110
|
+
rendered_table = render_step_table(context.table, " ")
|
|
111
|
+
res = u"{res}\n{table}".format(res=res, table=rendered_table)
|
|
112
|
+
elif with_text and hasattr(context, "text") and context.text is not None:
|
|
113
|
+
rendered_text = ModelDescriptor.describe_docstring(context.text, " ")
|
|
114
|
+
res = u"{res}\n{text}".format(res=res, text=rendered_text)
|
|
115
|
+
|
|
116
|
+
return res
|
|
117
|
+
|
|
118
|
+
def __step_description(context):
|
|
119
|
+
return __get_report_manager().get_step_description(context.step)
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
def execute_steps(steps_text):
|
|
123
|
+
"""
|
|
124
|
+
Wrapper to Context.execute_steps method, that manages scope levels of sub-steps.
|
|
125
|
+
|
|
126
|
+
WARNING: The method context.execute_steps is not thread safe.
|
|
127
|
+
If it is called a second time in another thread very closely, the steps behind the second call
|
|
128
|
+
will be executed two times, one time in each thread.
|
|
129
|
+
TODO EKL: Do tests to make this function thread safe.
|
|
130
|
+
"""
|
|
131
|
+
# Manage sub-step level
|
|
132
|
+
thread_id = MultitaskManager.get_thread_id()
|
|
133
|
+
scope_manager = __get_scope_manager()
|
|
134
|
+
if scope_manager:
|
|
135
|
+
level_already_exists = scope_manager.has_scope_level("steps")
|
|
136
|
+
origin_level = scope_manager.scope_level("steps")
|
|
137
|
+
if level_already_exists:
|
|
138
|
+
scope_manager.increase_scope_level("steps")
|
|
139
|
+
if Tools.do_log(logger, logging.DEBUG):
|
|
140
|
+
logger.debug(f"Executing steps (level {scope_manager.scope_level('steps')} ; thread: {thread_id}):\n{steps_text}")
|
|
141
|
+
else:
|
|
142
|
+
if Tools.do_log(logger, logging.DEBUG):
|
|
143
|
+
logger.debug(f"Executing steps (thread: {thread_id}):\n{steps_text}")
|
|
144
|
+
|
|
145
|
+
try:
|
|
146
|
+
SessionContext.instance().behave_manager.get_context().execute_steps(steps_text)
|
|
147
|
+
finally:
|
|
148
|
+
if scope_manager:
|
|
149
|
+
scope_manager.reset_scope_level("steps", origin_level)
|
|
150
|
+
|
|
151
|
+
def render_step_table(table, indentation=None, do_escape_cell=False):
|
|
152
|
+
"""
|
|
153
|
+
NOTE: It's a copy of behave method ModelDescriptor.describe_table, but not escaping cells by default.
|
|
154
|
+
If parameter do_escape_cell is True, the behavior is identical to ModelDescriptor.describe_table.
|
|
155
|
+
|
|
156
|
+
Provide a textual description of the table (as used w/ Gherkin).
|
|
157
|
+
|
|
158
|
+
:param table: Table to use (as :class:`behave.model.Table`)
|
|
159
|
+
:param indentation: Line prefix to use (as string, if any).
|
|
160
|
+
:return: Textual table description (as unicode string).
|
|
161
|
+
"""
|
|
162
|
+
# -- STEP: Determine output size of all cells.
|
|
163
|
+
cell_lengths = []
|
|
164
|
+
all_rows = [table.headings] + table.rows
|
|
165
|
+
for row in all_rows:
|
|
166
|
+
if do_escape_cell:
|
|
167
|
+
lengths = [len(escape_cell(c)) for c in row]
|
|
168
|
+
else:
|
|
169
|
+
lengths = [len(c) for c in row]
|
|
170
|
+
cell_lengths.append(lengths)
|
|
171
|
+
|
|
172
|
+
# -- STEP: Determine max. output size for each column.
|
|
173
|
+
max_lengths = []
|
|
174
|
+
for col in range(0, len(cell_lengths[0])):
|
|
175
|
+
max_lengths.append(max([c[col] for c in cell_lengths]))
|
|
176
|
+
|
|
177
|
+
# -- STEP: Build textual table description.
|
|
178
|
+
lines = []
|
|
179
|
+
for r, row in enumerate(all_rows):
|
|
180
|
+
line = u"|"
|
|
181
|
+
for c, (cell, max_length) in enumerate(zip(row, max_lengths)):
|
|
182
|
+
pad_size = max_length - cell_lengths[r][c]
|
|
183
|
+
if do_escape_cell:
|
|
184
|
+
line += u" %s%s |" % (escape_cell(cell), " " * pad_size)
|
|
185
|
+
else:
|
|
186
|
+
line += u" %s%s |" % (cell, " " * pad_size)
|
|
187
|
+
line += u"\n"
|
|
188
|
+
lines.append(line)
|
|
189
|
+
|
|
190
|
+
if indentation:
|
|
191
|
+
return indent(lines, indentation)
|
|
192
|
+
# -- OTHERWISE:
|
|
193
|
+
return u"".join(lines)
|
|
194
|
+
|
|
195
|
+
|
|
196
|
+
def Given(regexp, accept_scope_in_define=True, accept_condition=True):
|
|
197
|
+
return _wrapped_step(behave.given, regexp, accept_scope_in_define=accept_scope_in_define, accept_condition=accept_condition, do_format_regexp=not is_steps_catalog) #pylint: disable=no-member @UndefinedVariable
|
|
198
|
+
|
|
199
|
+
def Then(regexp):
|
|
200
|
+
return _wrapped_step(behave.then, regexp, do_format_regexp=not is_steps_catalog) #pylint: disable=no-member @UndefinedVariable
|
|
201
|
+
|
|
202
|
+
def When(regexp):
|
|
203
|
+
return _wrapped_step(behave.when, regexp, do_format_regexp=not is_steps_catalog) #pylint: disable=no-member @UndefinedVariable
|
|
204
|
+
|
|
205
|
+
def Step(regexp):
|
|
206
|
+
return _wrapped_step(behave.step, regexp, do_format_regexp=not is_steps_catalog) #pylint: disable=no-member @UndefinedVariable
|
|
207
|
+
|
|
208
|
+
# def For(regexp):
|
|
209
|
+
# return _wrapped_step(behave.step, regexp, accept_expected_exception=False) #pylint: disable=no-member @UndefinedVariable
|
|
210
|
+
|
|
211
|
+
|
|
212
|
+
def _wrapped_step(step_function, regexp, accept_expected_exception=True, accept_condition=True, accept_scope_in_define=True, do_format_regexp=True):
|
|
213
|
+
# Replace SRE types by associated regex
|
|
214
|
+
if do_format_regexp:
|
|
215
|
+
try:
|
|
216
|
+
regexp = regexp.format(**SRE.all_as_dict())
|
|
217
|
+
except IndexError:
|
|
218
|
+
# This error occurs when regexp has no {} section to format
|
|
219
|
+
pass
|
|
220
|
+
except KeyError:
|
|
221
|
+
# This error can occur when format is already done in file defining step
|
|
222
|
+
pass
|
|
223
|
+
|
|
224
|
+
def wrapper(func):
|
|
225
|
+
res_func = func
|
|
226
|
+
if accept_expected_exception:
|
|
227
|
+
res_func = _accept_expected_exception(res_func)
|
|
228
|
+
if accept_condition:
|
|
229
|
+
res_func = _accept_condition(res_func)
|
|
230
|
+
if accept_scope_in_define:
|
|
231
|
+
res_func = _accept_scope_in_define(res_func)
|
|
232
|
+
return step_function(regexp)(res_func)
|
|
233
|
+
return wrapper
|
|
234
|
+
|
|
235
|
+
def _accept_condition(func):
|
|
236
|
+
"""
|
|
237
|
+
If a condition is ongoing, and current condition is not valid, bypass the step execution.
|
|
238
|
+
"""
|
|
239
|
+
def wrapper(context, *args, **kwargs):
|
|
240
|
+
# logger.debug(f"++++++++++ Wrapper begin ; func={Typing.get_object_class_fullname(func)} ; context={context.__dict__} ; args={args} ; kwargs={kwargs}")
|
|
241
|
+
if __get_scope_manager().is_in_condition() and not __get_scope_manager().is_in_valid_condition():
|
|
242
|
+
step_context = __get_scope_manager().get_step_context()
|
|
243
|
+
step_context.status = "skipped"
|
|
244
|
+
else:
|
|
245
|
+
func(context, *args, **kwargs)
|
|
246
|
+
|
|
247
|
+
return wrapper
|
|
248
|
+
|
|
249
|
+
def _accept_scope_in_define(func):
|
|
250
|
+
"""
|
|
251
|
+
If a block is under definition, bypass step execution.
|
|
252
|
+
Note: in before_step, the step was added in scope under define.
|
|
253
|
+
"""
|
|
254
|
+
def wrapper(context, *args, **kwargs):
|
|
255
|
+
# logger.debug(f"++++++++++ Wrapper begin ; func={Typing.get_object_class_fullname(func)} ; context={context.__dict__} ; args={args} ; kwargs={kwargs}")
|
|
256
|
+
if __get_block_manager().is_in_define:
|
|
257
|
+
# Bypass step execution: in before_step, the step was added in scope under define
|
|
258
|
+
pass
|
|
259
|
+
else:
|
|
260
|
+
func(context, *args, **kwargs)
|
|
261
|
+
|
|
262
|
+
return wrapper
|
|
263
|
+
|
|
264
|
+
|
|
265
|
+
|
|
266
|
+
###################################################################################################
|
|
267
|
+
## Manage expected exception
|
|
268
|
+
|
|
269
|
+
def _accept_expected_exception(func):
|
|
270
|
+
"""
|
|
271
|
+
If an error is expected, check if an error really occurs and if it matches expected error.
|
|
272
|
+
Otherwise raise it again.
|
|
273
|
+
"""
|
|
274
|
+
def wrapper(context, *args, **kwargs):
|
|
275
|
+
# logger.debug(f"++++++++++ Wrapper begin ; context={context.__dict__} ; args={args} ; kwargs={kwargs}")
|
|
276
|
+
try:
|
|
277
|
+
func(context, *args, **kwargs)
|
|
278
|
+
except Exception as exc: #pylint: disable=W0703
|
|
279
|
+
__process_step_exception(context, exc)
|
|
280
|
+
|
|
281
|
+
__process_expected_exception_at_end_of_step(context)
|
|
282
|
+
|
|
283
|
+
return wrapper
|
|
284
|
+
|
|
285
|
+
def __process_step_exception(context, exc):
|
|
286
|
+
if not __has_scenario_context():
|
|
287
|
+
raise exc
|
|
288
|
+
|
|
289
|
+
# logger.debug(f"++++++++++ Wrapper: exception catched: {exc}")
|
|
290
|
+
exc_verified = False
|
|
291
|
+
# Verify exception if an exception was expected
|
|
292
|
+
if not context.in_expected_exception_step \
|
|
293
|
+
and __get_scope_manager().scope_level("steps") == context.expected_exception_step_level \
|
|
294
|
+
and MultitaskManager.get_thread_id() == context.expected_exception_thread_id:
|
|
295
|
+
# logger.debug(f"++++++++++ Wrapper: verify catched exception")
|
|
296
|
+
exc_verified = True
|
|
297
|
+
if isinstance(exc, HAException) or not hasattr(context, "sub_step_exception") or context.sub_step_exception is None:
|
|
298
|
+
exc_to_verify = exc
|
|
299
|
+
else:
|
|
300
|
+
exc_to_verify = context.sub_step_exception
|
|
301
|
+
|
|
302
|
+
# Reset expected exception, only try matching once.
|
|
303
|
+
expected_exception_str, expected_exception_pattern = pop_expected_exception(context)
|
|
304
|
+
|
|
305
|
+
# Process verification
|
|
306
|
+
# logger.debug(f"++++++++++ Wrapper: process verification on exception: {exc_to_verify}")
|
|
307
|
+
if expected_exception_str:
|
|
308
|
+
exc_str = "{}({})".format(Typing.get_object_class_fullname(exc_to_verify), str(exc_to_verify))
|
|
309
|
+
if expected_exception_str != exc_str:
|
|
310
|
+
raise VerifyException(f"Obtained exception is not the expected one:\n obtained: {exc_str}\n expected: {expected_exception_str}")
|
|
311
|
+
elif expected_exception_pattern:
|
|
312
|
+
exc_str = "{}({})".format(Typing.get_object_class_fullname(exc_to_verify), str(exc_to_verify))
|
|
313
|
+
regex = re.compile(expected_exception_pattern, re.DOTALL)
|
|
314
|
+
|
|
315
|
+
if not regex.search(exc_str):
|
|
316
|
+
raise VerifyException(f"Obtained exception is not matching the expected pattern:\n obtained: {exc_str}\n expected pattern: '{expected_exception_pattern}'")
|
|
317
|
+
|
|
318
|
+
# Update status
|
|
319
|
+
# logger.debug(f"++++++++++ Wrapper: update behave objects")
|
|
320
|
+
context.do_update_step_status = Status.passed
|
|
321
|
+
|
|
322
|
+
# Store as sub-step exception
|
|
323
|
+
if __get_scope_manager().scope_level("steps") > 0 and not exc_verified:
|
|
324
|
+
context.sub_step_exception = exc
|
|
325
|
+
|
|
326
|
+
# If no other exception is raised, re-raise the same exception
|
|
327
|
+
if not exc_verified:
|
|
328
|
+
# logger.debug(f"++++++++++ Wrapper: raise catched exception")
|
|
329
|
+
raise
|
|
330
|
+
|
|
331
|
+
def __process_expected_exception_at_end_of_step(context):
|
|
332
|
+
if context.in_expected_exception_step:
|
|
333
|
+
# logger.debug(f"++++++++++ Wrapper: Finish declaration of step setting expected exception")
|
|
334
|
+
# Finish declaration of step setting expected exception
|
|
335
|
+
leave_expected_exception_step(context)
|
|
336
|
+
elif __get_scope_manager().scope_level("steps") == context.expected_exception_step_level \
|
|
337
|
+
and MultitaskManager.get_thread_id() == context.expected_exception_thread_id:
|
|
338
|
+
# logger.debug(f"++++++++++ Wrapper: Manage expected exception has not occurred")
|
|
339
|
+
# Manage expected exception has not occurred
|
|
340
|
+
if context.expected_exception_str:
|
|
341
|
+
# Raise exception to make scenario failing, since step hasn't failed as expected
|
|
342
|
+
msg = "Step passed but was expected fail on an exception:\n step:\n{}\n expected exception:\n{}".format(
|
|
343
|
+
Tools.indent_string(8, __step_description(context)),
|
|
344
|
+
Tools.indent_string(8, context.expected_exception_str))
|
|
345
|
+
if context.step.hook_failed:
|
|
346
|
+
msg += "\n Hook failed"
|
|
347
|
+
logger.error(msg)
|
|
348
|
+
raise FunctionalException(msg)
|
|
349
|
+
elif context.expected_exception_pattern:
|
|
350
|
+
# Raise exception to make scenario failing, since step hasn't failed as expected
|
|
351
|
+
msg = "Step passed but was expected fail on an exception:\n step:\n{}\n expected exception matching: '{}'".format(
|
|
352
|
+
Tools.indent_string(8, __step_description(context)),
|
|
353
|
+
Tools.indent_string(8, context.expected_exception_pattern))
|
|
354
|
+
if context.step.hook_failed:
|
|
355
|
+
msg += "\n Hook failed"
|
|
356
|
+
logger.error(msg)
|
|
357
|
+
raise FunctionalException(msg)
|
|
358
|
+
else:
|
|
359
|
+
raise TechnicalException("No expected exception is configured")
|
|
360
|
+
|
|
361
|
+
def enter_expected_exception_step(context, expected_exception_str = None, expected_exception_pattern=None):
|
|
362
|
+
context.expected_exception_str = expected_exception_str
|
|
363
|
+
context.expected_exception_pattern = expected_exception_pattern
|
|
364
|
+
context.in_expected_exception_step = True
|
|
365
|
+
context.expected_exception_step_level = __get_scope_manager().scope_level("steps")
|
|
366
|
+
context.expected_exception_thread_id = MultitaskManager.get_thread_id()
|
|
367
|
+
|
|
368
|
+
def leave_expected_exception_step(context):
|
|
369
|
+
context.in_expected_exception_step = False
|
|
370
|
+
|
|
371
|
+
def pop_expected_exception(context):
|
|
372
|
+
expected_exception_str = context.expected_exception_str
|
|
373
|
+
expected_exception_pattern = context.expected_exception_pattern
|
|
374
|
+
context.expected_exception_str = None
|
|
375
|
+
context.expected_exception_pattern = None
|
|
376
|
+
context.expected_exception_step_level = -1
|
|
377
|
+
context.expected_exception_thread_id = None
|
|
378
|
+
return expected_exception_str, expected_exception_pattern
|
|
379
|
+
|
|
380
|
+
|
|
381
|
+
|
|
382
|
+
###################################################################################################
|
|
383
|
+
## Setup custom step decorators
|
|
384
|
+
###################################################################################################
|
|
385
|
+
|
|
386
|
+
### /!\ Not yet working, that's why next lines are commented
|
|
387
|
+
### Next lines enable the decorator, so that declaration of steps with this decorator is working.
|
|
388
|
+
### But behave has to be patched to parse .feature correctly and considering these decorators as steps:
|
|
389
|
+
### - in behave/parser.py: in Parser.parse_step, manage the new step types ('for')
|
|
390
|
+
### - in behave/i18n.py: add the new step types ('for')
|
|
391
|
+
|
|
392
|
+
# def setup_step_decorators():
|
|
393
|
+
# registry=behave.step_registry.registry
|
|
394
|
+
# for step_type in ("for",):
|
|
395
|
+
# registry.steps[step_type] = []
|
|
396
|
+
# registry.make_decorator(step_type)
|
|
397
|
+
#
|
|
398
|
+
# setup_step_decorators()
|
|
399
|
+
|
|
400
|
+
|
|
@@ -0,0 +1,169 @@
|
|
|
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
|
+
import behave
|
|
17
|
+
|
|
18
|
+
from holado.common.context.session_context import SessionContext
|
|
19
|
+
from holado_core.common.tools.tools import Tools
|
|
20
|
+
import types
|
|
21
|
+
from holado_test.behave.scenario.behave_step_tools import BehaveStepTools
|
|
22
|
+
from holado_test.scenario.step_tools import StepTools
|
|
23
|
+
from holado_test.test_config import TestConfig
|
|
24
|
+
import time
|
|
25
|
+
from behave.model_core import Status
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
logger = logging.getLogger(__name__)
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
# Use regular expression in step definitions
|
|
32
|
+
behave.use_step_matcher(BehaveStepTools.DEFAULT_STEP_MATCHER)
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
def __has_scenario_context():
|
|
36
|
+
return SessionContext.instance().has_scenario_context()
|
|
37
|
+
|
|
38
|
+
def __get_scope_manager():
|
|
39
|
+
if __has_scenario_context():
|
|
40
|
+
return SessionContext.instance().get_scenario_context().scope_manager
|
|
41
|
+
else:
|
|
42
|
+
return None
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
def before_all(context):
|
|
46
|
+
try:
|
|
47
|
+
SessionContext.instance().before_all(context)
|
|
48
|
+
except:
|
|
49
|
+
logger.exception("Hook error")
|
|
50
|
+
raise
|
|
51
|
+
|
|
52
|
+
def after_all(context):
|
|
53
|
+
try:
|
|
54
|
+
SessionContext.instance().after_all()
|
|
55
|
+
except:
|
|
56
|
+
logger.exception("Hook error")
|
|
57
|
+
raise
|
|
58
|
+
|
|
59
|
+
def before_feature(context, feature):
|
|
60
|
+
try:
|
|
61
|
+
SessionContext.instance().before_feature(feature)
|
|
62
|
+
except:
|
|
63
|
+
logger.exception(f"Hook error (feature: {feature})")
|
|
64
|
+
raise
|
|
65
|
+
|
|
66
|
+
def after_feature(context, feature):
|
|
67
|
+
try:
|
|
68
|
+
SessionContext.instance().after_feature(feature)
|
|
69
|
+
except:
|
|
70
|
+
logger.exception(f"Hook error (feature: {feature})")
|
|
71
|
+
raise
|
|
72
|
+
|
|
73
|
+
def before_scenario(context, scenario):
|
|
74
|
+
try:
|
|
75
|
+
SessionContext.instance().before_scenario(scenario)
|
|
76
|
+
except:
|
|
77
|
+
logger.exception(f"Hook error (scenario: {scenario})")
|
|
78
|
+
raise
|
|
79
|
+
|
|
80
|
+
def after_scenario(context, scenario):
|
|
81
|
+
# Process after step for undefined and skipped steps
|
|
82
|
+
try:
|
|
83
|
+
for step in scenario.steps[SessionContext.instance().get_scenario_context().get_nb_steps():]:
|
|
84
|
+
after_step(context, step, has_started=False)
|
|
85
|
+
except:
|
|
86
|
+
logger.exception(f"Hook error (scenario: {scenario})")
|
|
87
|
+
|
|
88
|
+
# Process after scenario
|
|
89
|
+
try:
|
|
90
|
+
SessionContext.instance().after_scenario(scenario)
|
|
91
|
+
except:
|
|
92
|
+
logger.exception(f"Hook error (scenario: {scenario})")
|
|
93
|
+
raise
|
|
94
|
+
|
|
95
|
+
def before_step(context, step):
|
|
96
|
+
try:
|
|
97
|
+
scope_manager = __get_scope_manager()
|
|
98
|
+
logger.info(f"Step [{__step_description(step)}] (level: {scope_manager.scope_level('steps') if scope_manager else '?'})")
|
|
99
|
+
|
|
100
|
+
SessionContext.instance().before_step(step)
|
|
101
|
+
except:
|
|
102
|
+
# logger.exception(f"Hook error (step: {step})")
|
|
103
|
+
logger.exception(f"Hook error (step: {step})", stack_info=True)
|
|
104
|
+
raise
|
|
105
|
+
|
|
106
|
+
context.step = step
|
|
107
|
+
|
|
108
|
+
def after_step(context, step, has_started=True):
|
|
109
|
+
try:
|
|
110
|
+
# Update step if needed (ex: if step raised an expected exception, the step is in fact passing)
|
|
111
|
+
if hasattr(context, "do_update_step_status"):
|
|
112
|
+
# logger.warning(f"+++++++++++ Update step status to {context.do_update_step_status}")
|
|
113
|
+
step.status = context.do_update_step_status
|
|
114
|
+
del context.do_update_step_status
|
|
115
|
+
|
|
116
|
+
# Session context
|
|
117
|
+
SessionContext.instance().after_step(step, has_started=has_started)
|
|
118
|
+
|
|
119
|
+
# Log step result
|
|
120
|
+
step_descr = __step_description(step)
|
|
121
|
+
try:
|
|
122
|
+
var_step_descr = StepTools.evaluate_variable_name(step_descr, log_level=logging.NOTSET)
|
|
123
|
+
except:
|
|
124
|
+
var_step_descr = "[ERROR during evaluation]"
|
|
125
|
+
try:
|
|
126
|
+
interpreted_step_descr = StepTools.evaluate_string_parameter(step_descr, log_level=logging.NOTSET)
|
|
127
|
+
except:
|
|
128
|
+
interpreted_step_descr = "[ERROR during interpretation]"
|
|
129
|
+
if step.status in [Status.failed, Status.error] or interpreted_step_descr != step_descr or var_step_descr != interpreted_step_descr:
|
|
130
|
+
msg = "Step {}:\n step:\n{}{}{}".format(
|
|
131
|
+
step.status.name, Tools.indent_string(8, step_descr),
|
|
132
|
+
"" if interpreted_step_descr == step_descr else "\n interpreted step:\n{}".format(Tools.indent_string(8, interpreted_step_descr)),
|
|
133
|
+
"" if var_step_descr == interpreted_step_descr else "\n partially interpreted step:\n{}".format(Tools.indent_string(8, var_step_descr)) )
|
|
134
|
+
|
|
135
|
+
if step.status in [Status.failed, Status.error]:
|
|
136
|
+
msg += "\n error:\n{}\n step attributes:\n{}".format(
|
|
137
|
+
Tools.indent_string(8, __step_error(step)),
|
|
138
|
+
Tools.indent_string(8, __step_attributes(step)) )
|
|
139
|
+
if step.hook_failed:
|
|
140
|
+
msg += "\n Hook failed"
|
|
141
|
+
elif '\n' in step_descr:
|
|
142
|
+
msg = "Step {}:\n{}".format(step.status.name, Tools.indent_string(4, step_descr))
|
|
143
|
+
else:
|
|
144
|
+
msg = "Step {}: {}".format(step.status.name, step_descr)
|
|
145
|
+
|
|
146
|
+
if step.status in [Status.failed, Status.error]:
|
|
147
|
+
logger.error(msg)
|
|
148
|
+
|
|
149
|
+
if TestConfig.wait_on_step_failure_s > 0:
|
|
150
|
+
time.sleep(TestConfig.wait_on_step_failure_s)
|
|
151
|
+
else:
|
|
152
|
+
logger.debug(msg)
|
|
153
|
+
except:
|
|
154
|
+
logger.exception(f"Hook error (step: {step})")
|
|
155
|
+
raise
|
|
156
|
+
|
|
157
|
+
def __step_description(step):
|
|
158
|
+
return SessionContext.instance().report_manager.get_step_description(step)
|
|
159
|
+
|
|
160
|
+
def __step_error(step):
|
|
161
|
+
return SessionContext.instance().report_manager.get_step_error(step)
|
|
162
|
+
|
|
163
|
+
def __step_attributes(step):
|
|
164
|
+
res_list = []
|
|
165
|
+
for attr_name in dir(step):
|
|
166
|
+
if not attr_name.startswith("__") and type(getattr(step, attr_name)) not in [types.MethodType, types.MethodWrapperType]:
|
|
167
|
+
res_list.append("{}: {}".format(attr_name, str(getattr(step, attr_name))))
|
|
168
|
+
return "\n".join(res_list)
|
|
169
|
+
|