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,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_report.report.builders.report_builder import ReportBuilder
|
|
16
|
+
from holado_report.report.report_manager import ReportManager
|
|
17
|
+
from holado_python.common.tools.datetime import FORMAT_DATETIME_ISO, DateTime
|
|
18
|
+
from holado_system.system.filesystem.file import File
|
|
19
|
+
from holado_core.common.exceptions.technical_exception import TechnicalException
|
|
20
|
+
|
|
21
|
+
logger = logging.getLogger(__name__)
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
class SummaryScenarioReportBuilder(ReportBuilder):
|
|
26
|
+
def __init__(self, filepath, file_format='txt', exclude_statuses=None, exclude_categories=None, with_scenario_end_date=True, with_scenario_period=False, with_step_period=False, use_compact_format=True):
|
|
27
|
+
self.__file_format = file_format.lower()
|
|
28
|
+
self.__exclude_statuses = exclude_statuses
|
|
29
|
+
self.__exclude_categories = exclude_categories
|
|
30
|
+
self.__with_scenario_end_date = with_scenario_end_date
|
|
31
|
+
self.__with_scenario_period = with_scenario_period
|
|
32
|
+
self.__with_step_period = with_step_period
|
|
33
|
+
self.__use_compact_format = use_compact_format
|
|
34
|
+
|
|
35
|
+
if self.__file_format == 'txt':
|
|
36
|
+
self.__file = File(filepath, mode='wt')
|
|
37
|
+
else:
|
|
38
|
+
raise TechnicalException(f"Unmanaged format '{self.__file_format}' (possible formats: 'txt')")
|
|
39
|
+
|
|
40
|
+
def build(self):
|
|
41
|
+
'''
|
|
42
|
+
The file is built after each scenario
|
|
43
|
+
'''
|
|
44
|
+
pass
|
|
45
|
+
|
|
46
|
+
def after_scenario(self, scenario, scenario_report=None):
|
|
47
|
+
category_validation, status_validation, step_failed, step_number, scenario_context, step_context = ReportManager.get_current_scenario_status_information(scenario)
|
|
48
|
+
|
|
49
|
+
# Manage excluded scenario on status
|
|
50
|
+
if self.__exclude_statuses and status_validation in self.__exclude_statuses:
|
|
51
|
+
return
|
|
52
|
+
|
|
53
|
+
self.__file_add_scenario(scenario, category_validation, status_validation, step_failed, step_number, scenario_context, step_context)
|
|
54
|
+
|
|
55
|
+
def after_all(self):
|
|
56
|
+
self.__file.close()
|
|
57
|
+
|
|
58
|
+
def __file_add_scenario(self, scenario, category_validation, status_validation, step_failed, step_number, scenario_context, step_context):
|
|
59
|
+
self.__open_file_if_needed()
|
|
60
|
+
|
|
61
|
+
# Manage excluded scenario on category
|
|
62
|
+
if category_validation:
|
|
63
|
+
ind = category_validation.find(' (')
|
|
64
|
+
category = category_validation[:ind] if ind > 0 else category_validation
|
|
65
|
+
if self.__exclude_categories and category in self.__exclude_categories:
|
|
66
|
+
return
|
|
67
|
+
|
|
68
|
+
category_str = f" => {category_validation}" if category_validation else ""
|
|
69
|
+
scenario_prefix_str = f"{ReportManager.format_context_period(scenario_context)} " if self.__with_scenario_period \
|
|
70
|
+
else f"{DateTime.datetime_2_str(scenario_context.end_datetime, FORMAT_DATETIME_ISO)} - " if self.__with_scenario_end_date else ""
|
|
71
|
+
if step_failed:
|
|
72
|
+
step_format_kwargs = {'step_context': step_context if self.__with_step_period else None,
|
|
73
|
+
'dt_ref': scenario_context.start_datetime if self.__use_compact_format else None}
|
|
74
|
+
self.__file.write(f"{scenario_prefix_str}{ReportManager.format_scenario_short_description(scenario)} - {ReportManager.format_step_short_description(step_failed, step_number, has_failed=True, **step_format_kwargs)} - {status_validation}{category_str}\n")
|
|
75
|
+
else:
|
|
76
|
+
self.__file.write(f"{scenario_prefix_str}{ReportManager.format_scenario_short_description(scenario)} - {status_validation}{category_str}\n")
|
|
77
|
+
|
|
78
|
+
def __open_file_if_needed(self):
|
|
79
|
+
if not self.__file.is_open:
|
|
80
|
+
self.__file.open()
|
|
81
|
+
|
|
@@ -0,0 +1,144 @@
|
|
|
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
|
|
16
|
+
from typing import NamedTuple
|
|
17
|
+
from holado.common.context.session_context import SessionContext
|
|
18
|
+
|
|
19
|
+
logger = logging.getLogger(__name__)
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
class ExecutionHistoric():
|
|
24
|
+
def __init__(self):
|
|
25
|
+
self.__execution_historic = []
|
|
26
|
+
|
|
27
|
+
def __iter__(self):
|
|
28
|
+
return self.__execution_historic.__iter__()
|
|
29
|
+
|
|
30
|
+
def __next__(self):
|
|
31
|
+
return self.__execution_historic.__next__()
|
|
32
|
+
|
|
33
|
+
def __has_scenario_context(self):
|
|
34
|
+
return SessionContext.instance().has_scenario_context()
|
|
35
|
+
|
|
36
|
+
@property
|
|
37
|
+
def __multitask_manager(self):
|
|
38
|
+
return SessionContext.instance().multitask_manager
|
|
39
|
+
|
|
40
|
+
def before_all(self):
|
|
41
|
+
pass
|
|
42
|
+
|
|
43
|
+
def before_feature(self, feature_context, feature, feature_report=None):
|
|
44
|
+
self.__execution_historic.append( self.__new_FeatureExecutionHistoric(feature_context, feature, feature_report) )
|
|
45
|
+
|
|
46
|
+
def __new_FeatureExecutionHistoric(self, feature_context, feature, feature_report=None):
|
|
47
|
+
res = NamedTuple("FeatureExecutionHistoric", feature_context=object, feature=object, feature_report=object, scenarios=list)
|
|
48
|
+
res.feature_context = feature_context
|
|
49
|
+
res.feature = feature
|
|
50
|
+
res.feature_report = feature_report
|
|
51
|
+
res.scenarios = []
|
|
52
|
+
return res
|
|
53
|
+
|
|
54
|
+
def before_scenario(self, scenario_context, scenario, scenario_report=None):
|
|
55
|
+
seh = self.__new_ScenarioExecutionHistoric(scenario_context, scenario, scenario_report)
|
|
56
|
+
self.__get_execution_historic_current_feature_scenarios().append(seh)
|
|
57
|
+
|
|
58
|
+
def __new_ScenarioExecutionHistoric(self, scenario_context, scenario, scenario_report):
|
|
59
|
+
res = NamedTuple("ScenarioExecutionHistoric", scenario_context=object, scenario=object, scenario_report=object, steps_by_scope=dict,
|
|
60
|
+
category_validation=str, status_validation=str, step_failed=object, step_failed_number=int)
|
|
61
|
+
res.scenario_context = scenario_context
|
|
62
|
+
res.scenario = scenario
|
|
63
|
+
res.scenario_report = scenario_report
|
|
64
|
+
res.steps_by_scope = {}
|
|
65
|
+
res.category_validation = None
|
|
66
|
+
res.status_validation = None
|
|
67
|
+
res.step_failed = None
|
|
68
|
+
res.step_failed_number = None
|
|
69
|
+
return res
|
|
70
|
+
|
|
71
|
+
def before_step(self, step_context, step, step_level):
|
|
72
|
+
seh = self.__new_StepExecutionHistoric(step_context, step)
|
|
73
|
+
self.__get_execution_historic_current_scenario_steps(step_level).append(seh)
|
|
74
|
+
|
|
75
|
+
def __new_StepExecutionHistoric(self, step_context, step, step_description=None):
|
|
76
|
+
if step_description is None and step is not None:
|
|
77
|
+
from holado_report.report.report_manager import ReportManager
|
|
78
|
+
step_description = ReportManager.get_step_description(step)
|
|
79
|
+
|
|
80
|
+
res = NamedTuple("StepExecutionHistoric", step_context=object, step=object, step_description=str, sub_steps=list)
|
|
81
|
+
res.step_context = step_context
|
|
82
|
+
res.step = step
|
|
83
|
+
res.step_description = step_description
|
|
84
|
+
res.sub_steps = []
|
|
85
|
+
return res
|
|
86
|
+
|
|
87
|
+
def after_step(self, step_context, step, step_level):
|
|
88
|
+
pass
|
|
89
|
+
|
|
90
|
+
def after_scenario(self, scenario, scenario_report=None):
|
|
91
|
+
from holado_report.report.report_manager import ReportManager
|
|
92
|
+
category_validation, status_validation, step_failed, step_number, _, _ = ReportManager.get_current_scenario_status_information(scenario)
|
|
93
|
+
|
|
94
|
+
# Update execution historic
|
|
95
|
+
current_scenario = self.__get_execution_historic_current_scenario()
|
|
96
|
+
current_scenario.category_validation = category_validation
|
|
97
|
+
current_scenario.status_validation = status_validation
|
|
98
|
+
current_scenario.step_failed = step_failed
|
|
99
|
+
current_scenario.step_failed_number = step_number
|
|
100
|
+
|
|
101
|
+
# Prepare after scenario steps
|
|
102
|
+
seh = self.__new_StepExecutionHistoric(step_context=None, step=None, step_description="After scenario steps")
|
|
103
|
+
self.__get_execution_historic_current_scenario_steps(0).append(seh)
|
|
104
|
+
|
|
105
|
+
|
|
106
|
+
def after_feature(self, feature, feature_report=None):
|
|
107
|
+
pass
|
|
108
|
+
|
|
109
|
+
def after_all(self):
|
|
110
|
+
# logger.info(f"++++++++++ Execution historic size: {len(self.__execution_historic)}")
|
|
111
|
+
pass
|
|
112
|
+
|
|
113
|
+
def __get_execution_historic_current_feature_scenarios(self):
|
|
114
|
+
if len(self.__execution_historic) > 0:
|
|
115
|
+
return self.__execution_historic[-1].scenarios
|
|
116
|
+
else:
|
|
117
|
+
raise TechnicalException(f"No feature in execution historic")
|
|
118
|
+
|
|
119
|
+
def __get_execution_historic_current_scenario(self):
|
|
120
|
+
scenario_list = self.__get_execution_historic_current_feature_scenarios()
|
|
121
|
+
if len(scenario_list) > 0:
|
|
122
|
+
return scenario_list[-1]
|
|
123
|
+
else:
|
|
124
|
+
raise TechnicalException(f"No scenario in current feature in execution historic")
|
|
125
|
+
|
|
126
|
+
def __get_execution_historic_current_scenario_steps(self, step_level):
|
|
127
|
+
steps_by_scope = self.__get_execution_historic_current_scenario().steps_by_scope
|
|
128
|
+
|
|
129
|
+
if self.__multitask_manager.is_main_thread:
|
|
130
|
+
scope_name = "main"
|
|
131
|
+
else:
|
|
132
|
+
scope_name = self.__multitask_manager.get_thread_id()
|
|
133
|
+
if scope_name not in steps_by_scope:
|
|
134
|
+
steps_by_scope[scope_name] = []
|
|
135
|
+
res = steps_by_scope[scope_name]
|
|
136
|
+
|
|
137
|
+
for level in range(step_level):
|
|
138
|
+
if len(res) == 0:
|
|
139
|
+
logger.warning(f"Failed to get current scenario step list of level {step_level} (step list of level {level}: {res}) ; Add a fake step with description '[Missing step]'")
|
|
140
|
+
res.append( self.__new_StepExecutionHistoric(None, None, "[Missing step]") )
|
|
141
|
+
res = res[-1].sub_steps
|
|
142
|
+
return res
|
|
143
|
+
|
|
144
|
+
|
|
@@ -0,0 +1,424 @@
|
|
|
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.common.context.session_context import SessionContext
|
|
15
|
+
from holado_core.common.tools.tools import Tools
|
|
16
|
+
import logging
|
|
17
|
+
from holado_report.report.reports.base_report import BaseReport
|
|
18
|
+
from holado_scripting.common.tools.evaluate_parameters import EvaluateParameters
|
|
19
|
+
from holado_python.common.tools.datetime import DateTime, FORMAT_DATETIME_ISO, FORMAT_TIME_ISO
|
|
20
|
+
from holado.common.handlers.undefined import default_value, undefined_argument
|
|
21
|
+
from holado.holado_config import Config
|
|
22
|
+
# from holado_core.scenario.scenario_duration_manager import ScenarioDurationManager
|
|
23
|
+
|
|
24
|
+
logger = logging.getLogger(__name__)
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
class ReportManager(BaseReport):
|
|
30
|
+
""" Manage reports of current session
|
|
31
|
+
"""
|
|
32
|
+
TFeatureReport = None
|
|
33
|
+
TStepTools = None
|
|
34
|
+
|
|
35
|
+
_scenario_status_information_by_uid = {}
|
|
36
|
+
|
|
37
|
+
def __init__(self):
|
|
38
|
+
super().__init__()
|
|
39
|
+
|
|
40
|
+
self.__multitask_manager = None
|
|
41
|
+
|
|
42
|
+
# Auto configuration
|
|
43
|
+
self.configure()
|
|
44
|
+
|
|
45
|
+
def configure(self):
|
|
46
|
+
from holado_report.report.reports.feature_report import FeatureReport
|
|
47
|
+
ReportManager.TFeatureReport = FeatureReport
|
|
48
|
+
|
|
49
|
+
from holado_test.behave.scenario.behave_step_tools import BehaveStepTools
|
|
50
|
+
ReportManager.TStepTools = BehaveStepTools
|
|
51
|
+
|
|
52
|
+
def initialize(self, multitask_manager):
|
|
53
|
+
self.__multitask_manager = multitask_manager
|
|
54
|
+
|
|
55
|
+
def initialize_reports(self):
|
|
56
|
+
from holado_report.report.builders.detailed_scenario_report_builder import DetailedScenarioReportBuilder
|
|
57
|
+
from holado_report.report.builders.summary_report_builder import SummaryReportBuilder
|
|
58
|
+
from holado_report.report.builders.summary_scenario_report_builder import SummaryScenarioReportBuilder
|
|
59
|
+
from holado_report.report.builders.short_scenario_report_builder import ShortScenarioReportBuilder
|
|
60
|
+
from holado_report.report.builders.failure_report_builder import FailureReportBuilder
|
|
61
|
+
from holado_report.report.builders.summary_scenario_by_category_report_builder import SummaryScenarioByCategoryReportBuilder
|
|
62
|
+
from holado_report.report.builders.summary_by_category_report_builder import SummaryByCategoryReportBuilder
|
|
63
|
+
|
|
64
|
+
# self.set_execution_historic()
|
|
65
|
+
|
|
66
|
+
if self.has_report_path:
|
|
67
|
+
# fn = self.get_path("execution_historic.json")
|
|
68
|
+
# self.add_report_builder(ExecutionHistoricReportBuilder(self.execution_historic, fn))
|
|
69
|
+
|
|
70
|
+
fn = self.get_path("report_summary_scenario_failed.txt")
|
|
71
|
+
self.add_report_builder(SummaryScenarioReportBuilder(fn, exclude_statuses=['Passed']))
|
|
72
|
+
|
|
73
|
+
fn = self.get_path("report_summary_scenario_failed_by_category.txt")
|
|
74
|
+
self.add_report_builder(SummaryScenarioByCategoryReportBuilder(fn, exclude_categories=['Always Success']))
|
|
75
|
+
|
|
76
|
+
fn = self.get_path("report_summary_scenario_all.txt")
|
|
77
|
+
self.add_report_builder(SummaryScenarioReportBuilder(fn))
|
|
78
|
+
|
|
79
|
+
fn = self.get_path("report_failures.xml")
|
|
80
|
+
self.add_report_builder(FailureReportBuilder(fn))
|
|
81
|
+
|
|
82
|
+
fn = self.get_path("report_short_scenario_failed.txt")
|
|
83
|
+
self.add_report_builder(ShortScenarioReportBuilder(fn, exclude_statuses=['Passed']))
|
|
84
|
+
|
|
85
|
+
fn = self.get_path(Config.campaign_manager_import_report_name) # @UndefinedVariable
|
|
86
|
+
self.add_report_builder(DetailedScenarioReportBuilder(fn))
|
|
87
|
+
|
|
88
|
+
fn = self.get_path("report_summary.txt")
|
|
89
|
+
self.add_report_builder(SummaryReportBuilder(fn))
|
|
90
|
+
|
|
91
|
+
fn = self.get_path("report_summary_by_category.txt")
|
|
92
|
+
self.add_report_builder(SummaryByCategoryReportBuilder(fn))
|
|
93
|
+
|
|
94
|
+
@property
|
|
95
|
+
def __feature_reports(self):
|
|
96
|
+
return self.children_reports("feature")
|
|
97
|
+
|
|
98
|
+
@property
|
|
99
|
+
def current_feature_report(self):
|
|
100
|
+
# if self.__feature_reports:
|
|
101
|
+
# return self.__feature_reports[-1][1]
|
|
102
|
+
# else:
|
|
103
|
+
# return None
|
|
104
|
+
if SessionContext.instance().has_feature_context():
|
|
105
|
+
feature_context = SessionContext.instance().get_feature_context()
|
|
106
|
+
if feature_context.has_object("feature_report"):
|
|
107
|
+
return feature_context.get_object("feature_report")
|
|
108
|
+
return None
|
|
109
|
+
|
|
110
|
+
@property
|
|
111
|
+
def current_scenario_report(self):
|
|
112
|
+
cfr = self.current_feature_report
|
|
113
|
+
if cfr:
|
|
114
|
+
return cfr.current_scenario_report
|
|
115
|
+
else:
|
|
116
|
+
return None
|
|
117
|
+
|
|
118
|
+
def new_session(self, report_path):
|
|
119
|
+
self.report_path = report_path
|
|
120
|
+
if self.has_report_path:
|
|
121
|
+
SessionContext.instance().path_manager.makedirs(self.report_path, is_directory=True)
|
|
122
|
+
|
|
123
|
+
self.initialize_reports()
|
|
124
|
+
|
|
125
|
+
def before_all(self):
|
|
126
|
+
super().before_all()
|
|
127
|
+
|
|
128
|
+
def before_feature(self, feature_context, feature):
|
|
129
|
+
# Create new feature report
|
|
130
|
+
fr = ReportManager.TFeatureReport(self, feature_context, feature)
|
|
131
|
+
self.add_child_report(fr, "feature", feature.name, feature.filename)
|
|
132
|
+
fr.initialize_reports()
|
|
133
|
+
|
|
134
|
+
# Process self reports
|
|
135
|
+
super().before_feature(feature_context, feature, feature_report=fr)
|
|
136
|
+
|
|
137
|
+
# Store feature report in current feature context
|
|
138
|
+
self.__multitask_manager.get_feature_context().set_object("feature_report", fr)
|
|
139
|
+
|
|
140
|
+
def before_scenario(self, scenario_context, scenario):
|
|
141
|
+
# Create new scenario report in feature report
|
|
142
|
+
sr = self.current_feature_report.new_scenario_report(scenario_context, scenario)
|
|
143
|
+
|
|
144
|
+
# Process feature report
|
|
145
|
+
self.current_feature_report.before_scenario(scenario_context, scenario, scenario_report=sr)
|
|
146
|
+
|
|
147
|
+
# Process self reports
|
|
148
|
+
super().before_scenario(scenario_context, scenario, scenario_report=sr)
|
|
149
|
+
|
|
150
|
+
# Change active log file to scenario one
|
|
151
|
+
self.__enter_current_scenario_log_file()
|
|
152
|
+
|
|
153
|
+
def before_step(self, step_context, step, step_level):
|
|
154
|
+
super().before_step(step_context, step, step_level)
|
|
155
|
+
|
|
156
|
+
# Note: A step can be executed without scenario report (ex: post processes after scenario)
|
|
157
|
+
if self.current_scenario_report:
|
|
158
|
+
self.current_scenario_report.before_step(step_context, step, step_level)
|
|
159
|
+
|
|
160
|
+
def after_step(self, step_context, step, step_level):
|
|
161
|
+
super().after_step(step_context, step, step_level)
|
|
162
|
+
|
|
163
|
+
# Note: A step can be executed without scenario report (ex: post processes after scenario)
|
|
164
|
+
if self.current_scenario_report:
|
|
165
|
+
self.current_scenario_report.after_step(step_context, step, step_level)
|
|
166
|
+
|
|
167
|
+
def after_scenario(self, scenario):
|
|
168
|
+
self.current_feature_report.after_scenario(scenario, self.current_scenario_report)
|
|
169
|
+
super().after_scenario(scenario, self.current_scenario_report)
|
|
170
|
+
|
|
171
|
+
# Change active log file to root one
|
|
172
|
+
self.__leave_current_scenario_log_file()
|
|
173
|
+
|
|
174
|
+
self.current_scenario_report.release_resources()
|
|
175
|
+
|
|
176
|
+
def after_feature(self, feature):
|
|
177
|
+
super().after_feature(feature, self.current_feature_report)
|
|
178
|
+
|
|
179
|
+
self.current_feature_report.release_resources()
|
|
180
|
+
|
|
181
|
+
def after_all(self):
|
|
182
|
+
super().after_all(build_reports=True)
|
|
183
|
+
|
|
184
|
+
# Create files using execution historic as input
|
|
185
|
+
# fn_eh = self.get_path("execution_historic.json")
|
|
186
|
+
# sdm = ScenarioDurationManager()
|
|
187
|
+
# sdm.import_execution_historic(fn_eh)
|
|
188
|
+
#
|
|
189
|
+
# fn = self.get_path("scenario_durations.csv")
|
|
190
|
+
# scenario_duration_limits = sdm.compute_scenario_duration_limits()
|
|
191
|
+
# sdm.create_file_scenario_duration_limits(fn, scenario_duration_limits)
|
|
192
|
+
#
|
|
193
|
+
# fn = self.get_path("scenario_duration_tags.csv")
|
|
194
|
+
# duration_limit_tags = [(1, "fast"), (5, "rapid"), (60, "slow")]
|
|
195
|
+
# scenario_duration_tags = sdm.compute_scenario_duration_tags(duration_limit_tags, "long", missing_tag=True, new_tag=True, unchanged_tag=True, with_failed=True)
|
|
196
|
+
# sdm.create_file_scenario_duration_tags(fn, scenario_duration_tags)
|
|
197
|
+
|
|
198
|
+
# Update campaigns stored in test server
|
|
199
|
+
if self._get_test_server_client().is_available:
|
|
200
|
+
self._get_test_server_client().update_stored_campaigns()
|
|
201
|
+
|
|
202
|
+
def __enter_current_scenario_log_file(self):
|
|
203
|
+
if SessionContext.instance().log_manager.in_file and self.has_report_path:
|
|
204
|
+
log_filename = self.current_scenario_report.get_path("logs", "report.log")
|
|
205
|
+
SessionContext.instance().path_manager.makedirs(log_filename)
|
|
206
|
+
# Note: do_remove_other_file_handlers is set to True, in case leaving previous scenario log file has failed.
|
|
207
|
+
# Normally this case shouldn't appear but it was already observed. And when it appeared, execution slowdowned drastically.
|
|
208
|
+
SessionContext.instance().log_manager.enter_log_file(log_filename, do_remove_other_file_handlers=True)
|
|
209
|
+
|
|
210
|
+
def __leave_current_scenario_log_file(self):
|
|
211
|
+
if SessionContext.instance().log_manager.in_file and self.has_report_path:
|
|
212
|
+
log_filename = self.current_scenario_report.get_path("logs", "report.log")
|
|
213
|
+
SessionContext.instance().log_manager.leave_log_file(log_filename, do_remove_log_file=True)
|
|
214
|
+
|
|
215
|
+
@classmethod
|
|
216
|
+
def _get_test_server_client(cls):
|
|
217
|
+
return SessionContext.instance().test_server_client
|
|
218
|
+
|
|
219
|
+
@classmethod
|
|
220
|
+
def _get_scenario_uid(cls, scenario):
|
|
221
|
+
return f"{scenario.filename} at l.{scenario.line}"
|
|
222
|
+
|
|
223
|
+
@classmethod
|
|
224
|
+
def get_current_scenario_status_information(cls, scenario):
|
|
225
|
+
scenario_uid = cls._get_scenario_uid(scenario)
|
|
226
|
+
if scenario_uid not in cls._scenario_status_information_by_uid:
|
|
227
|
+
step_failed, step_nb = cls.get_step_failed_info(scenario)
|
|
228
|
+
|
|
229
|
+
# Define scenario status
|
|
230
|
+
if step_failed is not None and hasattr(SessionContext.instance().get_scenario_context(), "is_in_preconditions") and SessionContext.instance().get_scenario_context().is_in_preconditions:
|
|
231
|
+
status = "Failed in Preconditions"
|
|
232
|
+
elif step_failed is not None and step_failed.keyword == "Given":
|
|
233
|
+
status = "Failed in Given"
|
|
234
|
+
elif step_failed is not None or scenario.status.has_failed():
|
|
235
|
+
status = "Failed"
|
|
236
|
+
else:
|
|
237
|
+
status = scenario.status.name.capitalize()
|
|
238
|
+
|
|
239
|
+
# Define scenario category
|
|
240
|
+
category = None
|
|
241
|
+
if cls._get_test_server_client().is_available:
|
|
242
|
+
category = cls._compute_category_validation(scenario, status)
|
|
243
|
+
|
|
244
|
+
cls._scenario_status_information_by_uid[scenario_uid] = [category, status, step_failed, step_nb,
|
|
245
|
+
SessionContext.instance().get_scenario_context(),
|
|
246
|
+
SessionContext.instance().get_scenario_context().get_step(step_nb-1) if step_nb is not None else None]
|
|
247
|
+
|
|
248
|
+
return cls._scenario_status_information_by_uid[scenario_uid]
|
|
249
|
+
|
|
250
|
+
@classmethod
|
|
251
|
+
def _compute_category_validation(cls, scenario, status):
|
|
252
|
+
res = None
|
|
253
|
+
|
|
254
|
+
# Get scenario execution statuses
|
|
255
|
+
scenario_name = cls.format_scenario_short_description(scenario)
|
|
256
|
+
sce_hist = cls._get_test_server_client().get_scenario_history(scenario_name=scenario_name, size=29)
|
|
257
|
+
statuses = [s['status'] for s in reversed(sce_hist[0]['statuses'])] if sce_hist else []
|
|
258
|
+
statuses.append(status)
|
|
259
|
+
|
|
260
|
+
# Get scenario status sequences
|
|
261
|
+
passed_sequences = []
|
|
262
|
+
is_failed_relevant = None
|
|
263
|
+
for status in statuses:
|
|
264
|
+
if status == 'Passed':
|
|
265
|
+
passed = True
|
|
266
|
+
elif status.startswith("Failed"):
|
|
267
|
+
passed = False
|
|
268
|
+
if status == "Failed":
|
|
269
|
+
is_failed_relevant = True
|
|
270
|
+
elif is_failed_relevant is None:
|
|
271
|
+
is_failed_relevant = False
|
|
272
|
+
else:
|
|
273
|
+
continue
|
|
274
|
+
|
|
275
|
+
if len(passed_sequences) == 0 or passed != passed_sequences[-1][0]:
|
|
276
|
+
passed_sequences.append([passed, 1])
|
|
277
|
+
else:
|
|
278
|
+
passed_sequences[-1][1] += 1
|
|
279
|
+
|
|
280
|
+
# Compute category
|
|
281
|
+
if passed_sequences:
|
|
282
|
+
nb_exec = sum([x[1] for x in passed_sequences])
|
|
283
|
+
last_passed, last_nb_times = passed_sequences[-1]
|
|
284
|
+
if len(passed_sequences) == 1:
|
|
285
|
+
if last_passed:
|
|
286
|
+
res = f'Always Success ({last_nb_times})'
|
|
287
|
+
elif is_failed_relevant:
|
|
288
|
+
res = f'Always Failed ({last_nb_times})'
|
|
289
|
+
else:
|
|
290
|
+
res = f'Always Not Relevant ({last_nb_times})'
|
|
291
|
+
elif last_passed and len(passed_sequences) in [2, 3]:
|
|
292
|
+
res = f'Fixed ({last_nb_times} success / {nb_exec})'
|
|
293
|
+
elif len(passed_sequences) > 2:
|
|
294
|
+
nb_fail = sum([x[1] for x in passed_sequences if not x[0]])
|
|
295
|
+
if is_failed_relevant:
|
|
296
|
+
res = f'Random ({nb_fail} fails / {nb_exec})'
|
|
297
|
+
else:
|
|
298
|
+
res = f'Random but Not Relevant ({nb_fail} fails / {nb_exec})'
|
|
299
|
+
elif not last_passed:
|
|
300
|
+
if is_failed_relevant:
|
|
301
|
+
res = f'Regression ({last_nb_times} fails / {nb_exec})'
|
|
302
|
+
else:
|
|
303
|
+
res = f'Regression but Not Relevant ({last_nb_times} fails / {nb_exec})'
|
|
304
|
+
else:
|
|
305
|
+
res = f'Unknown (unmanaged sequence: {passed_sequences})'
|
|
306
|
+
|
|
307
|
+
logger.debug(f"Category of scenario '{scenario}': {res} (computed from last statuses: {statuses})")
|
|
308
|
+
return res
|
|
309
|
+
|
|
310
|
+
@classmethod
|
|
311
|
+
def get_step_failed_info(cls, scenario):
|
|
312
|
+
res_step, res_step_number = None, None
|
|
313
|
+
for ind, step in enumerate(scenario.steps):
|
|
314
|
+
if step.status.has_failed():
|
|
315
|
+
res_step, res_step_number = step, ind+1
|
|
316
|
+
break
|
|
317
|
+
return res_step, res_step_number
|
|
318
|
+
|
|
319
|
+
@classmethod
|
|
320
|
+
def get_step_description(cls, step):
|
|
321
|
+
res = "{} {}".format(step.keyword, step.name)
|
|
322
|
+
text = cls.TStepTools.get_step_multiline_text(step, eval_params=EvaluateParameters.nothing(), raise_exception_if_none=False, log_level=logging.TRACE) # @UndefinedVariable
|
|
323
|
+
if text is not None:
|
|
324
|
+
res += "\n\"\"\"\n{}\n\"\"\"".format(text)
|
|
325
|
+
if step.table:
|
|
326
|
+
res += "\n{}".format(cls.TStepTools.represent_step_table(step.table, 4))
|
|
327
|
+
return res
|
|
328
|
+
|
|
329
|
+
@classmethod
|
|
330
|
+
def get_step_error_message(cls, step):
|
|
331
|
+
if step:
|
|
332
|
+
if step.exception:
|
|
333
|
+
return str(step.exception)
|
|
334
|
+
elif step.error_message:
|
|
335
|
+
return step.error_message
|
|
336
|
+
elif step.status.is_undefined():
|
|
337
|
+
return "Undefined step"
|
|
338
|
+
elif step.status.is_pending():
|
|
339
|
+
return "Step exists but is not implemented"
|
|
340
|
+
elif step.status.has_failed():
|
|
341
|
+
return "Unknown error (unexpected error case)"
|
|
342
|
+
return None
|
|
343
|
+
|
|
344
|
+
@classmethod
|
|
345
|
+
def get_step_error(cls, step):
|
|
346
|
+
if step:
|
|
347
|
+
if step.exception:
|
|
348
|
+
formatted_exception = Tools.represent_exception(step.exception)
|
|
349
|
+
return "exception:\n{}".format(Tools.indent_string(4, formatted_exception))
|
|
350
|
+
elif step.error_message:
|
|
351
|
+
return "error_message:\n{}".format(Tools.indent_string(4, step.error_message))
|
|
352
|
+
else:
|
|
353
|
+
return cls.get_step_error_message(step)
|
|
354
|
+
return None
|
|
355
|
+
|
|
356
|
+
@classmethod
|
|
357
|
+
def format_context_period(cls, context, format_precision_nsec=None, dt_ref=None, use_compact_format=default_value):
|
|
358
|
+
dt_start, dt_end = context.start_datetime, context.end_datetime
|
|
359
|
+
|
|
360
|
+
# Prepare format of start datetime
|
|
361
|
+
if format_precision_nsec is not None:
|
|
362
|
+
dt_start = DateTime.truncate_datetime(dt_start, precision_nanoseconds=format_precision_nsec)
|
|
363
|
+
dt_format_start = cls._get_datetime_format_compared_to_reference(dt_start, dt_ref, use_compact_format=use_compact_format)
|
|
364
|
+
|
|
365
|
+
# Prepare format of end datetime
|
|
366
|
+
if dt_end is not None:
|
|
367
|
+
if format_precision_nsec is not None:
|
|
368
|
+
dt_end = DateTime.truncate_datetime(dt_end, precision_nanoseconds=format_precision_nsec)
|
|
369
|
+
dt_format_end = cls._get_datetime_format_compared_to_reference(dt_end, dt_start, use_compact_format=use_compact_format)
|
|
370
|
+
if len(dt_format_end) > len(dt_format_start):
|
|
371
|
+
dt_format_start = dt_format_end
|
|
372
|
+
else:
|
|
373
|
+
dt_format_end = None
|
|
374
|
+
|
|
375
|
+
# Format datetimes
|
|
376
|
+
start_txt = DateTime.datetime_2_str(dt_start, dt_format=dt_format_start)
|
|
377
|
+
end_txt = DateTime.datetime_2_str(dt_end, dt_format=dt_format_end) if dt_end is not None else ''
|
|
378
|
+
|
|
379
|
+
# Truncate formatted datetimes if needed
|
|
380
|
+
if format_precision_nsec is not None:
|
|
381
|
+
trunc_len = len(f'{int(format_precision_nsec)}') - 4
|
|
382
|
+
if trunc_len > 0:
|
|
383
|
+
start_txt = start_txt[:-trunc_len-1]+'Z' if start_txt.endswith('Z') else start_txt[:-trunc_len]
|
|
384
|
+
if len(end_txt) > 0:
|
|
385
|
+
end_txt = end_txt[:-trunc_len-1]+'Z' if end_txt.endswith('Z') else end_txt[:-trunc_len]
|
|
386
|
+
|
|
387
|
+
return f"[{start_txt} - {end_txt}]"
|
|
388
|
+
|
|
389
|
+
@classmethod
|
|
390
|
+
def _get_datetime_format_compared_to_reference(cls, dt, dt_ref=None, use_compact_format=default_value):
|
|
391
|
+
if use_compact_format is default_value:
|
|
392
|
+
use_compact_format = Config.report_compact_datetime_period # @UndefinedVariable
|
|
393
|
+
|
|
394
|
+
if dt_ref is None:
|
|
395
|
+
return FORMAT_DATETIME_ISO
|
|
396
|
+
|
|
397
|
+
if not use_compact_format or dt.date() != dt_ref.date():
|
|
398
|
+
return FORMAT_DATETIME_ISO
|
|
399
|
+
elif dt.hour != dt_ref.hour:
|
|
400
|
+
return FORMAT_TIME_ISO
|
|
401
|
+
elif dt.minute != dt_ref.minute:
|
|
402
|
+
return '%M:%S.%f'
|
|
403
|
+
elif dt.second != dt_ref.second:
|
|
404
|
+
return '%S.%f'
|
|
405
|
+
else:
|
|
406
|
+
return '.%f'
|
|
407
|
+
|
|
408
|
+
@classmethod
|
|
409
|
+
def format_scenario_short_description(cls, scenario):
|
|
410
|
+
return f"{scenario.filename} at l.{scenario.line}"
|
|
411
|
+
|
|
412
|
+
@classmethod
|
|
413
|
+
def format_step_short_description(cls, step, step_number, step_context=None, dt_ref=None, has_failed=undefined_argument):
|
|
414
|
+
if step:
|
|
415
|
+
if step_context and step_context.start_datetime is not None:
|
|
416
|
+
return f"step {step_number} (l.{step.line} on {cls.format_context_period(step_context, dt_ref=dt_ref)})"
|
|
417
|
+
else:
|
|
418
|
+
return f"step {step_number} (l.{step.line})"
|
|
419
|
+
elif has_failed is not undefined_argument and has_failed:
|
|
420
|
+
return "step ? (missing step implementation ?)"
|
|
421
|
+
else:
|
|
422
|
+
return None
|
|
423
|
+
|
|
424
|
+
|