holado 0.2.1__py3-none-any.whl → 0.2.3__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of holado might be problematic. Click here for more details.
- holado/__init__.py +8 -4
- {holado-0.2.1.dist-info → holado-0.2.3.dist-info}/METADATA +13 -9
- holado-0.2.3.dist-info/RECORD +535 -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 +203 -0
- holado_ais/ais/ais_payload.py +35 -0
- holado_ais/ais/enums.py +37 -0
- holado_ais/ais/patch_pyais.py +1303 -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 +182 -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 +131 -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 +36 -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 +695 -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 +133 -0
- holado_core/common/resource/resource_manager.py +143 -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 +194 -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 +366 -0
- holado_core/common/tables/table_row.py +169 -0
- holado_core/common/tables/table_with_header.py +236 -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 +107 -0
- holado_core/common/tools/path_manager.py +185 -0
- holado_core/common/tools/string_tools.py +135 -0
- holado_core/common/tools/tools.py +172 -0
- holado_core/common/transport/__init__.py +0 -0
- holado_core/common/transport/crc.py +40 -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 +136 -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 +537 -0
- holado_core/tools/__init__.py +0 -0
- holado_core/tools/abstracts/__init__.py +0 -0
- holado_core/tools/abstracts/blocking_command_service.py +56 -0
- holado_core/tools/abstracts/service.py +48 -0
- holado_data/__init__.py +31 -0
- holado_data/data/generator/base.py +93 -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 +60 -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_client.py +206 -0
- holado_db/tools/db/clients/postgresql/postgresql_client.py +65 -0
- holado_db/tools/db/clients/sqlite/sqlite_client.py +56 -0
- holado_db/tools/db/db_manager.py +109 -0
- holado_db/tools/db/query/base/query_builder.py +87 -0
- holado_db/tools/db/query/pypika/pypika_query_builder.py +193 -0
- holado_db/tools/db/query/query_manager.py +77 -0
- holado_docker/__init__.py +25 -0
- holado_docker/sdk/docker/docker_client.py +268 -0
- holado_docker/sdk/docker/docker_service.py +71 -0
- holado_docker/tests/behave/steps/__init__.py +16 -0
- holado_docker/tests/behave/steps/tools/docker_steps.py +33 -0
- holado_docker/tools/docker_controler/__init__.py +26 -0
- holado_docker/tools/docker_controler/docker_controler_client.py +36 -0
- holado_docker/tools/docker_controler/docker_controler_server.py +31 -0
- holado_docker/tools/docker_controler/proto/compile_proto.py +60 -0
- holado_docker/tools/docker_controler/proto/definitions/docker_controler.proto +63 -0
- holado_docker/tools/docker_controler/proto/generated/docker_controler_pb2.py +52 -0
- holado_docker/tools/docker_controler/proto/generated/docker_controler_pb2_grpc.py +233 -0
- holado_grpc/__init__.py +32 -0
- holado_grpc/api/rpc/TODO.txt +4 -0
- holado_grpc/api/rpc/grpc_client.py +181 -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 +42 -0
- holado_helper/docker/run_holado_test_nonreg_in_docker.sh +120 -0
- holado_helper/docker/run_terminal_in_docker-with_docker_control.sh +103 -0
- holado_helper/docker/run_terminal_in_docker.sh +101 -0
- holado_helper/holado_module_template/__init__.py +31 -0
- holado_helper/holado_module_template/test/behave/steps/__init__.py +16 -0
- holado_helper/holado_module_template/test/behave/steps/private/__init__.py +16 -0
- holado_helper/script/action.py +109 -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 +115 -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/ipc/json.py +125 -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 +120 -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 +59 -0
- holado_keycloak/tools/keycloak/__init__.py +0 -0
- holado_keycloak/tools/keycloak/keycloak_client.py +61 -0
- holado_logging/__init__.py +36 -0
- holado_logging/common/logging/holado_logger.py +75 -0
- holado_logging/common/logging/log_config.py +128 -0
- holado_logging/common/logging/log_manager.py +292 -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 +135 -0
- holado_multitask/multiprocessing/process.py +196 -0
- holado_multitask/multiprocessing/processesmanager.py +133 -0
- holado_multitask/multitasking/multitask_manager.py +439 -0
- holado_multitask/multithreading/__init__.py +0 -0
- holado_multitask/multithreading/context/thread_context.py +84 -0
- holado_multitask/multithreading/functionthreaded.py +129 -0
- holado_multitask/multithreading/loopfunctionthreaded.py +45 -0
- holado_multitask/multithreading/loopthread.py +100 -0
- holado_multitask/multithreading/periodicfunctionthreaded.py +136 -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 +177 -0
- holado_multitask/multithreading/threadsmanager.py +162 -0
- holado_multitask/multithreading/timer.py +48 -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 +965 -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 +35 -0
- holado_python/common/enums.py +34 -0
- holado_python/common/iterables.py +30 -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 +279 -0
- holado_python/standard_library/csv.py +207 -0
- holado_python/standard_library/hashlib.py +82 -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 +136 -0
- holado_python/standard_library/socket/echo_server.py +28 -0
- holado_python/standard_library/socket/message_socket.py +91 -0
- holado_python/standard_library/socket/non_blocking_socket.py +151 -0
- holado_python/standard_library/socket/socket.py +148 -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 +81 -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 +258 -0
- holado_python/tests/behave/steps/standard_library/ssl_steps.py +67 -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 +537 -0
- holado_rabbitmq/tests/behave/steps/tools/rabbitmq_server_steps.py +64 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_blocking_client.py +311 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_client.py +675 -0
- holado_rabbitmq/tools/rabbitmq/rabbitmq_manager.py +173 -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 +27 -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_failed_report_builder.py +146 -0
- holado_report/report/builders/json_execution_historic_report_builder.py +123 -0
- holado_report/report/builders/report_builder.py +64 -0
- holado_report/report/builders/short_scenario_failed_report_builder.py +76 -0
- holado_report/report/builders/summary_report_builder.py +89 -0
- holado_report/report/builders/summary_scenario_failed_report_builder.py +56 -0
- holado_report/report/builders/summary_scenario_report_builder.py +74 -0
- holado_report/report/execution_historic.py +141 -0
- holado_report/report/report_manager.py +256 -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 +24 -0
- holado_rest/api/rest/TODO.txt +2 -0
- holado_rest/api/rest/rest_client.py +113 -0
- holado_rest/api/rest/rest_manager.py +62 -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 +141 -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 +70 -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 +53 -0
- holado_scripting/common/tools/dynamic_text_manager.py +73 -0
- holado_scripting/common/tools/evaluate_parameters.py +210 -0
- holado_scripting/common/tools/expression_evaluator.py +387 -0
- holado_scripting/common/tools/variable_manager.py +321 -0
- holado_scripting/tests/behave/steps/__init__.py +22 -0
- holado_scripting/tests/behave/steps/common/tools/variable_convert_steps.py +158 -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_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/text_interpreter.py +216 -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 +32 -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 +216 -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 +76 -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 +215 -0
- holado_system/tests/behave/steps/system/system_steps.py +84 -0
- holado_test/__init__.py +27 -0
- holado_test/behave/__init__.py +0 -0
- holado_test/behave/behave.py +397 -0
- holado_test/behave/behave_environment.py +143 -0
- holado_test/behave/behave_function.py +33 -0
- holado_test/behave/behave_manager.py +555 -0
- holado_test/behave/independant_runner.py +68 -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 +79 -0
- holado_test/common/context/scenario_context.py +217 -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 +523 -0
- holado_test/scenario/tester_tools.py +52 -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 +87 -0
- holado_test/tests/behave/steps/scenario/tester_steps.py +65 -0
- holado_value/__init__.py +24 -0
- holado_value/common/tables/comparators/table_2_value_table_cell_comparator.py +195 -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 +217 -0
- holado_value/common/tables/value_table.py +29 -0
- holado_value/common/tables/value_table_cell.py +67 -0
- holado_value/common/tables/value_table_manager.py +58 -0
- holado_value/common/tables/value_table_row.py +44 -0
- holado_value/common/tables/value_table_with_header.py +28 -0
- holado_value/common/tools/unique_value_manager.py +108 -0
- holado_value/common/tools/value.py +164 -0
- holado_value/common/tools/value_types.py +35 -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_yaml/__init__.py +31 -0
- holado_yaml/tests/behave/steps/__init__.py +16 -0
- holado_yaml/tests/behave/steps/yaml_steps.py +64 -0
- holado_yaml/yaml/yaml_manager.py +86 -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 +42 -0
- test_holado/features/NonReg/api/REST.feature +21 -0
- test_holado/features/NonReg/api/gRPC.feature +122 -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 +239 -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_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.feature +101 -0
- test_holado/features/NonReg/holado_python/standard_library/socket_with_ssl.feature +180 -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 +218 -0
- test_holado/features/NonReg/ipc/bit_series.error.feature +33 -0
- test_holado/features/NonReg/ipc/bit_series.feature +131 -0
- test_holado/features/NonReg/ipc/json.feature +20 -0
- test_holado/features/NonReg/scenario/scenario.feature +139 -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/__init__.py +0 -0
- test_holado/logging.conf +41 -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/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 +27 -0
- test_holado/tools/django/api_grpc/manual_test_commands.txt +25 -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
- holado-0.2.1.dist-info/RECORD +0 -17
- {holado-0.2.1.dist-info → holado-0.2.3.dist-info}/WHEEL +0 -0
- {holado-0.2.1.dist-info → holado-0.2.3.dist-info}/licenses/LICENSE +0 -0
|
@@ -0,0 +1,358 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
#################################################
|
|
4
|
+
# HolAdo (Holistic Automation do)
|
|
5
|
+
#
|
|
6
|
+
# (C) Copyright 2021-2025 by Eric Klumpp
|
|
7
|
+
#
|
|
8
|
+
# Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
9
|
+
#
|
|
10
|
+
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
11
|
+
|
|
12
|
+
# The Software is provided “as is”, without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the Software.
|
|
13
|
+
#################################################
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
from holado_test.behave.behave import *
|
|
17
|
+
from holado.common.context.session_context import SessionContext
|
|
18
|
+
from holado_test.scenario.step_tools import StepTools
|
|
19
|
+
import logging
|
|
20
|
+
import queue
|
|
21
|
+
from typing import Iterable
|
|
22
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
23
|
+
from holado_core.common.tools.tools import Tools
|
|
24
|
+
from holado_system.system.global_system import GlobalSystem
|
|
25
|
+
from holado_system.system.filesystem.file import File
|
|
26
|
+
from holado_python.standard_library.queue import IterableQueue,\
|
|
27
|
+
IterableLifoQueue
|
|
28
|
+
from holado_test.behave.scenario.behave_step_tools import BehaveStepTools
|
|
29
|
+
from holado_scripting.common.tools.evaluate_parameters import EvaluateParameters
|
|
30
|
+
from holado_python.standard_library.typing import Typing
|
|
31
|
+
|
|
32
|
+
logger = logging.getLogger(__name__)
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
def __get_scenario_context():
|
|
36
|
+
return SessionContext.instance().get_scenario_context()
|
|
37
|
+
|
|
38
|
+
def __get_variable_manager():
|
|
39
|
+
return __get_scenario_context().get_variable_manager()
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
@Given(r"(?P<var_name>{Variable}) = new FIFO queue(?: of size (?P<size>{Int}))?(?: \((?:block on get: (?P<block_on_get>{Boolean}))?(?: ; )?(?:block on get timeout: (?P<block_on_get_timeout>{Float} s))?(?: ; )?(?:block on put: (?P<block_on_put>{Boolean}))?(?: ; )?(?:block on put timeout: (?P<block_on_put_timeout>{Float}) s)?\))?")
|
|
44
|
+
def step_impl(context, var_name, size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout):
|
|
45
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
46
|
+
size = StepTools.evaluate_scenario_parameter(size)
|
|
47
|
+
block_on_get = StepTools.evaluate_scenario_parameter(block_on_get)
|
|
48
|
+
block_on_get_timeout = StepTools.evaluate_scenario_parameter(block_on_get_timeout)
|
|
49
|
+
block_on_put = StepTools.evaluate_scenario_parameter(block_on_put)
|
|
50
|
+
block_on_put_timeout = StepTools.evaluate_scenario_parameter(block_on_put_timeout)
|
|
51
|
+
|
|
52
|
+
res = IterableQueue(size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout)
|
|
53
|
+
|
|
54
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
55
|
+
|
|
56
|
+
@Given(r"(?P<var_name>{Variable}) = new LIFO queue(?: of size (?P<size>{Int}))?(?: \((?:block on get: (?P<block_on_get>{Boolean}))?(?: ; )?(?:block on get timeout: (?P<block_on_get_timeout>{Float} s))?(?: ; )?(?:block on put: (?P<block_on_put>{Boolean}))?(?: ; )?(?:block on put timeout: (?P<block_on_put_timeout>{Float}) s)?\))?")
|
|
57
|
+
def step_impl(context, var_name, size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout):
|
|
58
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
59
|
+
size = StepTools.evaluate_scenario_parameter(size)
|
|
60
|
+
block_on_get = StepTools.evaluate_scenario_parameter(block_on_get)
|
|
61
|
+
block_on_get_timeout = StepTools.evaluate_scenario_parameter(block_on_get_timeout)
|
|
62
|
+
block_on_put = StepTools.evaluate_scenario_parameter(block_on_put)
|
|
63
|
+
block_on_put_timeout = StepTools.evaluate_scenario_parameter(block_on_put_timeout)
|
|
64
|
+
|
|
65
|
+
res = IterableLifoQueue(size, block_on_get, block_on_get_timeout, block_on_put, block_on_put_timeout)
|
|
66
|
+
|
|
67
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
68
|
+
|
|
69
|
+
@Step(r"put (?!all )(?P<value>{Any}) \(Queue: (?P<var_queue>{Variable})\)")
|
|
70
|
+
def step_impl(context, value, var_queue):
|
|
71
|
+
value = StepTools.evaluate_scenario_parameter(value)
|
|
72
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
73
|
+
|
|
74
|
+
q.put(value)
|
|
75
|
+
|
|
76
|
+
@Step(r"(?P<var_name>{Variable}) = get \(Queue: (?P<var_queue>{Variable})\)")
|
|
77
|
+
def step_impl(context, var_name, var_queue):
|
|
78
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
79
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
80
|
+
|
|
81
|
+
res = q.get()
|
|
82
|
+
|
|
83
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
84
|
+
|
|
85
|
+
@Step(r"task is done \(Queue: (?P<var_queue>{Variable})\)")
|
|
86
|
+
def step_impl(context, var_queue):
|
|
87
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
88
|
+
|
|
89
|
+
q.task_done()
|
|
90
|
+
|
|
91
|
+
@Step(r"join \(Queue: (?P<var_queue>{Variable})\)")
|
|
92
|
+
def step_impl(context, var_queue):
|
|
93
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
94
|
+
|
|
95
|
+
q.join()
|
|
96
|
+
|
|
97
|
+
@Step(r"(?P<var_name>{Variable}) = size \(Queue: (?P<var_queue>{Variable})\)")
|
|
98
|
+
def step_impl(context, var_name, var_queue):
|
|
99
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
100
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
101
|
+
|
|
102
|
+
res = q.qsize()
|
|
103
|
+
|
|
104
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
105
|
+
|
|
106
|
+
@Step(r"close queue \(Queue: (?P<var_queue>{Variable})\)")
|
|
107
|
+
def step_impl(context, var_queue):
|
|
108
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
109
|
+
q.close()
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
@Step(r"put all of (?P<iterable_str>{Variable}) \(Queue: (?P<var_queue>{Variable})(?: ; nb of repeat: (?P<repeat_nb>{Int}))?(?: ; rate log period: (?P<rate_period_s>{Int}) s)?\)")
|
|
114
|
+
def step_impl(context, iterable_str, var_queue, repeat_nb, rate_period_s):
|
|
115
|
+
iterable = StepTools.evaluate_scenario_parameter(iterable_str)
|
|
116
|
+
it_name = StepTools.evaluate_variable_name(iterable_str)
|
|
117
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
118
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
119
|
+
repeat_nb = StepTools.evaluate_scenario_parameter(repeat_nb)
|
|
120
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
121
|
+
|
|
122
|
+
if not isinstance(iterable, Iterable):
|
|
123
|
+
raise FunctionalException(f"Parameter [{iterable_str}] (type: {Typing.get_object_class_fullname(iterable)}) is not iterable")
|
|
124
|
+
|
|
125
|
+
if repeat_nb is None:
|
|
126
|
+
repeat_nb = 1
|
|
127
|
+
nb_elements = len(iterable)
|
|
128
|
+
|
|
129
|
+
beg = Tools.timer_s()
|
|
130
|
+
s_end, t_end = 0, beg
|
|
131
|
+
for num in range(1, repeat_nb+1):
|
|
132
|
+
s_beg, t_beg = is_beg, it_beg = s_end, t_end
|
|
133
|
+
ind_beg = 0
|
|
134
|
+
|
|
135
|
+
for ind, value in enumerate(iterable):
|
|
136
|
+
q.put(value)
|
|
137
|
+
|
|
138
|
+
if rate_period_s and ind > 0 and ind % 10 == 0:
|
|
139
|
+
it_end = Tools.timer_s()
|
|
140
|
+
if it_end > it_beg + rate_period_s:
|
|
141
|
+
is_end = q.qsize()
|
|
142
|
+
rate = (is_beg + ind - ind_beg - is_end) / (it_end - it_beg)
|
|
143
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Current rate: {round(rate,2)} item/s ; Queue size: {is_end}")
|
|
144
|
+
ind_beg, is_beg, it_beg = ind, is_end, it_end
|
|
145
|
+
|
|
146
|
+
# Yield processor in case of multithreading
|
|
147
|
+
if ind % 10 == 0:
|
|
148
|
+
GlobalSystem.yield_processor()
|
|
149
|
+
|
|
150
|
+
if rate_period_s:
|
|
151
|
+
s_end, t_end = q.qsize(), Tools.timer_s()
|
|
152
|
+
rate = (s_beg + nb_elements - s_end) / (t_end - t_beg)
|
|
153
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Mean rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
154
|
+
|
|
155
|
+
if rate_period_s:
|
|
156
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
157
|
+
rate = (nb_elements * repeat_nb - s_end) / (end - beg)
|
|
158
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s")
|
|
159
|
+
|
|
160
|
+
@Step(r"put all of (?P<iterable_str>{Variable}) by batch of (?P<batch_size>{Int}) items \(Queue: (?P<var_queue>{Variable})(?: ; nb of repeat: (?P<repeat_nb>{Int}))?(?: ; rate log period: (?P<rate_period_s>{Int}) s)?\)")
|
|
161
|
+
def step_impl(context, iterable_str, batch_size, var_queue, repeat_nb, rate_period_s):
|
|
162
|
+
iterable = StepTools.evaluate_scenario_parameter(iterable_str)
|
|
163
|
+
it_name = StepTools.evaluate_variable_name(iterable_str)
|
|
164
|
+
batch_size = StepTools.evaluate_scenario_parameter(batch_size)
|
|
165
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
166
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
167
|
+
repeat_nb = StepTools.evaluate_scenario_parameter(repeat_nb)
|
|
168
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
169
|
+
|
|
170
|
+
if not isinstance(iterable, Iterable):
|
|
171
|
+
raise FunctionalException(f"Parameter [{iterable_str}] (type: {Typing.get_object_class_fullname(iterable)}) is not iterable")
|
|
172
|
+
|
|
173
|
+
if repeat_nb is None:
|
|
174
|
+
repeat_nb = 1
|
|
175
|
+
nb_elements = len(iterable)
|
|
176
|
+
|
|
177
|
+
beg = Tools.timer_s()
|
|
178
|
+
s_end, t_end = 0, beg
|
|
179
|
+
for num in range(1, repeat_nb+1):
|
|
180
|
+
s_beg, t_beg = is_beg, it_beg = s_end, t_end
|
|
181
|
+
batch_counter_beg = batch_counter = 0
|
|
182
|
+
batch = []
|
|
183
|
+
|
|
184
|
+
for value in iterable:
|
|
185
|
+
batch.append(value)
|
|
186
|
+
if len(batch) >= batch_size:
|
|
187
|
+
batch_counter += 1
|
|
188
|
+
q.put(batch)
|
|
189
|
+
batch = []
|
|
190
|
+
|
|
191
|
+
if rate_period_s and batch_counter > 0 and batch_counter % 10 == 0:
|
|
192
|
+
it_end = Tools.timer_s()
|
|
193
|
+
if it_end > it_beg + rate_period_s:
|
|
194
|
+
is_end = q.qsize()
|
|
195
|
+
rate = (is_beg + batch_counter - batch_counter_beg - is_end) / (it_end - it_beg)
|
|
196
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Current rate: {round(rate,2)} item/s ; Queue size: {is_end}")
|
|
197
|
+
batch_counter_beg, is_beg, it_beg = batch_counter, is_end, it_end
|
|
198
|
+
|
|
199
|
+
# Yield processor in case of multithreading
|
|
200
|
+
if batch_counter % 10 == 0:
|
|
201
|
+
GlobalSystem.yield_processor()
|
|
202
|
+
|
|
203
|
+
if rate_period_s:
|
|
204
|
+
s_end, t_end = q.qsize(), Tools.timer_s()
|
|
205
|
+
rate = (s_beg + nb_elements - s_end) / (t_end - t_beg)
|
|
206
|
+
logger.print(f"[{it_name} -> Queue {q_name} ; Iteration {num}] Mean rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
207
|
+
|
|
208
|
+
if rate_period_s:
|
|
209
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
210
|
+
rate = (nb_elements * repeat_nb - s_end) / (end - beg)
|
|
211
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s")
|
|
212
|
+
|
|
213
|
+
@Step(r"put all lines of file (?P<file_str>{Variable})(?: \(offset: (?P<offset>{Int}) ; size: (?P<size>{Int})\))? \(Queue: (?P<var_queue>{Variable})(?: ; rate log period: (?P<rate_period_s>{Int}) s)?\)")
|
|
214
|
+
def step_impl(context, file_str, offset, size, var_queue, rate_period_s):
|
|
215
|
+
file = StepTools.evaluate_scenario_parameter(file_str)
|
|
216
|
+
file_name = StepTools.evaluate_variable_name(file_str)
|
|
217
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
218
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
219
|
+
offset = StepTools.evaluate_scenario_parameter(offset)
|
|
220
|
+
size = StepTools.evaluate_scenario_parameter(size)
|
|
221
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
222
|
+
|
|
223
|
+
if not isinstance(file, File):
|
|
224
|
+
raise FunctionalException(f"Parameter [{file_str}] is not a file object")
|
|
225
|
+
|
|
226
|
+
beg = Tools.timer_s()
|
|
227
|
+
s_beg, t_beg = s_end, t_end = 0, beg
|
|
228
|
+
ind_beg = 0
|
|
229
|
+
|
|
230
|
+
for ind, line in enumerate(file.internal_file):
|
|
231
|
+
if ind < offset:
|
|
232
|
+
continue
|
|
233
|
+
elif size > 0 and ind >= offset + size:
|
|
234
|
+
break
|
|
235
|
+
|
|
236
|
+
q.put(line.strip('\n'))
|
|
237
|
+
|
|
238
|
+
if rate_period_s and ind > 0 and ind % 10 == 0:
|
|
239
|
+
t_end = Tools.timer_s()
|
|
240
|
+
if t_end > t_beg + rate_period_s:
|
|
241
|
+
s_end = q.qsize()
|
|
242
|
+
rate = (s_beg + ind - ind_beg - s_end) / (t_end - t_beg)
|
|
243
|
+
logger.print(f"[File {file_name} -> Queue {q_name}] Current rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
244
|
+
ind_beg, s_beg, t_beg = ind, s_end, t_end
|
|
245
|
+
|
|
246
|
+
# Yield processor in case of multithreading
|
|
247
|
+
if ind > 0 and ind % 10 == 0:
|
|
248
|
+
GlobalSystem.yield_processor()
|
|
249
|
+
|
|
250
|
+
if rate_period_s:
|
|
251
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
252
|
+
rate = (ind + 1 - s_end) / (end - beg)
|
|
253
|
+
logger.print(f"[File {file_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s")
|
|
254
|
+
|
|
255
|
+
|
|
256
|
+
|
|
257
|
+
@Step(r"for (?P<item_var_name>{VariableName}) in (?P<iterable_str>{Variable}), call steps, and put (?P<result_var_name>{VariableName}) \(Queue: (?P<var_queue>{Variable})(?: ; rate log period: (?P<rate_period_s>{Int}) s)?(?: ; format with: (?P<format_with>{Variable}(?:, {Variable})*))?\)")
|
|
258
|
+
def step_impl(context, item_var_name, iterable_str, result_var_name, var_queue, rate_period_s, format_with):
|
|
259
|
+
item_var_name = StepTools.evaluate_variable_name(item_var_name)
|
|
260
|
+
iterable = StepTools.evaluate_variable_value(iterable_str)
|
|
261
|
+
it_name = StepTools.evaluate_variable_name(iterable_str)
|
|
262
|
+
result_var_name = StepTools.evaluate_variable_name(result_var_name)
|
|
263
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
264
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
265
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
266
|
+
format_with = StepTools.evaluate_variable_name(format_with)
|
|
267
|
+
steps = BehaveStepTools.get_step_multiline_text(context, eval_params=EvaluateParameters.nothing())
|
|
268
|
+
|
|
269
|
+
if format_with is not None:
|
|
270
|
+
steps = StepTools.format_steps_with(steps, format_with.split(', '))
|
|
271
|
+
|
|
272
|
+
beg = Tools.timer_s()
|
|
273
|
+
t_beg = t_end = beg
|
|
274
|
+
ind_beg = 0
|
|
275
|
+
|
|
276
|
+
for ind, item in enumerate(iterable):
|
|
277
|
+
__get_variable_manager().register_variable(item_var_name, item)
|
|
278
|
+
execute_steps(steps)
|
|
279
|
+
result = __get_variable_manager().get_variable_value(result_var_name)
|
|
280
|
+
|
|
281
|
+
q.put(result)
|
|
282
|
+
|
|
283
|
+
if rate_period_s and ind > 0 and ind % 10 == 0:
|
|
284
|
+
t_end = Tools.timer_s()
|
|
285
|
+
if t_end > t_beg + rate_period_s:
|
|
286
|
+
s_end = q.qsize()
|
|
287
|
+
rate = (ind - ind_beg) / (t_end - t_beg)
|
|
288
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Current rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
289
|
+
ind_beg, t_beg = ind, t_end
|
|
290
|
+
|
|
291
|
+
# Yield processor in case of multithreading
|
|
292
|
+
if ind > 0 and ind % 10 == 0:
|
|
293
|
+
GlobalSystem.yield_processor()
|
|
294
|
+
|
|
295
|
+
if rate_period_s:
|
|
296
|
+
end, s_end = Tools.timer_s(), q.qsize()
|
|
297
|
+
rate = (ind + 1) / (end - beg)
|
|
298
|
+
logger.print(f"[{it_name} -> Queue {q_name}] Mean rate: {round(rate,2)} item/s ; Queue size: {s_end}")
|
|
299
|
+
|
|
300
|
+
|
|
301
|
+
@Step(r"for (?P<item_var_name>{VariableName}) in queue, call steps \(Queue: (?P<var_queue>{Variable})(?: ; rate log period: (?P<rate_period_s>{Int}) s)?(?: ; format with: (?P<format_with>{Variable}(?:, {Variable})*))?\)")
|
|
302
|
+
def step_impl(context, item_var_name, var_queue, rate_period_s, format_with):
|
|
303
|
+
item_var_name = StepTools.evaluate_variable_name(item_var_name)
|
|
304
|
+
q = StepTools.evaluate_variable_value(var_queue)
|
|
305
|
+
q_name = StepTools.evaluate_variable_name(var_queue)
|
|
306
|
+
rate_period_s = StepTools.evaluate_scenario_parameter(rate_period_s)
|
|
307
|
+
format_with = StepTools.evaluate_variable_name(format_with)
|
|
308
|
+
steps = BehaveStepTools.get_step_multiline_text(context, eval_params=EvaluateParameters.nothing())
|
|
309
|
+
|
|
310
|
+
if format_with is not None:
|
|
311
|
+
steps = StepTools.format_steps_with(steps, format_with.split(', '))
|
|
312
|
+
|
|
313
|
+
counter = 0
|
|
314
|
+
beg = Tools.timer_s()
|
|
315
|
+
c_beg, t_beg = counter, beg
|
|
316
|
+
log_counter = 0
|
|
317
|
+
|
|
318
|
+
try:
|
|
319
|
+
while True:
|
|
320
|
+
# Get next item
|
|
321
|
+
item = q.get()
|
|
322
|
+
if q.is_sentinel(item):
|
|
323
|
+
break
|
|
324
|
+
counter += 1
|
|
325
|
+
|
|
326
|
+
__get_variable_manager().register_variable(item_var_name, item)
|
|
327
|
+
try:
|
|
328
|
+
execute_steps(steps)
|
|
329
|
+
except Exception as exc:
|
|
330
|
+
logger.warning(f"[Queue {q_name}] Failed to execute steps with {counter}'th item: [{Typing.get_object_class_fullname(exc)}] {str(exc)}")
|
|
331
|
+
finally:
|
|
332
|
+
q.task_done()
|
|
333
|
+
|
|
334
|
+
# Log rate if needed
|
|
335
|
+
if rate_period_s and counter % 10 == 0:
|
|
336
|
+
t_end = Tools.timer_s()
|
|
337
|
+
if t_end > t_beg + rate_period_s:
|
|
338
|
+
c_end, s_end = counter, q.qsize()
|
|
339
|
+
rate = (c_end - c_beg) / (t_end - t_beg)
|
|
340
|
+
log_counter += 1
|
|
341
|
+
logger.print(f"[Queue {q_name}] Rate: {int(rate)} msg/s ; Nb items: {counter} ; Queue size: {s_end}")
|
|
342
|
+
c_beg, t_beg = c_end, t_end
|
|
343
|
+
|
|
344
|
+
# Yield processor in case of multithreading
|
|
345
|
+
if counter % 10 == 0:
|
|
346
|
+
GlobalSystem.yield_processor()
|
|
347
|
+
except queue.Empty:
|
|
348
|
+
# Without block, or with timeout, this exception occurs when queue is empty
|
|
349
|
+
pass
|
|
350
|
+
|
|
351
|
+
if rate_period_s:
|
|
352
|
+
end = Tools.timer_s()
|
|
353
|
+
rate = counter / (end - beg)
|
|
354
|
+
logger.print(f"[Queue {q_name}] Mean rate: {int(rate)} msg/s ; Nb messages: {counter}")
|
|
355
|
+
|
|
356
|
+
|
|
357
|
+
|
|
358
|
+
|
|
@@ -0,0 +1,258 @@
|
|
|
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 *
|
|
19
|
+
import logging
|
|
20
|
+
from holado_test.behave.scenario.behave_step_tools import BehaveStepTools
|
|
21
|
+
from holado_value.common.tables.converters.value_table_converter import ValueTableConverter
|
|
22
|
+
from holado_python.standard_library.socket.blocking_socket import TCPBlockingSocketClient
|
|
23
|
+
from holado_python.standard_library.socket.echo_server import EchoTCPBlockingSocketServer
|
|
24
|
+
from holado_python.standard_library.socket.message_socket import MessageTCPSocketClient
|
|
25
|
+
from holado_core.common.handlers.wait import WaitEndChange
|
|
26
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
27
|
+
from holado_python.standard_library.socket.non_blocking_socket import TCPNonBlockingSocketClient
|
|
28
|
+
|
|
29
|
+
logger = logging.getLogger(__name__)
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
def __get_scenario_context():
|
|
33
|
+
return SessionContext.instance().get_scenario_context()
|
|
34
|
+
|
|
35
|
+
def __get_text_interpreter():
|
|
36
|
+
return __get_scenario_context().get_text_interpreter()
|
|
37
|
+
|
|
38
|
+
def __get_variable_manager():
|
|
39
|
+
return __get_scenario_context().get_variable_manager()
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
################################################################
|
|
44
|
+
## Clients
|
|
45
|
+
################################################################
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
@Given(r"(?P<var_name>{Variable}) = new TCP socket client")
|
|
49
|
+
def step_impl(context, var_name):
|
|
50
|
+
"""Return a new TCP socket client.
|
|
51
|
+
Note: Only IPv4 is managed for the moment
|
|
52
|
+
"""
|
|
53
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
54
|
+
table = BehaveStepTools.convert_step_table_2_value_table_with_header(context.table)
|
|
55
|
+
kwargs = ValueTableConverter.convert_name_value_table_2_dict(table)
|
|
56
|
+
|
|
57
|
+
blocking = kwargs.pop('blocking') if 'blocking' in kwargs else True
|
|
58
|
+
if blocking:
|
|
59
|
+
res = TCPBlockingSocketClient(create_ipv4_socket_kwargs=kwargs)
|
|
60
|
+
else:
|
|
61
|
+
res = TCPNonBlockingSocketClient(create_ipv4_socket_kwargs=kwargs)
|
|
62
|
+
|
|
63
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
@Given(r"(?P<var_name>{Variable}) = new message TCP socket client")
|
|
67
|
+
def step_impl(context, var_name):
|
|
68
|
+
"""Return a new message TCP socket client.
|
|
69
|
+
Parameter 'separator' specifies the separator at end of each message (default: b'\n')
|
|
70
|
+
Note: Only IPv4 is managed for the moment
|
|
71
|
+
"""
|
|
72
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
73
|
+
table = BehaveStepTools.convert_step_table_2_value_table_with_header(context.table)
|
|
74
|
+
kwargs = ValueTableConverter.convert_name_value_table_2_dict(table)
|
|
75
|
+
|
|
76
|
+
separator = kwargs.pop('separator') if 'separator' in kwargs else '\n'
|
|
77
|
+
res = MessageTCPSocketClient(separator, create_ipv4_socket_kwargs=kwargs)
|
|
78
|
+
|
|
79
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
@Step(r"start \(socket client: (?P<server_varname>{Variable})\)")
|
|
83
|
+
def step_impl(context, server_varname):
|
|
84
|
+
"""Start a non blocking socket client.
|
|
85
|
+
Note: current implementation uses 'start' method parameters default values.
|
|
86
|
+
"""
|
|
87
|
+
server = StepTools.evaluate_scenario_parameter(server_varname)
|
|
88
|
+
server.start()
|
|
89
|
+
|
|
90
|
+
@Step(r"stop \(socket client: (?P<server_varname>{Variable})\)")
|
|
91
|
+
def step_impl(context, server_varname):
|
|
92
|
+
"""Stop a non blocking socket client.
|
|
93
|
+
"""
|
|
94
|
+
server = StepTools.evaluate_scenario_parameter(server_varname)
|
|
95
|
+
server.stop()
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
################################################################
|
|
101
|
+
## Server
|
|
102
|
+
################################################################
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
@Given(r"(?P<var_name>{Variable}) = new echo TCP socket server")
|
|
106
|
+
def step_impl(context, var_name):
|
|
107
|
+
"""Return a new echo TCP socket server.
|
|
108
|
+
When started, it waits connections, and for each connection it listen data and send them back
|
|
109
|
+
Note: Only IPv4 is managed for the moment
|
|
110
|
+
"""
|
|
111
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
112
|
+
table = BehaveStepTools.convert_step_table_2_value_table_with_header(context.table)
|
|
113
|
+
kwargs = ValueTableConverter.convert_name_value_table_2_dict(table)
|
|
114
|
+
|
|
115
|
+
res = EchoTCPBlockingSocketServer(create_ipv4_socket_kwargs=kwargs)
|
|
116
|
+
|
|
117
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
118
|
+
|
|
119
|
+
@Step(r"start \(socket server: (?P<server_varname>{Variable})\)")
|
|
120
|
+
def step_impl(context, server_varname):
|
|
121
|
+
"""Start a socket server
|
|
122
|
+
Note: current implementation uses 'start' method parameters default values.
|
|
123
|
+
"""
|
|
124
|
+
server = StepTools.evaluate_scenario_parameter(server_varname)
|
|
125
|
+
server.start()
|
|
126
|
+
|
|
127
|
+
@Step(r"stop \(socket server: (?P<server_varname>{Variable})\)")
|
|
128
|
+
def step_impl(context, server_varname):
|
|
129
|
+
"""Start a socket server
|
|
130
|
+
Note: current implementation uses 'start' method parameters default values.
|
|
131
|
+
"""
|
|
132
|
+
server = StepTools.evaluate_scenario_parameter(server_varname)
|
|
133
|
+
server.stop()
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
################################################################
|
|
138
|
+
## Client and Server
|
|
139
|
+
################################################################
|
|
140
|
+
|
|
141
|
+
|
|
142
|
+
@Step(r"write (?P<data>{Bytes}) \(socket: (?P<socket_varname>{Variable})\)")
|
|
143
|
+
def step_impl(context, data, socket_varname):
|
|
144
|
+
"""Send data
|
|
145
|
+
This step do as many socket send as needed to send the whole data.
|
|
146
|
+
"""
|
|
147
|
+
data = StepTools.evaluate_scenario_parameter(data)
|
|
148
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
149
|
+
|
|
150
|
+
sock.write(data)
|
|
151
|
+
|
|
152
|
+
@Step(r"(?P<var_name>{Variable}) = read \(socket: (?P<socket_varname>{Variable})\)")
|
|
153
|
+
def step_impl(context, var_name, socket_varname):
|
|
154
|
+
"""Read data
|
|
155
|
+
This step do as many socket recv as needed to receive the whole data.
|
|
156
|
+
"""
|
|
157
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
158
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
159
|
+
|
|
160
|
+
res = sock.read()
|
|
161
|
+
|
|
162
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
163
|
+
|
|
164
|
+
|
|
165
|
+
|
|
166
|
+
# For client and servers managing messages
|
|
167
|
+
|
|
168
|
+
@Step(r"write message (?P<data>{Bytes}) \(socket: (?P<socket_varname>{Variable})\)")
|
|
169
|
+
def step_impl(context, data, socket_varname):
|
|
170
|
+
"""Send message
|
|
171
|
+
"""
|
|
172
|
+
data = StepTools.evaluate_scenario_parameter(data)
|
|
173
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
174
|
+
|
|
175
|
+
sock.write_message(data)
|
|
176
|
+
|
|
177
|
+
@Step(r"(?P<var_name>{Variable}) = read message \(socket: (?P<socket_varname>{Variable})\)")
|
|
178
|
+
def step_impl(context, var_name, socket_varname):
|
|
179
|
+
"""Read a received message.
|
|
180
|
+
If no message is in socket, None is returned.
|
|
181
|
+
"""
|
|
182
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
183
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
184
|
+
|
|
185
|
+
res = sock.read_message()
|
|
186
|
+
|
|
187
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
188
|
+
|
|
189
|
+
@Step(r"(?P<var_name>{Variable}) = read messages \(socket: (?P<socket_varname>{Variable})\)")
|
|
190
|
+
def step_impl(context, var_name, socket_varname):
|
|
191
|
+
"""Read all received messages.
|
|
192
|
+
If no message is in socket, an empty list is returned.
|
|
193
|
+
"""
|
|
194
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
195
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
196
|
+
|
|
197
|
+
res = sock.read_messages()
|
|
198
|
+
|
|
199
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
200
|
+
|
|
201
|
+
@Step(r"(?P<var_name>{Variable}) = received messages \(socket: (?P<socket_varname>{Variable})\)")
|
|
202
|
+
def step_impl(context, var_name, socket_varname):
|
|
203
|
+
"""Get received messages without removing from socket
|
|
204
|
+
"""
|
|
205
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
206
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
207
|
+
|
|
208
|
+
res = sock.messages
|
|
209
|
+
|
|
210
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
211
|
+
|
|
212
|
+
@Step(r"(?P<var_name>{Variable}) = number of received messages \(socket: (?P<socket_varname>{Variable})\)")
|
|
213
|
+
def step_impl(context, var_name, socket_varname):
|
|
214
|
+
"""Get received messages without removing from socket
|
|
215
|
+
"""
|
|
216
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
217
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
218
|
+
|
|
219
|
+
res = len(sock.messages)
|
|
220
|
+
|
|
221
|
+
__get_variable_manager().register_variable(var_name, res)
|
|
222
|
+
|
|
223
|
+
@Step(r"wait socket (?P<socket_varname>{Variable}) stops to receive data(?: \((?:first timeout: (?P<first_timeout_sec>{Float}) s)?(?: ; )?(?:window: (?P<window_sec>{Float}) s)?(?: ; )?(?:polling: (?P<polling_sec>{Float}) s)?\))?")
|
|
224
|
+
def step_impl(context, socket_varname, first_timeout_sec, window_sec, polling_sec):
|
|
225
|
+
"""Get received messages without removing from socket
|
|
226
|
+
"""
|
|
227
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
228
|
+
first_timeout_sec = StepTools.evaluate_scenario_parameter(first_timeout_sec)
|
|
229
|
+
window_sec = StepTools.evaluate_scenario_parameter(window_sec)
|
|
230
|
+
polling_sec = StepTools.evaluate_scenario_parameter(polling_sec)
|
|
231
|
+
|
|
232
|
+
wait = WaitEndChange(f"Wait end of data reception (socket: {sock})",
|
|
233
|
+
lambda: sock.received_data_size,
|
|
234
|
+
first_timeout_seconds=first_timeout_sec, window_seconds=window_sec, polling_seconds=polling_sec)
|
|
235
|
+
wait.without_raise_on_timeout()
|
|
236
|
+
data_size = wait.execute()
|
|
237
|
+
if data_size == 0:
|
|
238
|
+
raise FunctionalException(f"[{sock.name}] No data was received (timeout: {wait.timeout} seconds)")
|
|
239
|
+
|
|
240
|
+
@Step(r"wait socket (?P<socket_varname>{Variable}) stops to receive messages(?: \((?:first timeout: (?P<first_timeout_sec>{Float}) s)?(?: ; )?(?:window: (?P<window_sec>{Float}) s)?(?: ; )?(?:polling: (?P<polling_sec>{Float}) s)?\))?")
|
|
241
|
+
def step_impl(context, socket_varname, first_timeout_sec, window_sec, polling_sec):
|
|
242
|
+
"""Get received messages without removing from socket
|
|
243
|
+
"""
|
|
244
|
+
sock = StepTools.evaluate_scenario_parameter(socket_varname)
|
|
245
|
+
first_timeout_sec = StepTools.evaluate_scenario_parameter(first_timeout_sec)
|
|
246
|
+
window_sec = StepTools.evaluate_scenario_parameter(window_sec)
|
|
247
|
+
polling_sec = StepTools.evaluate_scenario_parameter(polling_sec)
|
|
248
|
+
|
|
249
|
+
wait = WaitEndChange(f"Wait end of message reception (socket: {sock})",
|
|
250
|
+
lambda: sock.nb_messages,
|
|
251
|
+
first_timeout_seconds=first_timeout_sec, window_seconds=window_sec, polling_seconds=polling_sec)
|
|
252
|
+
wait.without_raise_on_timeout()
|
|
253
|
+
nb_messages = wait.execute()
|
|
254
|
+
if nb_messages == 0:
|
|
255
|
+
raise FunctionalException(f"[{sock.name}] No message was received (timeout: {wait.timeout} seconds)")
|
|
256
|
+
|
|
257
|
+
|
|
258
|
+
|
|
@@ -0,0 +1,67 @@
|
|
|
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 *
|
|
19
|
+
import logging
|
|
20
|
+
from holado_test.behave.scenario.behave_step_tools import BehaveStepTools
|
|
21
|
+
from holado_value.common.tables.converters.value_table_converter import ValueTableConverter
|
|
22
|
+
from holado_python.standard_library.socket.blocking_socket import TCPBlockingSocketClient
|
|
23
|
+
from holado_python.standard_library.socket.echo_server import EchoTCPBlockingSocketServer
|
|
24
|
+
from holado_python.standard_library.socket.message_socket import MessageTCPSocketClient
|
|
25
|
+
from holado_core.common.handlers.wait import WaitFuncResultVerifying, WaitEndChange
|
|
26
|
+
from holado_core.common.exceptions.functional_exception import FunctionalException
|
|
27
|
+
from holado_python.standard_library.ssl.ssl import SslManager
|
|
28
|
+
|
|
29
|
+
logger = logging.getLogger(__name__)
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
def __get_scenario_context():
|
|
33
|
+
return SessionContext.instance().get_scenario_context()
|
|
34
|
+
|
|
35
|
+
def __get_text_interpreter():
|
|
36
|
+
return __get_scenario_context().get_text_interpreter()
|
|
37
|
+
|
|
38
|
+
def __get_variable_manager():
|
|
39
|
+
return __get_scenario_context().get_variable_manager()
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
@Given(r"(?P<var_name>{Variable}) = certfile path for localhost")
|
|
44
|
+
def step_impl(context, var_name):
|
|
45
|
+
"""Return path to cert file for localhost stored in internal resources.
|
|
46
|
+
Note: It is an autosigned certificate.
|
|
47
|
+
"""
|
|
48
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
49
|
+
|
|
50
|
+
cert_paths = SslManager.get_localhost_certificate()
|
|
51
|
+
|
|
52
|
+
__get_variable_manager().register_variable(var_name, cert_paths[0])
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
@Given(r"(?P<var_name>{Variable}) = keyfile path for localhost")
|
|
56
|
+
def step_impl(context, var_name):
|
|
57
|
+
"""Return path to key file for localhost stored in internal resources.
|
|
58
|
+
Note: It is an autosigned certificate.
|
|
59
|
+
"""
|
|
60
|
+
var_name = StepTools.evaluate_variable_name(var_name)
|
|
61
|
+
|
|
62
|
+
cert_paths = SslManager.get_localhost_certificate()
|
|
63
|
+
|
|
64
|
+
__get_variable_manager().register_variable(var_name, cert_paths[1])
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
|