pyopenapi-gen 0.15.0__tar.gz → 0.17.0__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.
Potentially problematic release.
This version of pyopenapi-gen might be problematic. Click here for more details.
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/claude.yml +22 -6
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/semantic-release.yml +27 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/CHANGELOG.md +148 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/CLAUDE.md +233 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/PKG-INFO +1 -1
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/coverage.xml +90 -78
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/input/business_swagger.json +30 -75
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/pyproject.toml +4 -2
- pyopenapi_gen-0.17.0/scripts/sync_version_to_init.py +139 -0
- pyopenapi_gen-0.17.0/src/pyopenapi_gen/__init__.py +223 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/parameters/parser.py +3 -3
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/postprocess_manager.py +8 -8
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/telemetry.py +5 -3
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/resolvers/schema_resolver.py +1 -0
- pyopenapi_gen-0.17.0/tests/api/test_programmatic_api.py +328 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_schema_resolver.py +32 -0
- pyopenapi_gen-0.15.0/src/pyopenapi_gen/__init__.py +0 -114
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.bandit +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.cursor/mcp.json +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.cursor/rules/architecture.mdc +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.cursor/rules/coding-conventions.mdc +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.cursor/rules/project-goal.mdc +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.cursor/rules/testing.mdc +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/BRANCH_PROTECTION.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/CLAUDE_CONFIGURATION.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/CODEOWNERS +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/ISSUE_TEMPLATE/bug_report.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/ISSUE_TEMPLATE/feature_request.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/dependabot.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/ci.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/claude-auto-approve.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/claude-review-trigger.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/pr-checks.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/production-release.yml.backup +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/promote-to-staging.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/staging-publish.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.github/workflows/testpypi-publish.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.gitignore +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.python-version +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/.vscode/settings.json +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/CONTRIBUTING.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/LICENSE +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/Makefile +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/README.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/README.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/architecture.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/endpoint_visitor.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/helpers.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/ir_models.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/line_writer.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/loader.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/model_visitor.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/release-automation.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/render_context.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/docs/unified_type_resolution.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/input/minimal_swagger.json +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/input/minimal_syntax_test.json +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/input/test_name_collision_spec.json +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/mkdocs.yml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/poetry.lock +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/scripts/validate_version_sync.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/__main__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/cli.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/context/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/context/file_manager.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/context/import_collector.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/context/render_context.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/auth/base.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/auth/plugins.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/exceptions.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/http_status_codes.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/http_transport.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/loader.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/operations/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/operations/parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/operations/post_processor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/operations/request_body.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/parameters/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/responses/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/responses/parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/schemas/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/loader/schemas/extractor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/pagination.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/cyclic_properties.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/direct_cycle.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/existing_schema.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/list_response.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/missing_ref.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/new_schema.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/helpers/stripped_suffix.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/ref_resolution/resolve_schema_ref.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/common/type_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/context.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/cycle_helpers.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/keywords/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/keywords/all_of_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/keywords/any_of_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/keywords/array_items_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/keywords/one_of_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/keywords/properties_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/schema_finalizer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/schema_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/transformers/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/transformers/inline_enum_extractor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/transformers/inline_object_promoter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/parsing/unified_cycle_detection.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/schemas.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/streaming_helpers.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/warning_collector.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/writers/code_writer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/writers/documentation_writer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/writers/line_writer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core/writers/python_construct_renderer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/core_package_template/README.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emit/models_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/client_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/core_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/docs_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/endpoints_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/exceptions_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/emitters/models_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/generator/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/generator/client_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/endpoint_utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_cleaner.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_helper.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/array_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/composition_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/finalizer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/named_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/object_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/primitive_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/type_resolution/resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/helpers/url_utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/http_types.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/ir.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/py.typed +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/contracts/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/contracts/protocols.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/contracts/types.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/resolvers/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/resolvers/reference_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/resolvers/response_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/services/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/services/type_service.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/strategies/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/types/strategies/response_strategy.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/CLAUDE.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/client_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/docs_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/endpoint_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/docstring_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/endpoint_method_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/request_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/response_handler_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/signature_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/generators/url_args_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/processors/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/processors/import_analyzer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/endpoint/processors/parameter_processor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/exception_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/model/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/model/alias_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/model/dataclass_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/model/enum_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/model/model_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/src/pyopenapi_gen/visit/visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/auth/auth_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/auth/test_auth_base.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/auth/test_auth_plugins.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/cli/cli_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/cli/test_cli_backup_diff.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/cli/test_cli_edge_cases.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/cli/test_cli_edge_cases_comprehensive.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/cli/test_cli_internal_utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/cli/test_http_pagination_cli.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/context_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/test_core_import_path.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/test_file_manager.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/test_import_collector.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/test_render_context.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/test_render_context_imports.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/context/test_render_context_relative_paths.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/core_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/loader/parameters/test_inline_enum_array_params.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/loader/test_extractor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/loader/test_top_level_enum_extraction.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/helpers_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_cyclic_properties.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_direct_cycle.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_existing_schema.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_list_response.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_missing_ref.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_new_schema.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/common/ref_resolution/helpers/test_stripped_suffix.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/keywords_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/test_all_of_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/test_any_of_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/test_array_items_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/test_one_of_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/keywords/test_properties_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/parsing_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_context.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_cycle_detection.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_cycle_helpers.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_improved_schema_naming.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_inline_enum_extractor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_inline_object_promoter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_logging.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_ref_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_schema_finalizer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_schema_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_schema_parser_list_response.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/parsing/test_type_parser.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_dataclass_serialization.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_detect_circular_imports.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_edge_cases_integration.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_edge_cases_systematic.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_exceptions_module.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_forward_references.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_http_transport.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_import_resolution.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_ir.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_ir_schema.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_loader.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_loader_extensive.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_loader_invalid_refs.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_loader_malformed.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_loader_media_types.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_pagination.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_parsing_context.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_protocol_defaults.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_schema_parser_specific_case.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_schemas.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_simple_self_ref_check.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_streaming_helpers.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_telemetry.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_telemetry_client.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/test_warning_collector.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/writers/test_code_writer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/writers/test_documentation_writer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/writers/test_line_writer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/writers/test_python_construct_renderer_json_wizard.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/core/writers/writers_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/emitters_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_client_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_docs_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_duplicate_operations.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_endpoints_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_exceptions_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_list_response_generation.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/emitters/test_models_emitter.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/end_to_end/test_dataclass_serialization_e2e.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/examples/test_developer_experience_demo.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/generation/generation_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/generation/test_external_core_package.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/generation_issues/specs/minimal_addmessage_like.json +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/generation_issues/test_addmessage_like_issues.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/generation_issues/test_agent_include_parameter_typing.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/generation_issues/test_message_batch_response_issue.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/helpers_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_array_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_endpoint_utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_endpoint_utils_extended.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_get_endpoint_return_types.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_named_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_named_type_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_object_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_put_endpoint_return_types.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_type_cleaner.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_type_helper.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_url_utils.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/helpers/test_utils_helpers.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/integration/test_generated_code_structure.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/integrations/integrations_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/integrations/test_business_swagger_message_type.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/integrations/test_end_to_end_business_swagger.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/integrations/test_end_to_end_petstore.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/integrations/test_name_collisions.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/specs/response_unwrapping_spec.yaml +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/test_analysis_overview.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/test_init.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_business_swagger_integration.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_contracts_types.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_missing_imports_bug.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_reference_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_response_resolver.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_response_strategy.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_response_strategy_simplified.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_schema_resolver_enums.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/types/test_type_service.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/generators_analysis.md +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_dataclass_integration.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_docstring_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_endpoint_method_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_match_case_response.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_request_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_response_handler_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_response_handler_generator_strategy.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_signature_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/generators/test_url_args_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/processors/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/processors/test_import_analyzer.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/processors/test_import_analyzer.py.bak +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/processors/test_parameter_processor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/endpoint/test_endpoint_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/__init__.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/test_alias_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/test_dataclass_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/test_dataclass_generator_json_wizard.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/test_enum_generator.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/test_json_value_integration.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/model/test_json_value_wrapper.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/test_client_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/test_model_visitor.py +0 -0
- {pyopenapi_gen-0.15.0 → pyopenapi_gen-0.17.0}/tests/visit/test_visitor.py +0 -0
|
@@ -44,17 +44,33 @@ jobs:
|
|
|
44
44
|
anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}
|
|
45
45
|
direct_prompt: |
|
|
46
46
|
Review this PR for code quality, security, and compatibility:
|
|
47
|
-
|
|
47
|
+
|
|
48
|
+
**IMPORTANT: DO NOT run quality gates (formatting, linting, tests, type checking)**
|
|
49
|
+
The CI pipeline already handles: Black, Ruff, mypy, Bandit, and pytest.
|
|
50
|
+
Focus on code logic, architecture, and security only.
|
|
51
|
+
|
|
48
52
|
**For hotfixes and minor fixes:**
|
|
49
|
-
1. If code
|
|
53
|
+
1. If code logic is sound and architecture is good, fix any issues directly
|
|
50
54
|
2. Provide detailed analysis in comments
|
|
51
55
|
3. Note if manual approval is recommended
|
|
52
|
-
|
|
56
|
+
|
|
53
57
|
**For larger changes:**
|
|
54
|
-
1. Provide comprehensive review feedback
|
|
58
|
+
1. Provide comprehensive review feedback on logic and architecture
|
|
55
59
|
2. Create issues for complex problems
|
|
56
60
|
3. Suggest improvements and alternatives
|
|
57
|
-
|
|
58
|
-
Focus on
|
|
61
|
+
|
|
62
|
+
**Focus on:**
|
|
63
|
+
- Code logic and correctness
|
|
64
|
+
- Security vulnerabilities and best practices
|
|
65
|
+
- Architecture decisions and design patterns
|
|
66
|
+
- API compatibility and breaking changes
|
|
67
|
+
- Algorithm efficiency and performance implications
|
|
68
|
+
|
|
69
|
+
**Skip (CI handles these):**
|
|
70
|
+
- Formatting checks (Black)
|
|
71
|
+
- Linting (Ruff)
|
|
72
|
+
- Type checking (mypy)
|
|
73
|
+
- Security scanning (Bandit)
|
|
74
|
+
- Test execution (pytest)
|
|
59
75
|
timeout_minutes: 60
|
|
60
76
|
|
|
@@ -97,6 +97,33 @@ jobs:
|
|
|
97
97
|
git config user.email "github-actions[bot]@users.noreply.github.com"
|
|
98
98
|
poetry run semantic-release version --skip-build
|
|
99
99
|
|
|
100
|
+
- name: Sync version to __init__.py
|
|
101
|
+
if: steps.check_changes.outputs.release_worthy > 0 || github.event_name == 'workflow_dispatch'
|
|
102
|
+
env:
|
|
103
|
+
GH_TOKEN: ${{ secrets.SEMANTIC_RELEASE_TOKEN || secrets.GITHUB_TOKEN }}
|
|
104
|
+
run: |
|
|
105
|
+
echo "🔄 Syncing version from pyproject.toml to __init__.py..."
|
|
106
|
+
|
|
107
|
+
# Fetch latest to ensure we have the semantic-release commit
|
|
108
|
+
git fetch origin main
|
|
109
|
+
git reset --hard origin/main
|
|
110
|
+
|
|
111
|
+
# Run sync script
|
|
112
|
+
poetry run python scripts/sync_version_to_init.py
|
|
113
|
+
|
|
114
|
+
# Check if __init__.py was modified
|
|
115
|
+
if git diff --quiet src/pyopenapi_gen/__init__.py; then
|
|
116
|
+
echo "✅ __init__.py already in sync, no changes needed"
|
|
117
|
+
else
|
|
118
|
+
echo "📝 __init__.py was updated, creating follow-up commit..."
|
|
119
|
+
git config user.name "github-actions[bot]"
|
|
120
|
+
git config user.email "github-actions[bot]@users.noreply.github.com"
|
|
121
|
+
git add src/pyopenapi_gen/__init__.py
|
|
122
|
+
git commit -m "chore(release): sync __init__.py version [skip ci]"
|
|
123
|
+
git push origin main
|
|
124
|
+
echo "✅ Version sync complete and committed"
|
|
125
|
+
fi
|
|
126
|
+
|
|
100
127
|
- name: Build packages after version bump
|
|
101
128
|
if: steps.check_changes.outputs.release_worthy > 0 || github.event_name == 'workflow_dispatch'
|
|
102
129
|
run: |
|
|
@@ -1,6 +1,154 @@
|
|
|
1
1
|
# CHANGELOG
|
|
2
2
|
|
|
3
3
|
|
|
4
|
+
## v0.17.0 (2025-10-13)
|
|
5
|
+
|
|
6
|
+
### Chores
|
|
7
|
+
|
|
8
|
+
- **release**: Sync __init__.py version [skip ci]
|
|
9
|
+
([`287f52a`](https://github.com/mindhiveoy/pyopenapi_gen/commit/287f52aeea6de427fb0c3bd8014e5317a9052369))
|
|
10
|
+
|
|
11
|
+
### Features
|
|
12
|
+
|
|
13
|
+
- **ci**: Optimize Claude Code workflow and enable bot releases
|
|
14
|
+
([`c2efbfa`](https://github.com/mindhiveoy/pyopenapi_gen/commit/c2efbfa17f29ab040412935cf758c6c92cb1569a))
|
|
15
|
+
|
|
16
|
+
1. Claude Code Workflow Optimization: - Instruct Claude to skip quality gates (formatting, linting,
|
|
17
|
+
tests, type checking) - CI pipeline already handles: Black, Ruff, mypy, Bandit, pytest - Focus
|
|
18
|
+
Claude on: code logic, security, architecture, API compatibility - Reduces duplicate work and
|
|
19
|
+
speeds up PR reviews
|
|
20
|
+
|
|
21
|
+
2. Semantic-Release Bot Support: - Added allowed_bots = ["dependabot", "renovate"] to pyproject.toml
|
|
22
|
+
- Fixes: "Workflow initiated by non-human actor" error - Enables automated dependency updates to
|
|
23
|
+
trigger releases
|
|
24
|
+
|
|
25
|
+
Benefits: - Faster CI reviews (Claude skips redundant checks) - Better focus (Claude concentrates on
|
|
26
|
+
logic and security) - Automated releases from bot PRs (dependabot, renovate) - Less noise in PR
|
|
27
|
+
reviews
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
## v0.16.1 (2025-10-13)
|
|
31
|
+
|
|
32
|
+
### Bug Fixes
|
|
33
|
+
|
|
34
|
+
- **version**: Manually sync __init__.py to 0.16.0 after failed workflow
|
|
35
|
+
([`7ee9090`](https://github.com/mindhiveoy/pyopenapi_gen/commit/7ee90902add14d93d471418b56514a8bcafd81cb))
|
|
36
|
+
|
|
37
|
+
The semantic-release workflow successfully created version 0.16.0 but failed when trying to push the
|
|
38
|
+
__init__.py sync due to the force-with-lease issue.
|
|
39
|
+
|
|
40
|
+
This commit manually syncs __init__.py to 0.16.0 to match pyproject.toml. Future releases will use
|
|
41
|
+
the new workflow logic with follow-up commits.
|
|
42
|
+
|
|
43
|
+
- **workflow**: Use follow-up commit instead of amending for version sync
|
|
44
|
+
([`96f2014`](https://github.com/mindhiveoy/pyopenapi_gen/commit/96f2014bb10ecbfbe3873db32ea6a5f8334542a2))
|
|
45
|
+
|
|
46
|
+
ISSUE: The git push --force-with-lease was failing with "stale info" because: 1. semantic-release
|
|
47
|
+
creates and pushes a commit 2. Our sync script tried to amend that commit 3. force-with-lease
|
|
48
|
+
detected remote had changed and rejected the push
|
|
49
|
+
|
|
50
|
+
SOLUTION: Changed strategy to use a follow-up commit instead of amending: 1. Fetch latest from
|
|
51
|
+
origin/main after semantic-release pushes 2. Reset --hard to origin/main to sync local state 3.
|
|
52
|
+
Run sync script to update __init__.py 4. If changed, create a NEW commit with [skip ci] flag 5.
|
|
53
|
+
Push normally (no force needed)
|
|
54
|
+
|
|
55
|
+
Benefits: - Safer: No force-pushing required - Cleaner: Normal git flow with proper commit sequence
|
|
56
|
+
- Prevents loops: [skip ci] prevents triggering another workflow run
|
|
57
|
+
|
|
58
|
+
This will result in two commits per release (semantic-release + sync) but is more reliable than
|
|
59
|
+
force-pushing.
|
|
60
|
+
|
|
61
|
+
Fixes: https://github.com/mindhiveoy/pyopenapi_gen/actions/runs/18461834318
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
## v0.16.0 (2025-10-13)
|
|
65
|
+
|
|
66
|
+
### Bug Fixes
|
|
67
|
+
|
|
68
|
+
- **api**: Improve type annotation for generate_client return type
|
|
69
|
+
([`f35d99c`](https://github.com/mindhiveoy/pyopenapi_gen/commit/f35d99c1d2233a20fdd1a69ef0a175ab902513c4))
|
|
70
|
+
|
|
71
|
+
- Change return type from List[Any] to List[Path] for better type safety - Add proper pathlib.Path
|
|
72
|
+
import to support the type annotation - Enhances IDE support and type checking for programmatic
|
|
73
|
+
API users
|
|
74
|
+
|
|
75
|
+
🤖 Generated with [Claude Code](https://claude.ai/code)
|
|
76
|
+
|
|
77
|
+
Co-authored-by: Ville Venäläinen <undefined@users.noreply.github.com>
|
|
78
|
+
|
|
79
|
+
- **api**: Update business_swagger.json descriptions and schemas
|
|
80
|
+
([`6496144`](https://github.com/mindhiveoy/pyopenapi_gen/commit/6496144200fb8dfb28275f0d111138107775fa29))
|
|
81
|
+
|
|
82
|
+
- **lint**: Correct import ordering in __init__.py for Ruff compliance
|
|
83
|
+
([`a159807`](https://github.com/mindhiveoy/pyopenapi_gen/commit/a159807fd1932206dd44c805629683998c88707f))
|
|
84
|
+
|
|
85
|
+
- **release**: Sync __init__.py version automatically in semantic-release workflow
|
|
86
|
+
([`7f28674`](https://github.com/mindhiveoy/pyopenapi_gen/commit/7f2867449be1b75b2fc4b7c04073fcad3320e865))
|
|
87
|
+
|
|
88
|
+
ISSUE: Semantic-release was updating pyproject.toml version but leaving __init__.py at the old
|
|
89
|
+
version, causing the version validation to fail.
|
|
90
|
+
|
|
91
|
+
SOLUTION: 1. Fixed immediate issue: Updated __init__.py to match pyproject.toml (0.15.0) 2. Added
|
|
92
|
+
automatic sync: Created scripts/sync_version_to_init.py to sync version from pyproject.toml to
|
|
93
|
+
__init__.py 3. Updated workflow: Added step after semantic-release version bump that runs the sync
|
|
94
|
+
script and amends the commit if __init__.py was updated
|
|
95
|
+
|
|
96
|
+
This ensures all version files stay synchronized after every semantic-release run.
|
|
97
|
+
|
|
98
|
+
Fixes: https://github.com/mindhiveoy/pyopenapi_gen/actions/runs/18461374998
|
|
99
|
+
|
|
100
|
+
- **security**: Address Bandit security warnings with proper logging and nosec annotations
|
|
101
|
+
([`f9b0ff3`](https://github.com/mindhiveoy/pyopenapi_gen/commit/f9b0ff3e73ebeaaed49fc631429835ee6e99a33c))
|
|
102
|
+
|
|
103
|
+
Fixed all Bandit security warnings: - Replace try-except-pass with proper exception logging in
|
|
104
|
+
parser.py - Replace try-except-pass with logging in telemetry.py - Add nosec B603 annotations to
|
|
105
|
+
all subprocess.run() calls with explanations - Add nosec B404 annotation to subprocess import with
|
|
106
|
+
justification
|
|
107
|
+
|
|
108
|
+
Changes: - parser.py: Log exceptions instead of silent pass for debugging - telemetry.py: Log
|
|
109
|
+
telemetry failures for debugging - postprocess_manager.py: Document all subprocess calls are safe
|
|
110
|
+
(hardcoded commands, no shell)
|
|
111
|
+
|
|
112
|
+
Bandit now reports zero issues (8 properly suppressed with nosec). All quality checks pass.
|
|
113
|
+
|
|
114
|
+
- **types**: Add binary format mapping to unified type resolver
|
|
115
|
+
([`ecba081`](https://github.com/mindhiveoy/pyopenapi_gen/commit/ecba081b37a217277ea61d58b30d1f0a7ac2e04d))
|
|
116
|
+
|
|
117
|
+
- Add 'binary' to format_mapping in OpenAPISchemaResolver._resolve_string() - Ensures string schemas
|
|
118
|
+
with format=binary resolve to bytes type - Adds comprehensive test coverage for binary format
|
|
119
|
+
resolution - Closes gap between legacy and unified type systems
|
|
120
|
+
|
|
121
|
+
Before: string fields with format=binary were typed as str
|
|
122
|
+
|
|
123
|
+
After: string fields with format=binary are correctly typed as bytes
|
|
124
|
+
|
|
125
|
+
### Features
|
|
126
|
+
|
|
127
|
+
- **api**: Add developer-friendly programmatic API with generate_client()
|
|
128
|
+
([`ec8ad0c`](https://github.com/mindhiveoy/pyopenapi_gen/commit/ec8ad0c7b166e9cb523a91d97f8639f050d940c3))
|
|
129
|
+
|
|
130
|
+
Add a clean, function-based API for programmatic usage alongside the existing CLI.
|
|
131
|
+
|
|
132
|
+
Key additions: - generate_client() convenience function for simple library usage - Export
|
|
133
|
+
ClientGenerator and GenerationError at package level - Comprehensive documentation with examples
|
|
134
|
+
in CLAUDE.md - Full test coverage with 9 new tests in tests/api/
|
|
135
|
+
|
|
136
|
+
Benefits: - Simple one-function API: generate_client(spec_path, project_root, output_package) - No
|
|
137
|
+
need to import from deep paths or understand internal structure - Proper error handling with
|
|
138
|
+
exported GenerationError exception - Fully backward compatible - all existing code continues to
|
|
139
|
+
work - Matches patterns from similar tools (openapi-python-client, datamodel-code-generator)
|
|
140
|
+
|
|
141
|
+
Documentation includes: - Basic usage examples - Advanced usage with error handling - Multi-client
|
|
142
|
+
generation scripts - Build system integration examples - Complete API reference
|
|
143
|
+
|
|
144
|
+
All tests pass (9 new + existing), type-safe (mypy strict), and quality checks pass.
|
|
145
|
+
|
|
146
|
+
### Refactoring
|
|
147
|
+
|
|
148
|
+
- **init**: Remove unused HTTPMethod enum and IR dataclasses
|
|
149
|
+
([`7b096ed`](https://github.com/mindhiveoy/pyopenapi_gen/commit/7b096ed321612823976a2e7b7a995d0aaf024312))
|
|
150
|
+
|
|
151
|
+
|
|
4
152
|
## v0.15.0 (2025-10-11)
|
|
5
153
|
|
|
6
154
|
### Bug Fixes
|
|
@@ -605,6 +605,239 @@ pyopenapi-gen api_v2.yaml --project-root . --output-package pyapis.v2 --core-pac
|
|
|
605
605
|
# └── v2/ # Second client
|
|
606
606
|
```
|
|
607
607
|
|
|
608
|
+
## Using as a Library (Programmatic API)
|
|
609
|
+
|
|
610
|
+
### Why Programmatic Usage?
|
|
611
|
+
The generator was designed to work both as a CLI tool and as a Python library. Programmatic usage enables integration with build systems, CI/CD pipelines, code generators, and custom tooling. You get the same powerful code generation capabilities with full Python API access.
|
|
612
|
+
|
|
613
|
+
### What Is the Programmatic API?
|
|
614
|
+
A simple, function-based API that wraps the internal `ClientGenerator` class, providing a clean entry point for library usage without requiring knowledge of internal structure.
|
|
615
|
+
|
|
616
|
+
### How to Use Programmatically
|
|
617
|
+
|
|
618
|
+
#### Basic Usage
|
|
619
|
+
```python
|
|
620
|
+
from pyopenapi_gen import generate_client
|
|
621
|
+
|
|
622
|
+
# Simple client generation
|
|
623
|
+
files = generate_client(
|
|
624
|
+
spec_path="input/openapi.yaml",
|
|
625
|
+
project_root=".",
|
|
626
|
+
output_package="pyapis.my_client"
|
|
627
|
+
)
|
|
628
|
+
|
|
629
|
+
print(f"Generated {len(files)} files")
|
|
630
|
+
```
|
|
631
|
+
|
|
632
|
+
#### Advanced Usage with All Options
|
|
633
|
+
```python
|
|
634
|
+
from pyopenapi_gen import generate_client, GenerationError
|
|
635
|
+
|
|
636
|
+
try:
|
|
637
|
+
files = generate_client(
|
|
638
|
+
spec_path="input/openapi.yaml",
|
|
639
|
+
project_root=".",
|
|
640
|
+
output_package="pyapis.my_client",
|
|
641
|
+
core_package="pyapis.core", # Optional shared core
|
|
642
|
+
force=True, # Overwrite without diff check
|
|
643
|
+
no_postprocess=False, # Run Black + mypy
|
|
644
|
+
verbose=True # Show progress
|
|
645
|
+
)
|
|
646
|
+
|
|
647
|
+
# Process generated files
|
|
648
|
+
for file_path in files:
|
|
649
|
+
print(f"Generated: {file_path}")
|
|
650
|
+
|
|
651
|
+
except GenerationError as e:
|
|
652
|
+
print(f"Generation failed: {e}")
|
|
653
|
+
# Handle error appropriately
|
|
654
|
+
```
|
|
655
|
+
|
|
656
|
+
#### Multi-Client Generation Script
|
|
657
|
+
```python
|
|
658
|
+
from pyopenapi_gen import generate_client
|
|
659
|
+
from pathlib import Path
|
|
660
|
+
|
|
661
|
+
# Configuration for multiple clients
|
|
662
|
+
clients = [
|
|
663
|
+
{
|
|
664
|
+
"spec": "api_v1.yaml",
|
|
665
|
+
"package": "pyapis.client_v1",
|
|
666
|
+
},
|
|
667
|
+
{
|
|
668
|
+
"spec": "api_v2.yaml",
|
|
669
|
+
"package": "pyapis.client_v2",
|
|
670
|
+
},
|
|
671
|
+
]
|
|
672
|
+
|
|
673
|
+
# Shared core package
|
|
674
|
+
core_package = "pyapis.core"
|
|
675
|
+
|
|
676
|
+
# Generate all clients
|
|
677
|
+
for client_config in clients:
|
|
678
|
+
print(f"Generating {client_config['package']}...")
|
|
679
|
+
|
|
680
|
+
generate_client(
|
|
681
|
+
spec_path=client_config["spec"],
|
|
682
|
+
project_root=".",
|
|
683
|
+
output_package=client_config["package"],
|
|
684
|
+
core_package=core_package,
|
|
685
|
+
force=True,
|
|
686
|
+
verbose=True
|
|
687
|
+
)
|
|
688
|
+
|
|
689
|
+
print("All clients generated successfully!")
|
|
690
|
+
```
|
|
691
|
+
|
|
692
|
+
#### Integration with Build Systems
|
|
693
|
+
```python
|
|
694
|
+
# Example: Custom build script
|
|
695
|
+
import sys
|
|
696
|
+
from pathlib import Path
|
|
697
|
+
from pyopenapi_gen import generate_client, GenerationError
|
|
698
|
+
|
|
699
|
+
def build_api_clients():
|
|
700
|
+
"""Generate all API clients as part of build process"""
|
|
701
|
+
|
|
702
|
+
specs_dir = Path("specs")
|
|
703
|
+
output_root = Path("src/pyapis")
|
|
704
|
+
|
|
705
|
+
# Find all OpenAPI specs
|
|
706
|
+
spec_files = list(specs_dir.glob("*.yaml")) + list(specs_dir.glob("*.json"))
|
|
707
|
+
|
|
708
|
+
if not spec_files:
|
|
709
|
+
print("No OpenAPI specs found in specs/")
|
|
710
|
+
return False
|
|
711
|
+
|
|
712
|
+
# Generate clients
|
|
713
|
+
for spec_file in spec_files:
|
|
714
|
+
client_name = spec_file.stem
|
|
715
|
+
package_name = f"pyapis.{client_name}"
|
|
716
|
+
|
|
717
|
+
print(f"Generating client for {spec_file.name}...")
|
|
718
|
+
|
|
719
|
+
try:
|
|
720
|
+
generate_client(
|
|
721
|
+
spec_path=str(spec_file),
|
|
722
|
+
project_root="src",
|
|
723
|
+
output_package=package_name,
|
|
724
|
+
core_package="pyapis.core",
|
|
725
|
+
force=True
|
|
726
|
+
)
|
|
727
|
+
except GenerationError as e:
|
|
728
|
+
print(f"Failed to generate {client_name}: {e}", file=sys.stderr)
|
|
729
|
+
return False
|
|
730
|
+
|
|
731
|
+
return True
|
|
732
|
+
|
|
733
|
+
if __name__ == "__main__":
|
|
734
|
+
success = build_api_clients()
|
|
735
|
+
sys.exit(0 if success else 1)
|
|
736
|
+
```
|
|
737
|
+
|
|
738
|
+
### API Reference
|
|
739
|
+
|
|
740
|
+
#### `generate_client()` Function
|
|
741
|
+
|
|
742
|
+
```python
|
|
743
|
+
def generate_client(
|
|
744
|
+
spec_path: str,
|
|
745
|
+
project_root: str,
|
|
746
|
+
output_package: str,
|
|
747
|
+
core_package: str | None = None,
|
|
748
|
+
force: bool = False,
|
|
749
|
+
no_postprocess: bool = False,
|
|
750
|
+
verbose: bool = False,
|
|
751
|
+
) -> List[Path]
|
|
752
|
+
```
|
|
753
|
+
|
|
754
|
+
**Parameters**:
|
|
755
|
+
- `spec_path`: Path to OpenAPI spec file (YAML or JSON)
|
|
756
|
+
- `project_root`: Root directory of your Python project
|
|
757
|
+
- `output_package`: Python package name (e.g., `'pyapis.my_client'`)
|
|
758
|
+
- `core_package`: Optional shared core package name (defaults to `{output_package}.core`)
|
|
759
|
+
- `force`: Skip diff check and overwrite existing output
|
|
760
|
+
- `no_postprocess`: Skip Black formatting and mypy type checking
|
|
761
|
+
- `verbose`: Print detailed progress information
|
|
762
|
+
|
|
763
|
+
**Returns**: List of `Path` objects for all generated files
|
|
764
|
+
|
|
765
|
+
**Raises**: `GenerationError` if generation fails
|
|
766
|
+
|
|
767
|
+
#### `ClientGenerator` Class (Advanced)
|
|
768
|
+
|
|
769
|
+
For advanced use cases requiring more control:
|
|
770
|
+
|
|
771
|
+
```python
|
|
772
|
+
from pyopenapi_gen import ClientGenerator, GenerationError
|
|
773
|
+
from pathlib import Path
|
|
774
|
+
|
|
775
|
+
# Create generator with custom settings
|
|
776
|
+
generator = ClientGenerator(verbose=True)
|
|
777
|
+
|
|
778
|
+
# Generate with full control
|
|
779
|
+
try:
|
|
780
|
+
files = generator.generate(
|
|
781
|
+
spec_path="openapi.yaml",
|
|
782
|
+
project_root=Path("."),
|
|
783
|
+
output_package="pyapis.my_client",
|
|
784
|
+
core_package="pyapis.core",
|
|
785
|
+
force=False,
|
|
786
|
+
no_postprocess=False
|
|
787
|
+
)
|
|
788
|
+
except GenerationError as e:
|
|
789
|
+
print(f"Generation failed: {e}")
|
|
790
|
+
```
|
|
791
|
+
|
|
792
|
+
#### `GenerationError` Exception
|
|
793
|
+
|
|
794
|
+
Raised when generation fails. Contains contextual information about the failure:
|
|
795
|
+
|
|
796
|
+
```python
|
|
797
|
+
from pyopenapi_gen import generate_client, GenerationError
|
|
798
|
+
|
|
799
|
+
try:
|
|
800
|
+
generate_client(
|
|
801
|
+
spec_path="invalid.yaml",
|
|
802
|
+
project_root=".",
|
|
803
|
+
output_package="test"
|
|
804
|
+
)
|
|
805
|
+
except GenerationError as e:
|
|
806
|
+
# Exception message includes context
|
|
807
|
+
print(f"Error: {e}")
|
|
808
|
+
# Typical causes:
|
|
809
|
+
# - Invalid OpenAPI specification
|
|
810
|
+
# - File I/O errors
|
|
811
|
+
# - Type checking failures
|
|
812
|
+
# - Invalid project structure
|
|
813
|
+
```
|
|
814
|
+
|
|
815
|
+
### Comparison: CLI vs Programmatic API
|
|
816
|
+
|
|
817
|
+
**CLI Usage**:
|
|
818
|
+
```bash
|
|
819
|
+
pyopenapi-gen input/openapi.yaml \
|
|
820
|
+
--project-root . \
|
|
821
|
+
--output-package pyapis.my_client \
|
|
822
|
+
--force \
|
|
823
|
+
--verbose
|
|
824
|
+
```
|
|
825
|
+
|
|
826
|
+
**Equivalent Programmatic Usage**:
|
|
827
|
+
```python
|
|
828
|
+
from pyopenapi_gen import generate_client
|
|
829
|
+
|
|
830
|
+
generate_client(
|
|
831
|
+
spec_path="input/openapi.yaml",
|
|
832
|
+
project_root=".",
|
|
833
|
+
output_package="pyapis.my_client",
|
|
834
|
+
force=True,
|
|
835
|
+
verbose=True
|
|
836
|
+
)
|
|
837
|
+
```
|
|
838
|
+
|
|
839
|
+
Both approaches use the same underlying implementation and produce identical results.
|
|
840
|
+
|
|
608
841
|
## Release Management & Semantic Versioning
|
|
609
842
|
|
|
610
843
|
### Automated Release Pipeline
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: pyopenapi-gen
|
|
3
|
-
Version: 0.
|
|
3
|
+
Version: 0.17.0
|
|
4
4
|
Summary: Modern, async-first Python client generator for OpenAPI specifications with advanced cycle detection and unified type resolution
|
|
5
5
|
Project-URL: Homepage, https://github.com/your-org/pyopenapi-gen
|
|
6
6
|
Project-URL: Documentation, https://github.com/your-org/pyopenapi-gen/blob/main/README.md
|