stoobly-agent 1.9.0__tar.gz → 1.9.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.9.0 → stoobly_agent-1.9.1}/PKG-INFO +1 -1
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/pyproject.toml +1 -1
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/__init__.py +1 -1
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/log.py +52 -2
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_snapshot.py +0 -1
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/scenario_snapshot.py +2 -3
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_service.py +9 -8
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/helpers/apply.py +9 -4
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_apply_test.py +143 -1
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_prune_test.py +72 -3
- stoobly_agent-1.9.1/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +1 -0
- stoobly_agent-1.9.0/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +0 -1
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/LICENSE +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/README.md +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/application_http_request_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/bodies_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/configs_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/headers_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/proxy_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/query_params_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/replayed_response_headers_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/replayed_responses_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/requests_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/response_headers_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/responses_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/routes.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/scenarios_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/simple_http_request_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/statuses_controller.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/ca_cert_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/config_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/decorators/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/decorators/config.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/decorators/exec.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/dev_tools_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/endpoint_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/feature_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/handlers/request_cli_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/handlers/scenario_cli_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/certificate_authority.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_apply_context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_apply_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_import_context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_import_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/feature_flags.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_config_update_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_mock_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_replay_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_test_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/iterate_group_by.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/json_print.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/openapi_endpoint_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/print_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/project_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/replay_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/report_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/request_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/request_synchronize_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/run_command_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/scenario_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/schema_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/shell.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/synchronize_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/tabulate_print_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/test_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/test_replay_context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/trace_aliases.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/trace_context_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/validations.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/verify_raw_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/intercept_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/main_group.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/project_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/report_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/request_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app_config.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app_create_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/config.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/constants.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/containerized_app.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/app_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/constants.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/build_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/configure_gateway.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/types.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/build_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/decorators_factory.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/dns_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/mock_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/reverse_proxy_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/env.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/hosts_file_manager.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/managed_services_docker_compose.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_config.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_create_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_delete_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_docker_compose.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_workflow.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_workflow_validate_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.Dockerfile.context +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.Makefile +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.docker-compose.networks.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/Makefile +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/.config.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/docker-compose.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/docker-compose.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/docker-compose.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/.config.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/docker-compose.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/docker-compose.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/docker-compose.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/.config.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/.docker-compose.base.template.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/.config.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/.docker-compose.exec.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/mock/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/mock/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/record/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/record/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/test/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/test/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/mock/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/mock/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/record/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/record/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/test/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/test/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.create +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.delete +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.disable +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.down +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.enable +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.list +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.logs +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.mkcert +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.overwrite +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.reset +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.services +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.snapshot +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.up +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/mock/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/mock/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/record/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/record/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/test/.configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/test/.init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/constants.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/factory.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/fixtures.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/public/.gitignore +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/configure +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/init +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/fixtures.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/public/.gitignore +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/validate_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/validate_exceptions.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_config.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_copy_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_create_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_env.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_log_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_run_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_validate_command.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scenario_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/snapshot_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/trace_cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/output.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/print_options.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/scenario.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/snapshot_migration.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/joined_request_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/request/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/request/python_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/response/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/response/python_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/joined_request_string_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/request/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/request/python_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/response/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/response/python_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/raw_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/stoobly_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/response/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/response/raw_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_http_request_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_http_response_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/request/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/request/python_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/response/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/response/python_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/stoobly/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/stoobly/request/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/stoobly/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/body_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/body.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/header.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/body_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/header_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/create_request_columns_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/log_event.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/search.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_types.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/local_db_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/orm_request_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/query_param_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/replayed_response_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/request_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/response_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/response_header_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/scenario_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/query_param.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/replayed_response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/response_header.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/scenario.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/stoobly/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/stoobly/request_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/stoobly/scenario_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/header_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/helpers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/helpers/create_request_params_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/query_param_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/replayed_response_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/request_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/response_header_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/response_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/scenario_model.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/schemas/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/schemas/request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/endpoint.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/replayed_response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/request_components.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/scenario.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/constants/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/constants/custom_response_codes.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_mock_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_record_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_replay_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_test_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/hot_reload.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/intercept_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/intercept_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/flow_mock.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/request_body_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/request_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/response_body_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/response_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/custom_not_found_response_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/eval_fixtures_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/eval_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/hashed_request_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/ignored_components_response_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/request_hasher.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/search_endpoint.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/types/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/join_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/joined_request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/overwrite_scenario_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/proxy_request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/request_string.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/request_string_control.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/response_string.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/response_string_control.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/upload_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/alias_context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/alias_resolver.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/body_parser_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/multipart.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/replay_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/replay_scenario_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/rewrite_params_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/trace_context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/run.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/simulate_intercept_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/context_abc.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/context_response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/diff_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/mitmproxy_response_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/request_component_names_facade.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/requests_response_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/stoobly_response_adapter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/test_results_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/upload_test_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/context.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/contract.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/custom.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/diff.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/errors.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/fuzzy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/handlers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/test_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/allowed_request_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/publish_change_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/request_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/response_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/rewrite.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/rewrite_rules_to_ignored_components_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/cli_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/firewall_action.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/intercept_mode.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/mode.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/request_component.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/data_rules.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/data_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/feature_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/firewall_rule.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/firewall_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/helpers/active_mode_settings_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/intercept_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/match_rule.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/match_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/parameter_rule.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/proxy_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/remote_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/rewrite_rule.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/rewrite_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/cli_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/proxy_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/remote_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/ui_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/ui_settings.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/url_rule.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/cli.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/alias_resolve_strategy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/custom_headers.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/env_vars.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/headers.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/intercept_policy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/mock_policy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/mode.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/query_params.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/record_order.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/record_policy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/replay_policy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/request_origin.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/statuses.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/test_filter.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/test_output_level.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/test_strategy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/data_dir.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/mitmproxy.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/schema.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/settings.yml.sample +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/config/source_dir.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_03_17_060144_create_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_03_17_074916_create_responses.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_05_10_003705_create_traces.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_05_10_003840_create_trace_aliases.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_06_29_234516_create_trace_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_06_29_235155_add_trace_request_reference_to_trace_aliases.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_12_12_092437_align_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_12_28_092917_add_filter_columns_to_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_01_21_055426_create_scenarios.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_01_21_060225_add_scenario_id_reference_to_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_02_02_022229_create_replayed_responses.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_03_20_192909_add_http_version_column_to_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_03_20_220448_add_http_version_column_to_responses.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_04_18_071327_align_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_05_15_212505_add_uuid_column_to_requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_05_15_213119_add_uuid_column_to_scenarios.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_05_29_053649_add_overwritable_column_to_scenarios.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/agent_api.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/api.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/body_param_names_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/endpoints_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/header_names_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/endpoints.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/headers.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/pagination_query_params.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/projects.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/query_params.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/reports.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/requests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/response_headers.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/responses.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/scenarios.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/tests.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/traces.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/users.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/json_response_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/organization_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/project_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/report_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/request_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/resource_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/scenario_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/test_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/uuid_key.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/param_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/projects_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/query_param_names_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/reports_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/requests_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/response_header_names_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/response_param_names_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/scenarios_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/stoobly_api.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/test_responses_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/tests_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/users_resource.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/cache.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/logger.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/base.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/migrate_service.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/replayed_response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/scenario.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/trace.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/trace_alias.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/trace_request.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_request_transformer.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_requests_response_transformer.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_request_transformer.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_response_transformer.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/types/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/types/request_columns.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/types/response_columns.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/request_parse_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/requests_response_builder.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/response_parse_handler.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/conditional_decorator.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/decode.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/jmespath.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/python_to_ruby_type.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/visitor.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/mock.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/0-es2015.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/0-es5.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/1-es2015.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/1-es5.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/10-es2015.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/10-es5.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/12-es2015.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/12-es5.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/13-es2015.6d3a4fd76d46bfa5f200.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/13-es5.6d3a4fd76d46bfa5f200.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/14-es2015.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/14-es5.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/15-es2015.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/15-es5.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/16-es2015.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/16-es5.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/17-es2015.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/17-es5.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/18-es2015.beb31fe4a4dee3007cb2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/18-es5.beb31fe4a4dee3007cb2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/19-es2015.e5acb2c1e0e91717efc2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/19-es5.e5acb2c1e0e91717efc2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/2-es2015.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/2-es5.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/20-es2015.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/20-es5.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/21-es2015.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/21-es5.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/22-es2015.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/22-es5.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/23-es2015.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/23-es5.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/28-es2015.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/28-es5.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/29-es2015.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/29-es5.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/30-es2015.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/30-es5.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/31-es2015.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/31-es5.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/32-es2015.57553995bff0ae518501.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/32-es5.57553995bff0ae518501.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/33-es2015.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/33-es5.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/34-es2015.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/34-es5.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/35-es2015.4ffe6f7a196ed1a87fc7.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/35-es5.4ffe6f7a196ed1a87fc7.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/36-es2015.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/36-es5.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/37-es2015.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/37-es5.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/38-es2015.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/38-es5.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/39-es2015.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/39-es5.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/3rdpartylicenses.txt +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/4-es2015.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/4-es5.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/40-es2015.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/40-es5.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/41-es2015.69f2771002745c066976.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/41-es5.69f2771002745c066976.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/42-es2015.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/42-es5.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/43-es2015.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/43-es5.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/44-es2015.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/44-es5.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/45-es2015.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/45-es5.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/46-es2015.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/46-es5.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/47-es2015.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/47-es5.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/5-es2015.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/5-es5.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/6-es2015.5fb726c0555664300974.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/6-es5.5fb726c0555664300974.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/7-es2015.ba9f789e186a8e3962d3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/7-es5.ba9f789e186a8e3962d3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/8-es2015.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/8-es5.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/9-es2015.1d75413af5d96b4ff1e5.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/9-es5.1d75413af5d96b4ff1e5.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/CHANGELOG.md +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/README.md +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/_redirects +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/1.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/2.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/3.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/4.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/5.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/6.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/7.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/8.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/landscape.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/mountain-cinematic.jpg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/checklist.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/data_center.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/idea.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/it_support.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/peak_mountain_3.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/under_constructions_1.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/colored.png +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/colored.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/white.png +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/white.svg +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/common-es2015.388805227aa99c527fba.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/common-es5.388805227aa99c527fba.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/favicon.ico +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/index.html +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/main-es2015.089b46f303768fbe864f.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/main-es5.089b46f303768fbe864f.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/polyfills-es2015.8ce2adc69f283f6c4c5e.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/polyfills-es5.7530172ddcec11a10eb3.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/runtime-es2015.f8c814b38b27708e91c1.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/runtime-es5.f8c814b38b27708e91c1.js +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/public/styles.817f011ab81b18b0e5c2.css +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/cli_mock_integration_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/firewall_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/match_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/project/config_project_set_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/rewrite_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/scenario/config_scenario_set_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/endpoint/endpoint_cli_apply_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/certificate_authority_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_additional_props_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_info_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_oauth2_scopes_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_servers_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/schema_builder_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/synchronize_request_service_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/intercept/intercept_configure_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/intercept/intercept_enable_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_delete_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_list_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_replay_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_reset_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_response_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_snapshot_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_test_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/cli_invoker.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/cli_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/e2e_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/hosts_file_manager_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_create_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_replay_integration_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_replay_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_reset_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_snapshot_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_test_integration_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/lifecycle_hooks_migrate.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_copy_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_migrate_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_update_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/joined_request_string_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/request/orm_mitmproxy_request_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/request/orm_python_request_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/response/orm_mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/response/orm_python_response_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/request/mitmproxy_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/request/raw_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/request/stoobly_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/response/mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/response/raw_response_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/log_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/request_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/response_adapter_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/.stoobly/db/stoobly_agent.sqlite3 +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/.stoobly/settings.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/.stoobly/tmp/options.json +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/request_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/mitmproxy/request_facade_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/mock/eval_fixtures_service_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/body_parser_service_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/rewrite_params_service_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/trace_context_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/visitor_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/test/helpers/test_results_builder_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/upload/request_string_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/upload/response_string_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/matchers/contract_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/matchers/diff_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/matchers/fuzzy_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/lifecycle_hooks_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/mock_scenario_lifecycle_hooks.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/mock_scenario_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/mock_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/record_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/config/data_dir_test.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/__init__.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/endpoint_show_response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-additional-props.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-expanded.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-missing-info.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-missing-oauth2-scopes.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-missing-servers.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-references.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-swagger-io.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/request_show_response.py +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/scaffold/docker-compose-assets-service.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/scaffold/docker-compose-local-service.yml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/scaffold/index.html +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/uspto.yaml +0 -0
- {stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/test/test_helper.py +0 -0
@@ -1,2 +1,2 @@
|
|
1
1
|
COMMAND = 'stoobly-agent'
|
2
|
-
VERSION = '1.9.
|
2
|
+
VERSION = '1.9.1'
|
@@ -8,6 +8,7 @@ from stoobly_agent.config.data_dir import DataDir
|
|
8
8
|
from stoobly_agent.lib.logger import bcolors, Logger
|
9
9
|
|
10
10
|
from .log_event import LogEvent
|
11
|
+
from .request_snapshot import RequestSnapshot
|
11
12
|
from .snapshot_types import DELETE_ACTION, PUT_ACTION, Resource
|
12
13
|
|
13
14
|
EVENT_DELIMITTER = "\n"
|
@@ -67,6 +68,25 @@ class Log():
|
|
67
68
|
contents = self.read()
|
68
69
|
return self.build_raw_events(contents)
|
69
70
|
|
71
|
+
@property
|
72
|
+
def scenario_inverted_index(self):
|
73
|
+
index = {}
|
74
|
+
|
75
|
+
def handle_snapshot(snapshot: RequestSnapshot):
|
76
|
+
request_uuid = snapshot.uuid
|
77
|
+
if not request_uuid in index:
|
78
|
+
index[request_uuid] = []
|
79
|
+
|
80
|
+
index[request_uuid].append(event.resource_uuid)
|
81
|
+
|
82
|
+
for event in self.target_events:
|
83
|
+
if not event.is_scenario():
|
84
|
+
continue
|
85
|
+
|
86
|
+
event.snapshot().iter_request_snapshots(handle_snapshot)
|
87
|
+
|
88
|
+
return index
|
89
|
+
|
70
90
|
@property
|
71
91
|
def unprocessed_events(self) -> List[LogEvent]:
|
72
92
|
events = self.events
|
@@ -197,12 +217,18 @@ class Log():
|
|
197
217
|
|
198
218
|
resource_index[event.resource_uuid].append(event)
|
199
219
|
|
220
|
+
scenario_inverted_index = self.scenario_inverted_index
|
221
|
+
|
200
222
|
pruned_events = self.collapse(events)
|
201
223
|
for event in pruned_events:
|
202
224
|
snapshot = event.snapshot()
|
203
225
|
snapshot_exists = snapshot.exists
|
204
226
|
|
205
227
|
if event.action == DELETE_ACTION or not snapshot_exists:
|
228
|
+
if event.is_request() and event.resource_uuid in scenario_inverted_index:
|
229
|
+
# If a request is deleted, only prune if it's not also a part of a scenario
|
230
|
+
continue
|
231
|
+
|
206
232
|
Logger.instance(LOG_ID).info(f"{bcolors.OKBLUE}Removing{bcolors.ENDC} {event.resource} {event.resource_uuid}")
|
207
233
|
|
208
234
|
resource_events: List[LogEvent] = resource_index[event.resource_uuid]
|
@@ -218,8 +244,16 @@ class Log():
|
|
218
244
|
removed_events[event.uuid] = True
|
219
245
|
|
220
246
|
if event.action == DELETE_ACTION and snapshot_exists:
|
221
|
-
if
|
247
|
+
if dry_run:
|
248
|
+
continue
|
249
|
+
|
250
|
+
if event.is_scenario():
|
251
|
+
# We still need to check each request in a scenario to make sure another scenario does not depend on it
|
252
|
+
snapshot.remove(lambda snapshot: self.remove_request_snapshot(snapshot, scenario_inverted_index))
|
253
|
+
elif event.is_request():
|
254
|
+
# We have already checked that a scenario does not depend on the request above
|
222
255
|
snapshot.remove()
|
256
|
+
|
223
257
|
Logger.instance(LOG_ID).info(f"Removing {event.resource} snapshot")
|
224
258
|
|
225
259
|
def build_raw_events(self, contents: str) -> List[str]:
|
@@ -242,6 +276,8 @@ class Log():
|
|
242
276
|
'''
|
243
277
|
Remove DELETE events where the last processed event was a PUT
|
244
278
|
'''
|
279
|
+
|
280
|
+
# Build an index such that if the last event is DELETE_ACTION, then it will NOT exist in the index
|
245
281
|
index = {}
|
246
282
|
for event in processed_events:
|
247
283
|
if event.action == PUT_ACTION:
|
@@ -249,10 +285,18 @@ class Log():
|
|
249
285
|
elif event.action == DELETE_ACTION:
|
250
286
|
if event.resource_uuid in index:
|
251
287
|
del index[event.resource_uuid]
|
288
|
+
|
289
|
+
scenario_inverted_index = self.scenario_inverted_index
|
290
|
+
|
291
|
+
def keep(e: LogEvent):
|
292
|
+
if e.action != DELETE_ACTION:
|
293
|
+
return True
|
294
|
+
|
295
|
+
return e.action == DELETE_ACTION and e.is_request() and e.resource_uuid in scenario_inverted_index
|
252
296
|
|
253
297
|
return list(
|
254
298
|
filter(
|
255
|
-
|
299
|
+
keep,
|
256
300
|
unprocessed_events
|
257
301
|
)
|
258
302
|
)
|
@@ -289,6 +333,12 @@ class Log():
|
|
289
333
|
remaining_events = self.remove_dangling_events(processed_events, unprocessed_events)
|
290
334
|
return list(filter(lambda e: e.uuid not in remaining_version_uuids, remaining_events))
|
291
335
|
|
336
|
+
def remove_request_snapshot(self, snapshot: RequestSnapshot, scenario_inverted_index: dict = None):
|
337
|
+
scenario_inverted_index = scenario_inverted_index or self.scenario_inverted_index
|
338
|
+
|
339
|
+
if snapshot.uuid not in scenario_inverted_index:
|
340
|
+
snapshot.remove()
|
341
|
+
|
292
342
|
# Rotate log to history
|
293
343
|
def rotate(self):
|
294
344
|
if not os.path.exists(self.__log_file_path):
|
@@ -1,7 +1,6 @@
|
|
1
1
|
import json
|
2
2
|
import os
|
3
3
|
import pdb
|
4
|
-
import shutil
|
5
4
|
|
6
5
|
from typing import Callable, List
|
7
6
|
|
@@ -128,12 +127,12 @@ class ScenarioSnapshot(Snapshot):
|
|
128
127
|
if os.path.exists(metadata_file_path):
|
129
128
|
os.remove(metadata_file_path)
|
130
129
|
|
131
|
-
def remove_requests(self):
|
130
|
+
def remove_requests(self, handle_remove_request_snapshot = None):
|
132
131
|
requests_file_path = self.requests_path
|
133
132
|
|
134
133
|
if os.path.exists(requests_file_path):
|
135
134
|
# A request only every belongs to one scenario
|
136
|
-
self.iter_request_snapshots(self.__handle_remove_requests)
|
135
|
+
self.iter_request_snapshots(handle_remove_request_snapshot or self.__handle_remove_requests)
|
137
136
|
|
138
137
|
os.remove(requests_file_path)
|
139
138
|
|
@@ -14,15 +14,17 @@ def snapshot_request(request: Request, **options: RequestSnapshotOptions):
|
|
14
14
|
return
|
15
15
|
|
16
16
|
snapshot = RequestSnapshot(request.uuid)
|
17
|
-
|
18
17
|
snapshot.backup()
|
19
18
|
|
19
|
+
log = Log()
|
20
|
+
|
20
21
|
if action == PUT_ACTION:
|
21
22
|
snapshot.write(request, **options)
|
22
23
|
elif action == DELETE_ACTION:
|
23
|
-
|
24
|
+
inverted_scenario_index = log.scenario_inverted_index
|
24
25
|
|
25
|
-
|
26
|
+
# If a scenario currently depends on this request, we can't remove the snapshot until the scenario is also removed
|
27
|
+
log.remove_request_snapshot(snapshot, inverted_scenario_index)
|
26
28
|
|
27
29
|
try:
|
28
30
|
if action == PUT_ACTION:
|
@@ -40,7 +42,6 @@ def snapshot_scenario(scenario: Scenario, **options):
|
|
40
42
|
return
|
41
43
|
|
42
44
|
snapshot = ScenarioSnapshot(scenario.uuid)
|
43
|
-
|
44
45
|
snapshot.backup_metadata()
|
45
46
|
|
46
47
|
if action == PUT_ACTION:
|
@@ -50,13 +51,13 @@ def snapshot_scenario(scenario: Scenario, **options):
|
|
50
51
|
|
51
52
|
snapshot.backup_requests()
|
52
53
|
|
54
|
+
log = Log()
|
55
|
+
inverted_scenario_index = log.scenario_inverted_index
|
53
56
|
if action == PUT_ACTION:
|
54
|
-
snapshot.remove_requests()
|
57
|
+
snapshot.remove_requests(lambda snapshot: log.remove_request_snapshot(snapshot, inverted_scenario_index))
|
55
58
|
snapshot.write_requests(scenario, **options)
|
56
59
|
elif action == DELETE_ACTION:
|
57
|
-
snapshot.remove_requests()
|
58
|
-
|
59
|
-
log = Log()
|
60
|
+
snapshot.remove_requests(lambda snapshot: log.remove_request_snapshot(snapshot, inverted_scenario_index))
|
60
61
|
|
61
62
|
if action == PUT_ACTION:
|
62
63
|
log.put(scenario)
|
@@ -1,5 +1,7 @@
|
|
1
1
|
import pdb
|
2
2
|
|
3
|
+
from typing import List
|
4
|
+
|
3
5
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.log import Log
|
4
6
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.request_snapshot import RequestSnapshot
|
5
7
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.scenario_snapshot import ScenarioSnapshot
|
@@ -71,6 +73,7 @@ class Apply():
|
|
71
73
|
if results:
|
72
74
|
status = results[1]
|
73
75
|
if status == 0 or status >= 400:
|
76
|
+
self.__logger(f"{bcolors.FAIL}Error{bcolors.ENDC} {results[0]}")
|
74
77
|
completed = False
|
75
78
|
break
|
76
79
|
|
@@ -218,14 +221,16 @@ class Apply():
|
|
218
221
|
|
219
222
|
snapshot_requests = {}
|
220
223
|
|
221
|
-
request_snapshots = snapshot.request_snapshots
|
224
|
+
request_snapshots: List[RequestSnapshot] = snapshot.request_snapshots
|
222
225
|
for request_snapshot in request_snapshots:
|
223
226
|
raw_request = request_snapshot.request
|
224
|
-
|
225
|
-
toks = raw_request.split(REQUEST_STRING_CLRF, 1)
|
226
227
|
|
228
|
+
if not raw_request:
|
229
|
+
return f"{request_snapshot.path} is missing", 400
|
230
|
+
|
231
|
+
toks = raw_request.split(REQUEST_STRING_CLRF, 1)
|
227
232
|
if len(toks) != 2:
|
228
|
-
return f"{
|
233
|
+
return f"{request_snapshot.path} contains an invalid request", 400
|
229
234
|
|
230
235
|
uuid = request_snapshot.uuid
|
231
236
|
res, status = self.__put_request(uuid, raw_request, scenario_id=scenario['id'])
|
@@ -547,4 +547,146 @@ class TestApply():
|
|
547
547
|
recreated_scenario = Scenario.find_by(uuid=created_scenario.uuid)
|
548
548
|
assert recreated_scenario
|
549
549
|
|
550
|
-
assert len(recreated_scenario.requests) == 0
|
550
|
+
assert len(recreated_scenario.requests) == 0
|
551
|
+
|
552
|
+
class TestWhenDeletingRequestWhileReferenced():
|
553
|
+
|
554
|
+
class TestWhenRemoveScenarioRequest():
|
555
|
+
'''
|
556
|
+
1. Create scenario
|
557
|
+
2. Add 2 requests to it
|
558
|
+
3. Snapshot scenario
|
559
|
+
4. Snapshot requests with action DELETE_ACTION
|
560
|
+
5. Apply
|
561
|
+
6. Expect scenario to have 1 request
|
562
|
+
'''
|
563
|
+
|
564
|
+
@pytest.fixture(scope='class')
|
565
|
+
def created_scenario(self, runner: CliRunner):
|
566
|
+
create_result = runner.invoke(scenario, ['create', 'test'])
|
567
|
+
assert create_result.exit_code == 0
|
568
|
+
return Scenario.last()
|
569
|
+
|
570
|
+
@pytest.fixture(scope='class', autouse=True)
|
571
|
+
def created_scenario_requests(self, runner: CliRunner, created_scenario: Scenario):
|
572
|
+
record_result = runner.invoke(record, ['--scenario-key', created_scenario.key(), DETERMINISTIC_GET_REQUEST_URL])
|
573
|
+
assert record_result.exit_code == 0
|
574
|
+
|
575
|
+
record_result = runner.invoke(record, ['--scenario-key', created_scenario.key(), NON_DETERMINISTIC_GET_REQUEST_URL])
|
576
|
+
assert record_result.exit_code == 0
|
577
|
+
|
578
|
+
return created_scenario.requests
|
579
|
+
|
580
|
+
@pytest.fixture(scope='class', autouse=True)
|
581
|
+
def delete_event(self, runner: CliRunner, created_scenario: Scenario, created_scenario_requests: List[Request]):
|
582
|
+
snapshot_result = runner.invoke(scenario, ['snapshot', created_scenario.key()])
|
583
|
+
assert snapshot_result.exit_code == 0
|
584
|
+
|
585
|
+
time.sleep(0.5) # So events do not have the same uuid
|
586
|
+
|
587
|
+
created_request = created_scenario_requests[1]
|
588
|
+
snapshot_result = runner.invoke(request, ['snapshot', created_request.key(), '--action', DELETE_ACTION])
|
589
|
+
assert snapshot_result.exit_code == 0
|
590
|
+
|
591
|
+
log = Log()
|
592
|
+
events = log.events
|
593
|
+
return events[len(events) - 1]
|
594
|
+
|
595
|
+
@pytest.fixture(scope='class')
|
596
|
+
def apply_result(self, runner: CliRunner, created_scenario: Scenario):
|
597
|
+
created_scenario = Scenario.find(created_scenario.id)
|
598
|
+
assert created_scenario.requests_count == 2
|
599
|
+
apply_result = runner.invoke(snapshot, ['apply'])
|
600
|
+
|
601
|
+
return apply_result
|
602
|
+
|
603
|
+
def test_it_updates_scenario(self, created_scenario: Scenario, apply_result):
|
604
|
+
assert apply_result.exit_code == 0
|
605
|
+
|
606
|
+
created_scenario = Scenario.find(created_scenario.id)
|
607
|
+
assert created_scenario.requests_count == 1
|
608
|
+
|
609
|
+
def test_it_maintains_requests(self, created_scenario: Scenario, created_scenario_requests: List[Request]):
|
610
|
+
created_scenario = Scenario.find(created_scenario.id)
|
611
|
+
assert len(created_scenario.requests) == 1
|
612
|
+
|
613
|
+
requests = created_scenario.requests
|
614
|
+
|
615
|
+
assert_orm_request_equivalent(requests[0], created_scenario_requests[0])
|
616
|
+
|
617
|
+
class TestWhenMovingScenarioRequest():
|
618
|
+
'''
|
619
|
+
1. Create scenario one and scenario two
|
620
|
+
2. Add 1 request to scenario one
|
621
|
+
3. Snapshot scenario one
|
622
|
+
4. Move scenario one request to scenario two
|
623
|
+
5. Snapshot scenario two
|
624
|
+
5. Apply
|
625
|
+
6. Expect scenario one to have 0 requests
|
626
|
+
7. Expect scenario two to have 1 request
|
627
|
+
'''
|
628
|
+
|
629
|
+
@pytest.fixture(scope='class')
|
630
|
+
def created_scenario_one(self, runner: CliRunner):
|
631
|
+
create_result = runner.invoke(scenario, ['create', 'test1'])
|
632
|
+
assert create_result.exit_code == 0
|
633
|
+
return Scenario.last()
|
634
|
+
|
635
|
+
@pytest.fixture(scope='class')
|
636
|
+
def created_scenario_two(self, runner: CliRunner):
|
637
|
+
create_result = runner.invoke(scenario, ['create', 'test2'])
|
638
|
+
assert create_result.exit_code == 0
|
639
|
+
return Scenario.last()
|
640
|
+
|
641
|
+
@pytest.fixture(scope='class', autouse=True)
|
642
|
+
def created_scenario_request(self, runner: CliRunner, created_scenario_one: Scenario):
|
643
|
+
record_result = runner.invoke(record, ['--scenario-key', created_scenario_one.key(), DETERMINISTIC_GET_REQUEST_URL])
|
644
|
+
assert record_result.exit_code == 0
|
645
|
+
|
646
|
+
return created_scenario_one.requests[0]
|
647
|
+
|
648
|
+
@pytest.fixture(scope='class', autouse=True)
|
649
|
+
def put_event_one(self, runner: CliRunner, created_scenario_one: Scenario, created_scenario_request: Request):
|
650
|
+
snapshot_result = runner.invoke(scenario, ['snapshot', created_scenario_one.key()])
|
651
|
+
assert snapshot_result.exit_code == 0
|
652
|
+
|
653
|
+
log = Log()
|
654
|
+
events = log.events
|
655
|
+
return events[len(events) - 1]
|
656
|
+
|
657
|
+
@pytest.fixture(scope='class', autouse=True)
|
658
|
+
def put_event_two(self, runner: CliRunner, created_scenario_two: Scenario, created_scenario_request: Request):
|
659
|
+
created_scenario_request.update(scenario_id=created_scenario_two.id)
|
660
|
+
|
661
|
+
snapshot_result = runner.invoke(scenario, ['snapshot', created_scenario_two.key()])
|
662
|
+
assert snapshot_result.exit_code == 0
|
663
|
+
|
664
|
+
log = Log()
|
665
|
+
events = log.events
|
666
|
+
return events[len(events) - 1]
|
667
|
+
|
668
|
+
@pytest.fixture(scope='class')
|
669
|
+
def apply_result(self, runner: CliRunner):
|
670
|
+
apply_result = runner.invoke(snapshot, ['apply'])
|
671
|
+
|
672
|
+
return apply_result
|
673
|
+
|
674
|
+
def test_it_removes_request_from_scenario_one(self, created_scenario_one: Scenario, apply_result):
|
675
|
+
assert apply_result.exit_code == 0
|
676
|
+
|
677
|
+
created_scenario_one = Scenario.find(created_scenario_one.id)
|
678
|
+
assert created_scenario_one.requests_count == 0
|
679
|
+
|
680
|
+
def test_it_adds_request_to_scenario_two(self, created_scenario_two: Scenario, apply_result):
|
681
|
+
assert apply_result.exit_code == 0
|
682
|
+
|
683
|
+
created_scenario_two = Scenario.find(created_scenario_two.id)
|
684
|
+
assert created_scenario_two.requests_count == 1
|
685
|
+
|
686
|
+
def test_it_maintains_requests(self, created_scenario_two: Scenario, created_scenario_request):
|
687
|
+
created_scenario_two = Scenario.find(created_scenario_two.id)
|
688
|
+
assert len(created_scenario_two.requests) == 1
|
689
|
+
|
690
|
+
requests = created_scenario_two.requests
|
691
|
+
|
692
|
+
assert_orm_request_equivalent(requests[0], created_scenario_request)
|
@@ -3,12 +3,14 @@ import pytest
|
|
3
3
|
import time
|
4
4
|
|
5
5
|
from click.testing import CliRunner
|
6
|
+
from typing import List
|
6
7
|
|
7
8
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.log import Log
|
8
9
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.log_event import DELETE_ACTION, LogEvent
|
9
|
-
from stoobly_agent.cli import record, request, snapshot
|
10
|
+
from stoobly_agent.cli import record, request, scenario, snapshot
|
10
11
|
from stoobly_agent.lib.orm.request import Request
|
11
|
-
from stoobly_agent.
|
12
|
+
from stoobly_agent.lib.orm.scenario import Scenario
|
13
|
+
from stoobly_agent.test.test_helper import assert_orm_request_equivalent, DETERMINISTIC_GET_REQUEST_URL, NON_DETERMINISTIC_GET_REQUEST_URL, reset
|
12
14
|
|
13
15
|
@pytest.fixture(scope='module')
|
14
16
|
def runner():
|
@@ -107,4 +109,71 @@ class TestPrune():
|
|
107
109
|
|
108
110
|
apply_result = runner.invoke(snapshot, ['prune'])
|
109
111
|
assert apply_result.exit_code == 0
|
110
|
-
assert len(log.events) == 0
|
112
|
+
assert len(log.events) == 0
|
113
|
+
|
114
|
+
class TestWhenRemoveScenarioRequest():
|
115
|
+
'''
|
116
|
+
1. Create scenario
|
117
|
+
2. Add 2 requests to it
|
118
|
+
3. Snapshot scenario
|
119
|
+
4. Snapshot request with action DELETE_ACTION
|
120
|
+
5. Prune, but because scenario depends on the request, should not be able to prune
|
121
|
+
6. Apply
|
122
|
+
7. Expect scenario to have 1 request
|
123
|
+
'''
|
124
|
+
|
125
|
+
@pytest.fixture(scope='class')
|
126
|
+
def created_scenario(self, runner: CliRunner):
|
127
|
+
create_result = runner.invoke(scenario, ['create', 'test'])
|
128
|
+
assert create_result.exit_code == 0
|
129
|
+
return Scenario.last()
|
130
|
+
|
131
|
+
@pytest.fixture(scope='class', autouse=True)
|
132
|
+
def created_scenario_requests(self, runner: CliRunner, created_scenario: Scenario):
|
133
|
+
record_result = runner.invoke(record, ['--scenario-key', created_scenario.key(), DETERMINISTIC_GET_REQUEST_URL])
|
134
|
+
assert record_result.exit_code == 0
|
135
|
+
|
136
|
+
record_result = runner.invoke(record, ['--scenario-key', created_scenario.key(), NON_DETERMINISTIC_GET_REQUEST_URL])
|
137
|
+
assert record_result.exit_code == 0
|
138
|
+
|
139
|
+
return created_scenario.requests
|
140
|
+
|
141
|
+
@pytest.fixture(scope='class', autouse=True)
|
142
|
+
def delete_event(self, runner: CliRunner, created_scenario: Scenario, created_scenario_requests: List[Request]):
|
143
|
+
snapshot_result = runner.invoke(scenario, ['snapshot', created_scenario.key()])
|
144
|
+
assert snapshot_result.exit_code == 0
|
145
|
+
|
146
|
+
time.sleep(0.5) # So events do not have the same uuid
|
147
|
+
|
148
|
+
created_request = created_scenario_requests[1]
|
149
|
+
snapshot_result = runner.invoke(request, ['snapshot', created_request.key(), '--action', DELETE_ACTION])
|
150
|
+
assert snapshot_result.exit_code == 0
|
151
|
+
|
152
|
+
log = Log()
|
153
|
+
events = log.events
|
154
|
+
return events[len(events) - 1]
|
155
|
+
|
156
|
+
@pytest.fixture(scope='class')
|
157
|
+
def apply_result(self, runner: CliRunner, created_scenario: Scenario):
|
158
|
+
prune_result = runner.invoke(snapshot, ['prune'])
|
159
|
+
assert prune_result.exit_code == 0
|
160
|
+
|
161
|
+
created_scenario = Scenario.find(created_scenario.id)
|
162
|
+
assert created_scenario.requests_count == 2
|
163
|
+
apply_result = runner.invoke(snapshot, ['apply'])
|
164
|
+
|
165
|
+
return apply_result
|
166
|
+
|
167
|
+
def test_it_updates_scenario(self, created_scenario: Scenario, apply_result):
|
168
|
+
assert apply_result.exit_code == 0
|
169
|
+
|
170
|
+
created_scenario = Scenario.find(created_scenario.id)
|
171
|
+
assert created_scenario.requests_count == 1
|
172
|
+
|
173
|
+
def test_it_maintains_requests(self, created_scenario: Scenario, created_scenario_requests: List[Request]):
|
174
|
+
created_scenario = Scenario.find(created_scenario.id)
|
175
|
+
assert len(created_scenario.requests) == 1
|
176
|
+
|
177
|
+
requests = created_scenario.requests
|
178
|
+
|
179
|
+
assert_orm_request_equivalent(requests[0], created_scenario_requests[0])
|
@@ -0,0 +1 @@
|
|
1
|
+
1.9.0
|
@@ -1 +0,0 @@
|
|
1
|
-
1.8.5
|
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.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/query_params_controller.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/api/replayed_responses_controller.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.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.9.0 → stoobly_agent-1.9.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
|
File without changes
|
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/handlers/request_cli_handler.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/handlers/scenario_cli_handler.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/certificate_authority.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoint_facade.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_apply_context.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_apply_service.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_mock_service.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_replay_service.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_test_service.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/iterate_group_by.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
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/run_command_service.py
RENAMED
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/scenario_facade.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/tabulate_print_service.py
RENAMED
File without changes
|
File without changes
|
{stoobly_agent-1.9.0 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/test_replay_context.py
RENAMED
File without changes
|