* Converts all schema instances back into primitives in cast_to_allowed_types, fixes test test_deserialize_oneof_reference * Updates type hint * Adds validated_path_to_schemas input * Adds debugging, storess validated schemas in validated_path_to_schemas * Adds __process_schema_classes * Simplifies class creation for enums, True/False/None * Removes unused methods * Fixes two tests * Removes unneeded method _enum_by_value * Adds and uses validation_ran_earlier * Skips running validation if already ran, base_classes changed to seen_classes * Adds and uses validation_ran_earlier * Simplifies __get_simple_class * Casts None/True/False into NoneClass and BoolClass instances to make tpye checking and unique items checking simpler * Always cast file input to FileIO, removes __get_simple_class * Moves type checking to separate class * Moves validation checking into a _validate method * Moves enum value checking into SchemaEnumMaker's _validate method * Fixes test_dict_validate_direct_instantiation_cast_item * Removes spy_decorator * Fixed test_dict_validate_direct_instantiation * Fixes test_list_validate_direct_instantiation_cast_item * Fixes test_list_validate_direct_instantiation * Fixes test_list_validate_from_openai_data_instantiation * Fixes test_dict_validate_from_openapi_data_instantiation * Fixes test_upload_files * Samples regenerated * Reverts version file
petstore-api
This spec is mainly for testing Petstore server and contains fake endpoints, models. Please do not use this for any other purpose. Special characters: " \
This Python package is automatically generated by the OpenAPI Generator project:
- API version: 1.0.0
- Package version: 1.0.0
- Build package: org.openapitools.codegen.languages.PythonExperimentalClientCodegen
Requirements.
Python >=3.9 v3.9 is needed so one can combine classmethod and property decorators to define object schema properties as classes
Installation & Usage
pip install
If the python package is hosted on a repository, you can install directly using:
pip install git+https://github.com/GIT_USER_ID/GIT_REPO_ID.git
(you may need to run pip with root permission: sudo pip install git+https://github.com/GIT_USER_ID/GIT_REPO_ID.git)
Then import the package:
import petstore_api
Setuptools
Install via Setuptools.
python setup.py install --user
(or sudo python setup.py install to install the package for all users)
Then import the package:
import petstore_api
Getting Started
Please follow the installation procedure and then run the following:
import datetimeimport datetimeimport datetimeimport datetimeimport datetimeimport datetimeimport datetime
import time
import petstore_api
from pprint import pprint
from petstore_api.api import another_fake_api
from petstore_api.model.client import Client
# Defining the host is optional and defaults to http://petstore.swagger.io:80/v2
# See configuration.py for a list of all supported configuration parameters.
configuration = petstore_api.Configuration(
    host = "http://petstore.swagger.io:80/v2"
)
# Enter a context with an instance of the API client
with petstore_api.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    api_instance = another_fake_api.AnotherFakeApi(api_client)
    client = Client(
        client="client_example",
    ) # Client | client model
    try:
        # To test special tags
        api_response = api_instance.call_123_test_special_tags(client)
        pprint(api_response)
    except petstore_api.ApiException as e:
        print("Exception when calling AnotherFakeApi->call_123_test_special_tags: %s\n" % e)
Documentation for API Endpoints
All URIs are relative to http://petstore.swagger.io:80/v2
| Class | Method | HTTP request | Description | 
|---|---|---|---|
| AnotherFakeApi | call_123_test_special_tags | PATCH /another-fake/dummy | To test special tags | 
| DefaultApi | foo_get | GET /foo | |
| FakeApi | additional_properties_with_array_of_enums | GET /fake/additional-properties-with-array-of-enums | Additional Properties with Array of Enums | 
| FakeApi | array_model | POST /fake/refs/arraymodel | |
| FakeApi | array_of_enums | POST /fake/refs/array-of-enums | Array of Enums | 
| FakeApi | body_with_file_schema | PUT /fake/body-with-file-schema | |
| FakeApi | body_with_query_params | PUT /fake/body-with-query-params | |
| FakeApi | boolean | POST /fake/refs/boolean | |
| FakeApi | case_sensitive_params | PUT /fake/case-sensitive-params | |
| FakeApi | client_model | PATCH /fake | To test "client" model | 
| FakeApi | composed_one_of_different_types | POST /fake/refs/composed_one_of_number_with_validations | |
| FakeApi | delete_coffee | DELETE /fake/deleteCoffee/{id} | Delete coffee | 
| FakeApi | endpoint_parameters | POST /fake | Fake endpoint for testing various parameters 假端點 偽のエンドポイント 가짜 엔드 포인트 | 
| FakeApi | enum_parameters | GET /fake | To test enum parameters | 
| FakeApi | fake_health_get | GET /fake/health | Health check endpoint | 
| FakeApi | group_parameters | DELETE /fake | Fake endpoint to test group parameters (optional) | 
| FakeApi | inline_additional_properties | POST /fake/inline-additionalProperties | test inline additionalProperties | 
| FakeApi | inline_composition | POST /fake/inlineComposition/ | testing composed schemas at inline locations | 
| FakeApi | json_form_data | GET /fake/jsonFormData | test json serialization of form data | 
| FakeApi | json_with_charset | POST /fake/jsonWithCharset | json with charset tx and rx | 
| FakeApi | mammal | POST /fake/refs/mammal | |
| FakeApi | number_with_validations | POST /fake/refs/number | |
| FakeApi | object_in_query | GET /fake/objInQuery | user list | 
| FakeApi | object_model_with_ref_props | POST /fake/refs/object_model_with_ref_props | |
| FakeApi | parameter_collisions | POST /fake/parameterCollisions/{1}/{aB}/{Ab}/{self}/{A-B}/ | parameter collision case | 
| FakeApi | query_parameter_collection_format | PUT /fake/test-query-paramters | |
| FakeApi | ref_object_in_query | GET /fake/refObjInQuery | user list | 
| FakeApi | response_without_schema | GET /fake/responseWithoutSchema | receives a response without schema | 
| FakeApi | string | POST /fake/refs/string | |
| FakeApi | string_enum | POST /fake/refs/enum | |
| FakeApi | upload_download_file | POST /fake/uploadDownloadFile | uploads a file and downloads a file using application/octet-stream | 
| FakeApi | upload_file | POST /fake/uploadFile | uploads a file using multipart/form-data | 
| FakeApi | upload_files | POST /fake/uploadFiles | uploads files using multipart/form-data | 
| FakeClassnameTags123Api | classname | PATCH /fake_classname_test | To test class name in snake case | 
| PetApi | add_pet | POST /pet | Add a new pet to the store | 
| PetApi | delete_pet | DELETE /pet/{petId} | Deletes a pet | 
| PetApi | find_pets_by_status | GET /pet/findByStatus | Finds Pets by status | 
| PetApi | find_pets_by_tags | GET /pet/findByTags | Finds Pets by tags | 
| PetApi | get_pet_by_id | GET /pet/{petId} | Find pet by ID | 
| PetApi | update_pet | PUT /pet | Update an existing pet | 
| PetApi | update_pet_with_form | POST /pet/{petId} | Updates a pet in the store with form data | 
| PetApi | upload_file_with_required_file | POST /fake/{petId}/uploadImageWithRequiredFile | uploads an image (required) | 
| PetApi | upload_image | POST /pet/{petId}/uploadImage | uploads an image | 
| StoreApi | delete_order | DELETE /store/order/{order_id} | Delete purchase order by ID | 
| StoreApi | get_inventory | GET /store/inventory | Returns pet inventories by status | 
| StoreApi | get_order_by_id | GET /store/order/{order_id} | Find purchase order by ID | 
| StoreApi | place_order | POST /store/order | Place an order for a pet | 
| UserApi | create_user | POST /user | Create user | 
| UserApi | create_users_with_array_input | POST /user/createWithArray | Creates list of users with given input array | 
| UserApi | create_users_with_list_input | POST /user/createWithList | Creates list of users with given input array | 
| UserApi | delete_user | DELETE /user/{username} | Delete user | 
| UserApi | get_user_by_name | GET /user/{username} | Get user by user name | 
| UserApi | login_user | GET /user/login | Logs user into the system | 
| UserApi | logout_user | GET /user/logout | Logs out current logged in user session | 
| UserApi | update_user | PUT /user/{username} | Updated user | 
Documentation For Models
- AdditionalPropertiesClass
- AdditionalPropertiesWithArrayOfEnums
- Address
- Animal
- AnimalFarm
- AnyTypeNotString
- ApiResponse
- Apple
- AppleReq
- ArrayHoldingAnyType
- ArrayOfArrayOfNumberOnly
- ArrayOfEnums
- ArrayOfNumberOnly
- ArrayTest
- ArrayWithValidationsInItems
- Banana
- BananaReq
- Bar
- BasquePig
- Boolean
- BooleanEnum
- Capitalization
- Cat
- Category
- ChildCat
- ClassModel
- Client
- ComplexQuadrilateral
- ComposedAnyOfDifferentTypesNoValidations
- ComposedArray
- ComposedBool
- ComposedNone
- ComposedNumber
- ComposedObject
- ComposedOneOfDifferentTypes
- ComposedString
- Currency
- DanishPig
- DateTimeTest
- DateTimeWithValidations
- DateWithValidations
- DecimalPayload
- Dog
- Drawing
- EnumArrays
- EnumClass
- EnumTest
- EquilateralTriangle
- File
- FileSchemaTestClass
- Foo
- FormatTest
- Fruit
- FruitReq
- GmFruit
- GrandparentAnimal
- HasOnlyReadOnly
- HealthCheckResult
- IntegerEnum
- IntegerEnumBig
- IntegerEnumOneValue
- IntegerEnumWithDefaultValue
- IntegerMax10
- IntegerMin15
- IsoscelesTriangle
- Mammal
- MapTest
- MixedPropertiesAndAdditionalPropertiesClass
- Model200Response
- ModelReturn
- Money
- Name
- NoAdditionalProperties
- NullableClass
- NullableShape
- NullableString
- Number
- NumberOnly
- NumberWithValidations
- ObjectInterface
- ObjectModelWithRefProps
- ObjectWithDecimalProperties
- ObjectWithDifficultlyNamedProps
- ObjectWithInlineCompositionProperty
- ObjectWithValidations
- Order
- ParentPet
- Pet
- Pig
- Player
- Quadrilateral
- QuadrilateralInterface
- ReadOnlyFirst
- ScaleneTriangle
- Shape
- ShapeOrNull
- SimpleQuadrilateral
- SomeObject
- SpecialModelName
- String
- StringBooleanMap
- StringEnum
- StringEnumWithDefaultValue
- StringWithValidation
- Tag
- Triangle
- TriangleInterface
- UUIDString
- User
- Whale
- Zebra
Documentation For Authorization
api_key
- Type: API key
- API key parameter name: api_key
- Location: HTTP header
api_key_query
- Type: API key
- API key parameter name: api_key_query
- Location: URL query string
bearer_test
- Type: Bearer authentication (JWT)
http_basic_test
- Type: HTTP basic authentication
http_signature_test
- Type: HTTP signature authentication
Authentication schemes defined for the API:
petstore_auth
- Type: OAuth
- Flow: implicit
- Authorization URL: http://petstore.swagger.io/api/oauth/dialog
- Scopes:
- write:pets: modify pets in your account
- read:pets: read your pets
Author
Notes for Large OpenAPI documents
If the OpenAPI document is large, imports in petstore_api.apis and petstore_api.models may fail with a RecursionError indicating the maximum recursion limit has been exceeded. In that case, there are a couple of solutions:
Solution 1: Use specific imports for apis and models like:
- from petstore_api.api.default_api import DefaultApi
- from petstore_api.model.pet import Pet
Solution 1: Before importing the package, adjust the maximum recursion limit as shown below:
import sys
sys.setrecursionlimit(1500)
import petstore_api
from petstore_api.apis import *
from petstore_api.models import *