stoobly-agent 1.5.0__tar.gz → 1.5.1__tar.gz
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.
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/PKG-INFO +1 -1
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/pyproject.toml +1 -1
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/__init__.py +1 -1
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/handle_config_update_service.py +2 -2
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request.py +1 -1
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/request_adapter.py +17 -11
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/request.py +1 -2
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/handle_mock_service.py +75 -55
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/handle_test_service.py +17 -8
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/custom_not_found_response_builder.py +5 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/eval_fixtures_service.py +3 -2
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/eval_request_service.py +16 -11
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/response_handler.py +11 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/custom_headers.py +1 -0
- stoobly_agent-1.5.1/stoobly_agent/config/constants/query_params.py +2 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request_test.py +4 -4
- stoobly_agent-1.5.1/stoobly_agent/test/cli/mock_scenario_lifecycle_hooks.py +5 -0
- stoobly_agent-1.5.1/stoobly_agent/test/cli/mock_scenario_test.py +62 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/cli/mock_test.py +1 -9
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/LICENSE +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/README.md +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/application_http_request_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/bodies_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/configs_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/headers_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/proxy_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/query_params_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/replayed_response_headers_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/replayed_responses_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/requests_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/response_headers_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/responses_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/routes.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/scenarios_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/simple_http_request_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/statuses_controller.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/ca_cert_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/config_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/decorators/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/decorators/config.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/decorators/exec.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/dev_tools_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/endpoint_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/feature_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/handlers/request_cli_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/handlers/scenario_cli_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/certificate_authority.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/endpoints_apply_context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/endpoints_apply_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/endpoints_import_context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/endpoints_import_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/feature_flags.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/handle_mock_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/handle_replay_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/handle_test_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/iterate_group_by.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/json_print.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/openapi_endpoint_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/print_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/project_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/replay_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/report_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/request_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/request_synchronize_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/run_command_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/scenario_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/schema_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/shell.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/synchronize_request_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/tabulate_print_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/test_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/test_replay_context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/trace_aliases.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/trace_context_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/validations.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/helpers/verify_raw_request_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/intercept_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/main_group.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/project_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/report_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/request_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/app.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/app_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/app_config.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/app_create_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/config.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/constants.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/app_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/constants.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/service/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/service/build_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/service/builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/service/set_gateway_ports.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/service/types.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/build_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/decorators_factory.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/development_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/mock_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/docker/workflow/reverse_proxy_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/env.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/hosts_file_manager.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/managed_services_docker_compose.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_config.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_create_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_delete_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_docker_compose.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_workflow.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/service_workflow_validate_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/.Dockerfile.context +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/.Makefile +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/Makefile +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/.config.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/.config.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/docker-compose.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/docker-compose.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/docker-compose.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/.config.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/.docker-compose.base.template.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/.config.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/.docker-compose.exec.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.create +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.delete +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.disable +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.down +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.enable +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.list +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.logs +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.mkcert +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.reset +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.services +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.snapshot +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/bin/.up +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/constants.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/factory.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/fixtures.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/public/.gitignore +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/.configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/.init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/configure +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/init +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/fixtures.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/public/.gitignore +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/validate_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/validate_exceptions.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_copy_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_create_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_env.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_log_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_run_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold/workflow_validate_command.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scaffold_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/scenario_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/snapshot_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/trace_cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/types/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/types/output.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/types/print_options.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/types/request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/types/scenario.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/cli/types/test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/joined_request_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/mitmproxy/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/mitmproxy/request/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/mitmproxy/request/python_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/mitmproxy/response/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/mitmproxy/response/python_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/joined_request_string_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/request/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/request/python_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/response/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/orm/response/python_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/request/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/request/raw_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/request/stoobly_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/response/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/python/response/raw_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_http_request_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_http_response_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_joined/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_joined/request/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_joined/request/python_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_joined/response/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/raw_joined/response/python_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/stoobly/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/stoobly/request/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/adapters/stoobly/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/body_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/body.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/header.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/body_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/header_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/create_request_columns_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/log.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/log_event.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_snapshot.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/scenario_snapshot.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/search.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_types.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/local_db_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/orm_request_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/query_param_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/replayed_response_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/response_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/response_header_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/local_db/scenario_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/query_param.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/replayed_response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/response_header.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/scenario.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/stoobly/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/stoobly/request_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/factories/resource/stoobly/scenario_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/header_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/helpers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/helpers/apply.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/helpers/create_request_params_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/query_param_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/replayed_response_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/request_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/response_header_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/response_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/scenario_model.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/schemas/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/schemas/request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/endpoint.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/replayed_response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/request_components.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/models/types/scenario.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/constants/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/constants/custom_response_codes.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/handle_record_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/handle_replay_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/hot_reload.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/intercept_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/intercept_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/flow_mock.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/request_body_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/request_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/response_body_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mitmproxy/response_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/hashed_request_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/ignored_components_response_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/request_hasher.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/search_endpoint.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/types/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/join_request_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/joined_request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/overwrite_scenario_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/proxy_request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/request_string.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/request_string_control.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/response_string.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/response_string_control.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/record/upload_request_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/alias_context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/alias_resolver.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/body_parser_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/multipart.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/replay_request_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/replay_scenario_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/rewrite_params_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/replay/trace_context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/run.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/simulate_intercept_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/context_abc.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/context_response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/diff_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/mitmproxy_response_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/request_component_names_facade.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/requests_response_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/stoobly_response_adapter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/test_results_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/helpers/upload_test_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/context.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/contract.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/custom.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/diff.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/errors.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/fuzzy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/matchers/handlers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/test/test_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/allowed_request_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/publish_change_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/request_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/rewrite.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/rewrite_rules_to_ignored_components_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/cli_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/constants/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/constants/firewall_action.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/constants/intercept_mode.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/constants/mode.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/constants/request_component.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/data_rules.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/data_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/feature_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/firewall_rule.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/firewall_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/helpers/active_mode_settings_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/intercept_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/match_rule.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/match_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/parameter_rule.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/proxy_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/remote_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/rewrite_rule.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/rewrite_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/types/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/types/cli_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/types/proxy_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/types/remote_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/types/ui_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/ui_settings.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/settings/url_rule.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/cli.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/alias_resolve_strategy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/env_vars.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/headers.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/intercept_policy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/mitmproxy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/mock_policy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/mode.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/record_policy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/replay_policy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/request_origin.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/statuses.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/test_filter.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/test_output_level.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/test_strategy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/data_dir.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/mitmproxy.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/schema.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/settings.yml.sample +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/source_dir.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_03_17_060144_create_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_03_17_074916_create_responses.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_05_10_003705_create_traces.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_05_10_003840_create_trace_aliases.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_06_29_234516_create_trace_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_06_29_235155_add_trace_request_reference_to_trace_aliases.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_12_12_092437_align_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2022_12_28_092917_add_filter_columns_to_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_01_21_055426_create_scenarios.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_01_21_060225_add_scenario_id_reference_to_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_02_02_022229_create_replayed_responses.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_03_20_192909_add_http_version_column_to_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_03_20_220448_add_http_version_column_to_responses.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_04_18_071327_align_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_05_15_212505_add_uuid_column_to_requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_05_15_213119_add_uuid_column_to_scenarios.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/2023_05_29_053649_add_overwritable_column_to_scenarios.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/db/migrations/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/agent_api.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/api.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/body_param_names_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/endpoints_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/header_names_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/endpoints.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/headers.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/pagination_query_params.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/projects.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/query_params.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/reports.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/requests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/response_headers.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/responses.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/scenarios.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/tests.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/traces.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/interfaces/users.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/json_response_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/organization_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/project_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/report_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/request_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/resource_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/scenario_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/test_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/keys/uuid_key.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/param_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/projects_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/query_param_names_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/reports_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/requests_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/response_header_names_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/response_param_names_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/scenarios_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/stoobly_api.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/test_responses_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/tests_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/api/users_resource.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/cache.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/logger.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/base.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/migrate_service.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/replayed_response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/scenario.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/trace.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/trace_alias.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/trace_request.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/transformers/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/transformers/orm_to_request_transformer.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/transformers/orm_to_requests_response_transformer.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_request_transformer.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_response_transformer.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/types/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/types/request_columns.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/types/response_columns.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/utils/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/utils/request_parse_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/utils/requests_response_builder.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/orm/utils/response_parse_handler.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/utils/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/utils/conditional_decorator.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/utils/decode.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/utils/jmespath.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/utils/python_to_ruby_type.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/lib/utils/visitor.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/mock.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/0-es2015.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/0-es5.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/1-es2015.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/1-es5.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/10-es2015.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/10-es5.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/12-es2015.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/12-es5.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/13-es2015.343b0261a8b3b3f4a1fc.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/13-es5.343b0261a8b3b3f4a1fc.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/14-es2015.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/14-es5.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/15-es2015.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/15-es5.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/16-es2015.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/16-es5.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/17-es2015.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/17-es5.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/18-es2015.503207073756a9c8211a.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/18-es5.503207073756a9c8211a.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/19-es2015.78ec0e9fd228b5104712.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/19-es5.78ec0e9fd228b5104712.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/2-es2015.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/2-es5.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/20-es2015.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/20-es5.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/21-es2015.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/21-es5.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/22-es2015.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/22-es5.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/23-es2015.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/23-es5.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/28-es2015.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/28-es5.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/29-es2015.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/29-es5.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/30-es2015.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/30-es5.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/31-es2015.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/31-es5.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/32-es2015.57553995bff0ae518501.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/32-es5.57553995bff0ae518501.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/33-es2015.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/33-es5.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/34-es2015.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/34-es5.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/35-es2015.8f79ff8748d4ff06ab03.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/35-es5.8f79ff8748d4ff06ab03.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/36-es2015.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/36-es5.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/37-es2015.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/37-es5.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/38-es2015.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/38-es5.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/39-es2015.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/39-es5.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/3rdpartylicenses.txt +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/4-es2015.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/4-es5.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/40-es2015.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/40-es5.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/41-es2015.69f2771002745c066976.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/41-es5.69f2771002745c066976.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/42-es2015.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/42-es5.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/43-es2015.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/43-es5.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/44-es2015.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/44-es5.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/45-es2015.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/45-es5.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/46-es2015.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/46-es5.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/47-es2015.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/47-es5.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/5-es2015.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/5-es5.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/6-es2015.5fb726c0555664300974.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/6-es5.5fb726c0555664300974.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/7-es2015.19ccb84e62e2ea874f53.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/7-es5.19ccb84e62e2ea874f53.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/8-es2015.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/8-es5.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/9-es2015.b7bcad8238f58e214f03.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/9-es5.b7bcad8238f58e214f03.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/CHANGELOG.md +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/README.md +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/_redirects +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/1.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/2.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/3.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/4.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/5.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/6.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/7.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/8.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/landscape.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/demo/mountain-cinematic.jpg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/illustrations/checklist.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/illustrations/data_center.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/illustrations/idea.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/illustrations/it_support.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/illustrations/peak_mountain_3.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/illustrations/under_constructions_1.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/logo/colored.png +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/logo/colored.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/logo/white.png +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/assets/img/logo/white.svg +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/common-es2015.388805227aa99c527fba.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/common-es5.388805227aa99c527fba.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/favicon.ico +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/index.html +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/main-es2015.d682619f3d6d53d64c6a.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/main-es5.d682619f3d6d53d64c6a.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/polyfills-es2015.8ce2adc69f283f6c4c5e.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/polyfills-es5.7530172ddcec11a10eb3.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/runtime-es2015.8c1efed946fc02c923fc.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/runtime-es5.8c1efed946fc02c923fc.js +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/public/styles.ab281309cf423b2cdcb0.css +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/cli_mock_integration_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/config/firewall_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/config/match_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/config/project/config_project_set_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/config/rewrite_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/config/scenario/config_scenario_set_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/endpoint/endpoint_cli_apply_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/certificate_authority_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_additional_props_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_info_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_oauth2_scopes_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_servers_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/schema_builder_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/helpers/synchronize_request_service_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/intercept/intercept_configure_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/intercept/intercept_enable_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_delete_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_list_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_replay_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_reset_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_response_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_snapshot_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/request/request_test_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scaffold/cli_invoker.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scaffold/cli_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scaffold/e2e_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scaffold/hosts_file_manager_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scenario/scenario_create_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scenario/scenario_replay_integration_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scenario/scenario_replay_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scenario/scenario_reset_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scenario/scenario_snapshot_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/scenario/scenario_test_integration_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/snapshot/snapshot_apply_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/snapshot/snapshot_copy_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/snapshot/snapshot_prune_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/cli/snapshot/snapshot_update_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/orm/joined_request_string_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/orm/request/orm_mitmproxy_request_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/orm/request/orm_python_request_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/orm/response/orm_mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/orm/response/orm_python_response_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/python/request/mitmproxy_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/python/request/raw_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/python/request/stoobly_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/python/response/mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/adapters/python/response/raw_response_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/log_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/factories/resource/local_db/request_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/factories/resource/local_db/response_adapter_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/schemas/.stoobly/db/stoobly_agent.sqlite3 +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/schemas/.stoobly/settings.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/schemas/.stoobly/tmp/options.json +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/models/schemas/request_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/mitmproxy/request_facade_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/mock/eval_fixtures_service_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/replay/body_parser_service_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/replay/rewrite_params_service_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/replay/trace_context_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/replay/visitor_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/test/helpers/test_results_builder_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/upload/request_string_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/proxy/upload/response_string_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/test/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/test/matchers/contract_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/test/matchers/diff_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/app/test/matchers/fuzzy_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/cli/lifecycle_hooks_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/cli/record_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/config/data_dir_test.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/__init__.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/endpoint_show_response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-additional-props.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-expanded.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-missing-info.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-missing-oauth2-scopes.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-missing-servers.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-references.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore-swagger-io.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/petstore.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/request_show_response.py +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/scaffold/docker-compose-assets-service.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/scaffold/docker-compose-local-service.yml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/scaffold/index.html +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/mock_data/uspto.yaml +0 -0
- {stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/test/test_helper.py +0 -0
@@ -1,2 +1,2 @@
|
|
1
1
|
COMMAND = 'stoobly-agent'
|
2
|
-
VERSION = '1.5.
|
2
|
+
VERSION = '1.5.1'
|
@@ -58,9 +58,9 @@ def handle_intercept_active_update(new_settings: Settings, context: Context = No
|
|
58
58
|
scenario_model.update(_scenario_key.id, **{ 'overwritable': False })[1]
|
59
59
|
elif _mode == intercept_mode.MOCK:
|
60
60
|
# When mock is stopped, clear request access counts
|
61
|
-
from stoobly_agent.app.models.factories.resource.local_db.helpers.tiebreak_scenario_request import
|
61
|
+
from stoobly_agent.app.models.factories.resource.local_db.helpers.tiebreak_scenario_request import reset_sessions
|
62
62
|
|
63
|
-
|
63
|
+
reset_sessions()
|
64
64
|
|
65
65
|
def handle_scenario_update(new_settings: Settings, context = None):
|
66
66
|
new_scenario_key = __scenario_key(new_settings.proxy)
|
@@ -10,7 +10,7 @@ from stoobly_agent.app.models.types import RequestCreateParams, RequestDestroyPa
|
|
10
10
|
from stoobly_agent.app.proxy.mock.custom_not_found_response_builder import CustomNotFoundResponseBuilder
|
11
11
|
from stoobly_agent.app.proxy.mock.ignored_components_response_builder import IgnoreComponentsResponseBuilder
|
12
12
|
from stoobly_agent.app.proxy.record.joined_request import JoinedRequest
|
13
|
-
from stoobly_agent.config.constants import custom_headers
|
13
|
+
from stoobly_agent.config.constants import custom_headers, query_params as request_query_params
|
14
14
|
from stoobly_agent.lib.orm import ORM
|
15
15
|
from stoobly_agent.lib.orm.request import Request
|
16
16
|
from stoobly_agent.lib.orm.response import Response
|
@@ -73,7 +73,6 @@ class LocalDBRequestAdapter(LocalDBAdapter):
|
|
73
73
|
def response(self, **query_params: RequestColumns) -> requests.Response:
|
74
74
|
self.__adapt_scenario_id(query_params)
|
75
75
|
|
76
|
-
endpoint_promise = query_params.get('endpoint_promise')
|
77
76
|
request = None
|
78
77
|
|
79
78
|
if not query_params.get('request_id'):
|
@@ -85,16 +84,19 @@ class LocalDBRequestAdapter(LocalDBAdapter):
|
|
85
84
|
requests = self.__request_orm.where_for(**request_columns).get()
|
86
85
|
|
87
86
|
if 'scenario_id' in query_params:
|
88
|
-
# TODO: Would need an additional ID to distinguish different scenario sessions
|
89
|
-
session_id = generate_session_id(request_columns)
|
90
|
-
|
91
87
|
if len(requests) > 1:
|
92
|
-
|
88
|
+
session_id = query_params.get(request_query_params.SESSION_ID)
|
89
|
+
request_session_id_components = { **request_columns }
|
90
|
+
|
91
|
+
if session_id:
|
92
|
+
request_session_id_components[request_query_params.SESSION_ID] = session_id
|
93
|
+
|
94
|
+
# When multiple requests are matched for a scenario, return them in sequence
|
95
|
+
request_session_id = generate_session_id(request_session_id_components)
|
96
|
+
request = tiebreak_scenario_request(request_session_id, requests)
|
97
|
+
access_request(request_session_id, request.id)
|
93
98
|
else:
|
94
99
|
request = requests.last()
|
95
|
-
|
96
|
-
if request:
|
97
|
-
access_request(session_id, request.id)
|
98
100
|
else:
|
99
101
|
request = requests.last()
|
100
102
|
else:
|
@@ -104,6 +106,7 @@ class LocalDBRequestAdapter(LocalDBAdapter):
|
|
104
106
|
request = None
|
105
107
|
|
106
108
|
if not request:
|
109
|
+
endpoint_promise = query_params.get(request_query_params.ENDPOINT_PROMISE)
|
107
110
|
return self.__handle_request_not_found(endpoint_promise)
|
108
111
|
|
109
112
|
response_record = request.response
|
@@ -315,8 +318,8 @@ class LocalDBRequestAdapter(LocalDBAdapter):
|
|
315
318
|
return candidates.get()
|
316
319
|
|
317
320
|
def __filter_request_response_columns(self, request_columns: RequestCreateParams):
|
318
|
-
if request_columns.get(
|
319
|
-
del request_columns[
|
321
|
+
if request_columns.get(request_query_params.ENDPOINT_PROMISE):
|
322
|
+
del request_columns[request_query_params.ENDPOINT_PROMISE]
|
320
323
|
|
321
324
|
if request_columns.get('infer'):
|
322
325
|
del request_columns['infer']
|
@@ -327,6 +330,9 @@ class LocalDBRequestAdapter(LocalDBAdapter):
|
|
327
330
|
if request_columns.get('retry'):
|
328
331
|
del request_columns['retry']
|
329
332
|
|
333
|
+
if request_columns.get(request_query_params.SESSION_ID):
|
334
|
+
del request_columns[request_query_params.SESSION_ID]
|
335
|
+
|
330
336
|
def __request(self, request_id: str):
|
331
337
|
if self.validate_uuid(request_id):
|
332
338
|
return self.__request_orm.find_by(uuid=request_id)
|
@@ -3,7 +3,7 @@ import pdb
|
|
3
3
|
import requests
|
4
4
|
import time
|
5
5
|
|
6
|
-
from mitmproxy.http import Request as MitmproxyRequest
|
6
|
+
from mitmproxy.http import HTTPFlow as MitmproxyHTTPFlow, Request as MitmproxyRequest
|
7
7
|
from typing import Callable, TypedDict
|
8
8
|
|
9
9
|
from stoobly_agent.app.models.request_model import RequestModel
|
@@ -18,7 +18,7 @@ from .mock.eval_fixtures_service import eval_fixtures
|
|
18
18
|
from .mock.eval_request_service import inject_eval_request
|
19
19
|
from .utils.allowed_request_service import get_active_mode_policy
|
20
20
|
from .utils.request_handler import reverse_proxy
|
21
|
-
from .utils.response_handler import bad_request, pass_on
|
21
|
+
from .utils.response_handler import bad_request, enable_cors, pass_on
|
22
22
|
from .utils.rewrite import rewrite_request, rewrite_response
|
23
23
|
|
24
24
|
LOG_ID = 'Mock'
|
@@ -44,60 +44,68 @@ def handle_request_mock_generic_without_rewrite(context: MockContext, **options:
|
|
44
44
|
# @param settings [Dict]
|
45
45
|
#
|
46
46
|
def handle_request_mock_generic(context: MockContext, **options: MockOptions):
|
47
|
+
handle_error = options['error'] if 'error' in options and callable(options['error']) else None
|
48
|
+
handle_failure = options['failure'] if 'failure' in options and callable(options['failure']) else None
|
49
|
+
handle_success = options['success'] if 'success' in options and callable(options['success']) else None
|
47
50
|
intercept_settings = context.intercept_settings
|
48
51
|
request: MitmproxyRequest = context.flow.request
|
49
|
-
|
50
|
-
handle_failure = options['failure'] if 'failure' in options and callable(options['failure']) else None
|
52
|
+
res = None
|
51
53
|
|
52
54
|
policy = get_active_mode_policy(request, intercept_settings)
|
53
55
|
if policy == mock_policy.NONE:
|
56
|
+
if handle_error:
|
57
|
+
res = handle_error(context)
|
58
|
+
|
59
|
+
return pass_on(context.flow, res)
|
60
|
+
|
61
|
+
if policy not in [mock_policy.ALL, mock_policy.FOUND]:
|
62
|
+
if handle_error:
|
63
|
+
res = handle_error(context)
|
64
|
+
|
65
|
+
return bad_request(
|
66
|
+
context.flow,
|
67
|
+
"Valid env MOCK_POLICY: %s, Got: %s" %
|
68
|
+
([mock_policy.ALL, mock_policy.FOUND, mock_policy.NONE], policy)
|
69
|
+
)
|
70
|
+
|
71
|
+
if not options.get('no_rewrite'):
|
72
|
+
__rewrite_request(context)
|
73
|
+
|
74
|
+
__mock_hook(lifecycle_hooks.BEFORE_MOCK, context)
|
75
|
+
|
76
|
+
# If ignore rules are set, then ignore specified request parameters
|
77
|
+
ignore_rules = intercept_settings.ignore_rules
|
78
|
+
if len(ignore_rules) > 0:
|
79
|
+
request_facade = MitmproxyRequestFacade(request)
|
80
|
+
_ignore_rules = request_facade.select_parameter_rules(ignore_rules)
|
81
|
+
ignored_components = rewrite_rules_to_ignored_components(_ignore_rules)
|
82
|
+
options['ignored_components'] += ignored_components if 'ignored_components' in options else ignored_components
|
83
|
+
|
84
|
+
request_model = RequestModel(intercept_settings.settings)
|
85
|
+
eval_request = inject_eval_request(request_model, intercept_settings)
|
86
|
+
|
87
|
+
if policy == mock_policy.ALL:
|
88
|
+
res = eval_request_with_retry(context, eval_request, **options)
|
89
|
+
|
90
|
+
context.with_response(res)
|
91
|
+
elif policy == mock_policy.FOUND:
|
92
|
+
res = eval_request_with_retry(context, eval_request, **options)
|
93
|
+
|
94
|
+
context.with_response(res)
|
95
|
+
|
96
|
+
if res.status_code in [custom_response_codes.NOT_FOUND, custom_response_codes.IGNORE_COMPONENTS]:
|
97
|
+
try:
|
98
|
+
res = __handle_found_policy(context)
|
99
|
+
except RuntimeError:
|
100
|
+
# Do nothing, return custom error response
|
101
|
+
pass
|
102
|
+
|
103
|
+
if res.status_code == custom_response_codes.NOT_FOUND:
|
54
104
|
if handle_failure:
|
55
|
-
res = handle_failure(context)
|
105
|
+
res = handle_failure(context) or res
|
56
106
|
else:
|
57
|
-
if
|
58
|
-
|
59
|
-
|
60
|
-
__mock_hook(lifecycle_hooks.BEFORE_MOCK, context)
|
61
|
-
|
62
|
-
# If ignore rules are set, then ignore specified request parameters
|
63
|
-
ignore_rules = intercept_settings.ignore_rules
|
64
|
-
if len(ignore_rules) > 0:
|
65
|
-
request_facade = MitmproxyRequestFacade(request)
|
66
|
-
_ignore_rules = request_facade.select_parameter_rules(ignore_rules)
|
67
|
-
ignored_components = rewrite_rules_to_ignored_components(_ignore_rules)
|
68
|
-
options['ignored_components'] += ignored_components if 'ignored_components' in options else ignored_components
|
69
|
-
|
70
|
-
request_model = RequestModel(intercept_settings.settings)
|
71
|
-
eval_request = inject_eval_request(request_model, intercept_settings)
|
72
|
-
|
73
|
-
if policy == mock_policy.ALL:
|
74
|
-
res = eval_request_with_retry(context, eval_request, **options)
|
75
|
-
|
76
|
-
context.with_response(res)
|
77
|
-
|
78
|
-
if handle_success:
|
79
|
-
res = handle_success(context) or res
|
80
|
-
elif policy == mock_policy.FOUND:
|
81
|
-
res = eval_request_with_retry(context, eval_request, **options)
|
82
|
-
|
83
|
-
context.with_response(res)
|
84
|
-
|
85
|
-
if res.status_code in [custom_response_codes.NOT_FOUND, custom_response_codes.IGNORE_COMPONENTS]:
|
86
|
-
if handle_failure:
|
87
|
-
try:
|
88
|
-
res = handle_failure(context)
|
89
|
-
except RuntimeError:
|
90
|
-
# Do nothing, return custom error response
|
91
|
-
pass
|
92
|
-
else:
|
93
|
-
if handle_success:
|
94
|
-
res = handle_success(context) or res
|
95
|
-
else:
|
96
|
-
return bad_request(
|
97
|
-
context.flow,
|
98
|
-
"Valid env MOCK_POLICY: %s, Got: %s" %
|
99
|
-
([mock_policy.ALL, mock_policy.FOUND, mock_policy.NONE], policy)
|
100
|
-
)
|
107
|
+
if handle_success:
|
108
|
+
res = handle_success(context) or res
|
101
109
|
|
102
110
|
return pass_on(context.flow, res)
|
103
111
|
|
@@ -147,13 +155,19 @@ def handle_response_mock(context: MockContext):
|
|
147
155
|
__rewrite_response(context)
|
148
156
|
__mock_hook(lifecycle_hooks.AFTER_MOCK, context)
|
149
157
|
|
150
|
-
def __handle_mock_success(context: MockContext) -> None:
|
151
|
-
if os.environ.get(env_vars.AGENT_SIMULATE_LATENCY):
|
152
|
-
response = context.response
|
153
|
-
start_time = context.start_time
|
154
|
-
__simulate_latency(response.headers.get(custom_headers.RESPONSE_LATENCY), start_time)
|
155
|
-
|
156
158
|
def __handle_mock_failure(context: MockContext) -> None:
|
159
|
+
flow = context.flow
|
160
|
+
request = flow.request
|
161
|
+
|
162
|
+
if request.method.upper() != 'OPTIONS':
|
163
|
+
return False
|
164
|
+
|
165
|
+
# Default OPTIONS request to allow CORS
|
166
|
+
enable_cors(flow)
|
167
|
+
|
168
|
+
return True
|
169
|
+
|
170
|
+
def __handle_found_policy(context: MockContext) -> None:
|
157
171
|
req = context.flow.request
|
158
172
|
intercept_settings = context.intercept_settings
|
159
173
|
upstream_url = intercept_settings.upstream_url
|
@@ -169,6 +183,12 @@ def __handle_mock_failure(context: MockContext) -> None:
|
|
169
183
|
|
170
184
|
reverse_proxy(req, upstream_url, {})
|
171
185
|
|
186
|
+
def __handle_mock_success(context: MockContext) -> None:
|
187
|
+
if os.environ.get(env_vars.AGENT_SIMULATE_LATENCY):
|
188
|
+
response = context.response
|
189
|
+
start_time = context.start_time
|
190
|
+
__simulate_latency(response.headers.get(custom_headers.RESPONSE_LATENCY), start_time)
|
191
|
+
|
172
192
|
def __rewrite_request(context: MockContext):
|
173
193
|
# Rewrite request with paramter rules for mock
|
174
194
|
|
@@ -62,6 +62,7 @@ def handle_response_test(context: ReplayContext) -> None:
|
|
62
62
|
# At this point, the request may already been rewritten during replay, do not rewrite again
|
63
63
|
handle_request_mock_generic_without_rewrite(
|
64
64
|
MockContext(flow, intercept_settings),
|
65
|
+
error=lambda mock_context: __handle_mock_error(TestContext(context, mock_context)),
|
65
66
|
failure=lambda mock_context: __handle_mock_failure(TestContext(context, mock_context)),
|
66
67
|
#infer=intercept_settings.test_strategy == test_strategy.FUZZY, # For fuzzy testing we can use an inferred response
|
67
68
|
success=lambda mock_context: __handle_mock_success(TestContext(context, mock_context))
|
@@ -71,6 +72,22 @@ def __decorate_test_id(flow: MitmproxyHTTPFlow, test_response: TestShowResponse)
|
|
71
72
|
if test_response.get('id'):
|
72
73
|
flow.response.headers[custom_headers.TEST_ID] = str(test_response['id'])
|
73
74
|
|
75
|
+
def __handle_mock_error(test_context: TestContext):
|
76
|
+
Logger.instance().warn(f"{LOG_ID}:TestStatus: Mock not enabled")
|
77
|
+
|
78
|
+
intercept_settings = test_context.intercept_settings
|
79
|
+
|
80
|
+
if intercept_settings.request_origin == request_origin.CLI:
|
81
|
+
return build_response(False, 'No test found')
|
82
|
+
|
83
|
+
def __handle_mock_failure(test_context: TestContext) -> None:
|
84
|
+
Logger.instance().warn(f"{LOG_ID}:TestStatus: No test found")
|
85
|
+
|
86
|
+
intercept_settings = test_context.intercept_settings
|
87
|
+
|
88
|
+
if intercept_settings.request_origin == request_origin.CLI:
|
89
|
+
return build_response(False, 'No test found')
|
90
|
+
|
74
91
|
def __handle_mock_success(test_context: TestContext) -> None:
|
75
92
|
flow: MitmproxyHTTPFlow = test_context.flow
|
76
93
|
|
@@ -138,14 +155,6 @@ def __handle_mock_success(test_context: TestContext) -> None:
|
|
138
155
|
|
139
156
|
return flow.response
|
140
157
|
|
141
|
-
def __handle_mock_failure(test_context: TestContext) -> None:
|
142
|
-
Logger.instance().warn(f"{LOG_ID}:TestStatus: No test found")
|
143
|
-
|
144
|
-
intercept_settings = test_context.intercept_settings
|
145
|
-
|
146
|
-
if intercept_settings.request_origin == request_origin.CLI:
|
147
|
-
return build_response(False, 'No test found')
|
148
|
-
|
149
158
|
def __override_response(flow: MitmproxyHTTPFlow, content: bytes):
|
150
159
|
headers = { 'Content-Type': 'text/plain' }
|
151
160
|
headers[custom_headers.CONTENT_TYPE] = custom_headers.CONTENT_TYPE_TEST_RESULTS
|
@@ -12,4 +12,9 @@ class CustomNotFoundResponseBuilder():
|
|
12
12
|
def build(self):
|
13
13
|
self.__response.status_code = custom_response_codes.NOT_FOUND
|
14
14
|
self.__response.raw = BytesIO('Request not found'.encode())
|
15
|
+
self.__response.headers = {
|
16
|
+
'Access-Control-Allow-Origin': '*',
|
17
|
+
'Access-Control-Allow-Methods': 'GET, OPTIONS, POST, PATCH, PUT, DELETE',
|
18
|
+
'Content-Type': 'text/plain',
|
19
|
+
}
|
15
20
|
return self.__response
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/eval_fixtures_service.py
RENAMED
@@ -40,8 +40,9 @@ def eval_fixtures(request: MitmproxyRequest, **options: Options) -> Union[Respon
|
|
40
40
|
|
41
41
|
if not fixture_path:
|
42
42
|
fixture_path = _fixture_path
|
43
|
-
|
44
|
-
|
43
|
+
|
44
|
+
if not os.path.isfile(fixture_path):
|
45
|
+
return
|
45
46
|
else:
|
46
47
|
fixture_path = fixture.get('path')
|
47
48
|
if not fixture_path or not os.path.isfile(fixture_path):
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/mock/eval_request_service.py
RENAMED
@@ -5,16 +5,17 @@ import re
|
|
5
5
|
from mitmproxy.http import Request as MitmproxyRequest
|
6
6
|
from requests import Response
|
7
7
|
from typing import List, TypedDict, Union
|
8
|
-
from stoobly_agent.config.constants import custom_headers
|
9
8
|
|
10
|
-
from stoobly_agent.lib.api.param_builder import ParamBuilder
|
11
|
-
from stoobly_agent.lib.api.interfaces.requests import RequestResponseShowQueryParams
|
12
|
-
from stoobly_agent.lib.logger import Logger
|
13
9
|
from stoobly_agent.app.models.request_model import RequestModel
|
14
10
|
from stoobly_agent.app.proxy.intercept_settings import InterceptSettings
|
11
|
+
from stoobly_agent.app.proxy.mock.custom_not_found_response_builder import CustomNotFoundResponseBuilder
|
15
12
|
from stoobly_agent.app.settings import Settings
|
16
13
|
from stoobly_agent.app.settings.constants import request_component
|
17
14
|
from stoobly_agent.app.settings.match_rule import MatchRule
|
15
|
+
from stoobly_agent.config.constants import custom_headers, query_params as request_query_params
|
16
|
+
from stoobly_agent.lib.api.param_builder import ParamBuilder
|
17
|
+
from stoobly_agent.lib.api.interfaces.requests import RequestResponseShowQueryParams
|
18
|
+
from stoobly_agent.lib.logger import Logger
|
18
19
|
|
19
20
|
from .hashed_request_decorator import HashedRequestDecorator
|
20
21
|
from .search_endpoint import inject_search_endpoint
|
@@ -40,10 +41,6 @@ def inject_eval_request(
|
|
40
41
|
request_model, intercept_settings, request, ignored_components or [], **options
|
41
42
|
)
|
42
43
|
|
43
|
-
###
|
44
|
-
#
|
45
|
-
# @param settings [Settings.mode.mock | Settings.mode.record]
|
46
|
-
#
|
47
44
|
def eval_request(
|
48
45
|
request_model: RequestModel,
|
49
46
|
intercept_settings: InterceptSettings,
|
@@ -52,9 +49,14 @@ def eval_request(
|
|
52
49
|
**options: EvalRequestOptions
|
53
50
|
) -> Response:
|
54
51
|
query_params_builder = ParamBuilder({})
|
55
|
-
query_params_builder.with_resource_scoping(intercept_settings.project_key, intercept_settings.scenario_key)
|
56
52
|
|
57
|
-
|
53
|
+
try:
|
54
|
+
query_params_builder.with_resource_scoping(intercept_settings.project_key, intercept_settings.scenario_key)
|
55
|
+
except:
|
56
|
+
# If project_key or scenario_key are invalid, assume custom not found
|
57
|
+
return CustomNotFoundResponseBuilder().build()
|
58
|
+
|
59
|
+
# Tease out API returning ignored components on custom not found
|
58
60
|
if request_model.is_local and not options.get('retry'):
|
59
61
|
remote_project_key = intercept_settings.parsed_remote_project_key
|
60
62
|
|
@@ -63,7 +65,7 @@ def eval_request(
|
|
63
65
|
remote_project_id = remote_project_key.id
|
64
66
|
endpoint_promise = lambda: search_endpoint(remote_project_id, request.method, request.url, ignored_components=1)
|
65
67
|
|
66
|
-
query_params_builder.with_param(
|
68
|
+
query_params_builder.with_param(request_query_params.ENDPOINT_PROMISE, endpoint_promise)
|
67
69
|
|
68
70
|
ignored_components = __build_ignored_components(ignored_components_list or [])
|
69
71
|
query_params_builder.with_params(__build_request_params(request, ignored_components))
|
@@ -142,6 +144,9 @@ def __build_optional_params(request: MitmproxyRequest, options: EvalRequestOptio
|
|
142
144
|
if custom_headers.MOCK_REQUEST_ID in headers:
|
143
145
|
optional_params['request_id'] = headers[custom_headers.MOCK_REQUEST_ID]
|
144
146
|
|
147
|
+
if custom_headers.SESSION_ID in headers:
|
148
|
+
optional_params[request_query_params.SESSION_ID] = headers[custom_headers.SESSION_ID]
|
149
|
+
|
145
150
|
return optional_params
|
146
151
|
|
147
152
|
def __filter_by_match_rules(request: MitmproxyRequest, match_rules: List[MatchRule], query_params: RequestResponseShowQueryParams):
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/proxy/utils/response_handler.py
RENAMED
@@ -36,6 +36,17 @@ def bad_request(flow: MitmproxyHTTPFlow, message: str):
|
|
36
36
|
{'Content-Type': 'text/plain'} # (optional) headers
|
37
37
|
)
|
38
38
|
|
39
|
+
def enable_cors(flow: MitmproxyHTTPFlow):
|
40
|
+
flow.response = MitmproxyResponse.make(
|
41
|
+
200,
|
42
|
+
'',
|
43
|
+
{
|
44
|
+
'Access-Control-Allow-Origin': '*',
|
45
|
+
'Access-Control-Allow-Methods': 'GET, OPTIONS, POST, PATCH, PUT, DELETE',
|
46
|
+
'Access-Control-Allow-Headers': '*'
|
47
|
+
}
|
48
|
+
)
|
49
|
+
|
39
50
|
# Without deleting this header, causes parsing issues when reading response
|
40
51
|
def disable_transfer_encoding(response: MitmproxyResponse) -> None:
|
41
52
|
header_name = 'Transfer-Encoding'
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/config/constants/custom_headers.py
RENAMED
@@ -19,6 +19,7 @@ RESPONSE_ID = 'X-Stoobly-Response-Id'
|
|
19
19
|
RESPONSE_LATENCY = 'X-Stoobly-Request-Response-Latency'
|
20
20
|
RESPONSE_PROXY_MODE = 'X-Stoobly-Response-Proxy-Mode'
|
21
21
|
SCENARIO_KEY = 'X-Stoobly-Scenario-Key'
|
22
|
+
SESSION_ID = 'X-Stoobly-Session-Id'
|
22
23
|
SERVICE_URL = 'X-Stoobly-Service-Url'
|
23
24
|
TEST_FILTER = 'X-Stoobly-Test-Filter'
|
24
25
|
TEST_ID = 'X-Stoobly-Test-Id'
|
@@ -5,7 +5,7 @@ import time
|
|
5
5
|
from typing import List
|
6
6
|
|
7
7
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.tiebreak_scenario_request import (
|
8
|
-
access_request, generate_session_id,
|
8
|
+
access_request, generate_session_id, reset_sessions, tiebreak_scenario_request
|
9
9
|
)
|
10
10
|
from stoobly_agent.lib.cache import Cache
|
11
11
|
from stoobly_agent.lib.orm.request import Request
|
@@ -92,7 +92,7 @@ class TestTiebreakScenarioRequest():
|
|
92
92
|
request = tiebreak_scenario_request(session_id, requests)
|
93
93
|
assert request.id == 2
|
94
94
|
|
95
|
-
class
|
95
|
+
class TestWhenResetSessions():
|
96
96
|
@pytest.fixture(scope='class')
|
97
97
|
def created_request_one(self):
|
98
98
|
return RequestMock(1)
|
@@ -105,7 +105,7 @@ class TestTiebreakScenarioRequest():
|
|
105
105
|
def test_it_resets(self, cache: Cache, created_request_one: Request):
|
106
106
|
cache.write('persists', 1)
|
107
107
|
access_request('1', created_request_one.id)
|
108
|
-
|
108
|
+
reset_sessions()
|
109
109
|
|
110
110
|
assert cache.read('persists') != None
|
111
|
-
assert len(cache.read_all()) == 1
|
111
|
+
assert len(cache.read_all()) == 1
|
@@ -0,0 +1,62 @@
|
|
1
|
+
import pdb
|
2
|
+
import pytest
|
3
|
+
|
4
|
+
from click.testing import CliRunner
|
5
|
+
from pathlib import Path
|
6
|
+
|
7
|
+
from stoobly_agent.test.test_helper import DETERMINISTIC_GET_REQUEST_URL, NON_DETERMINISTIC_GET_REQUEST_URL
|
8
|
+
|
9
|
+
from stoobly_agent.config.constants.custom_headers import SESSION_ID
|
10
|
+
from stoobly_agent.cli import mock, record, scenario
|
11
|
+
from stoobly_agent.lib.api.keys.scenario_key import ScenarioKey
|
12
|
+
from stoobly_agent.lib.orm.request import Request
|
13
|
+
|
14
|
+
@pytest.fixture(scope='module')
|
15
|
+
def runner():
|
16
|
+
return CliRunner()
|
17
|
+
|
18
|
+
class TestMocking():
|
19
|
+
@pytest.fixture(scope='class')
|
20
|
+
def lifecycle_hooks_path(self):
|
21
|
+
return str(Path(__file__).parent / 'mock_scenario_lifecycle_hooks.py')
|
22
|
+
|
23
|
+
class TestScenario():
|
24
|
+
@pytest.fixture(scope='class')
|
25
|
+
def scenario_key(self, runner: CliRunner):
|
26
|
+
res = runner.invoke(scenario, ['create', '--select', 'key', '--without-headers', 'test-scenario'])
|
27
|
+
assert res.exit_code == 0
|
28
|
+
return ScenarioKey(res.stdout.strip()).raw
|
29
|
+
|
30
|
+
@pytest.fixture(autouse=True, scope='class')
|
31
|
+
def recorded_request1(self, runner: CliRunner, scenario_key: str):
|
32
|
+
record_result = runner.invoke(record, ['--scenario-key', scenario_key, DETERMINISTIC_GET_REQUEST_URL])
|
33
|
+
assert record_result.exit_code == 0
|
34
|
+
return Request.last()
|
35
|
+
|
36
|
+
@pytest.fixture(autouse=True, scope='class')
|
37
|
+
def recorded_request2(self, runner: CliRunner, scenario_key: str):
|
38
|
+
record_result = runner.invoke(record, ['--scenario-key', scenario_key, DETERMINISTIC_GET_REQUEST_URL])
|
39
|
+
assert record_result.exit_code == 0
|
40
|
+
return Request.last()
|
41
|
+
|
42
|
+
def test_it_does_not_mocks(self, runner: CliRunner, scenario_key: str):
|
43
|
+
mock_result = runner.invoke(mock, ['--scenario-key', scenario_key, NON_DETERMINISTIC_GET_REQUEST_URL])
|
44
|
+
assert mock_result.exit_code == 1
|
45
|
+
|
46
|
+
def test_it_mocks(self, runner: CliRunner, scenario_key: str):
|
47
|
+
mock_result = runner.invoke(mock, ['--scenario-key', scenario_key, DETERMINISTIC_GET_REQUEST_URL])
|
48
|
+
assert mock_result.exit_code == 0
|
49
|
+
|
50
|
+
def test_it_mocks_in_order(
|
51
|
+
self, runner: CliRunner, lifecycle_hooks_path: str, recorded_request1: Request, recorded_request2: Request, scenario_key: str
|
52
|
+
):
|
53
|
+
session_id = 'test'
|
54
|
+
args = [
|
55
|
+
'--lifecycle-hooks-path', lifecycle_hooks_path, '--scenario-key', scenario_key, '--output', '/dev/null',
|
56
|
+
'-H', f"{SESSION_ID}: {session_id}", DETERMINISTIC_GET_REQUEST_URL
|
57
|
+
]
|
58
|
+
mock_result = runner.invoke(mock, args)
|
59
|
+
assert int(mock_result.stdout) == recorded_request1.id
|
60
|
+
|
61
|
+
mock_result = runner.invoke(mock, args)
|
62
|
+
assert int(mock_result.stdout) == recorded_request2.id
|
@@ -8,8 +8,7 @@ from stoobly_agent.test.test_helper import DETERMINISTIC_GET_REQUEST_URL, reset
|
|
8
8
|
|
9
9
|
from stoobly_agent.config.constants import mode
|
10
10
|
from stoobly_agent.app.settings.constants import request_component
|
11
|
-
from stoobly_agent.cli import config, mock, record
|
12
|
-
from stoobly_agent.lib.api.keys.scenario_key import ScenarioKey
|
11
|
+
from stoobly_agent.cli import config, mock, record
|
13
12
|
from stoobly_agent.lib.orm.request import Request
|
14
13
|
|
15
14
|
@pytest.fixture(scope='module')
|
@@ -143,10 +142,3 @@ class TestMocking():
|
|
143
142
|
mock_result = runner.invoke(mock, [self.url])
|
144
143
|
assert mock_result.exit_code == 0
|
145
144
|
|
146
|
-
class TestScenario():
|
147
|
-
|
148
|
-
@pytest.fixture
|
149
|
-
def scenario_key(self, runner: CliRunner):
|
150
|
-
res = runner.invoke(scenario, ['create', '--select', 'key', '--without-headers', 'test-scenario'])
|
151
|
-
assert res.exit_code == 0
|
152
|
-
return ScenarioKey(res.stdout.strip())
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/query_params_controller.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/replayed_responses_controller.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/response_headers_controller.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{stoobly_agent-1.5.0 → stoobly_agent-1.5.1}/stoobly_agent/app/api/simple_http_request_handler.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|