Skip to content

Commit

Permalink
update samples
Browse files Browse the repository at this point in the history
  • Loading branch information
yugi committed Jan 7, 2025
1 parent 8e6169e commit ab4f245
Show file tree
Hide file tree
Showing 33 changed files with 730 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -1957,6 +1957,13 @@ components:
properties:
breed:
type: string
Hunting__Dog:
allOf:
- $ref: '#/components/schemas/Animal'
- type: object
properties:
isTrained:
type: boolean
Cat:
allOf:
- $ref: '#/components/schemas/Animal'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ docs/FooGetDefaultResponse.md
docs/FormatTest.md
docs/HasOnlyReadOnly.md
docs/HealthCheckResult.md
docs/HuntingDog.md
docs/ImportTestDatetimeApi.md
docs/Info.md
docs/InnerDictWithProperty.md
Expand Down Expand Up @@ -178,6 +179,7 @@ petstore_api/models/foo_get_default_response.py
petstore_api/models/format_test.py
petstore_api/models/has_only_read_only.py
petstore_api/models/health_check_result.py
petstore_api/models/hunting_dog.py
petstore_api/models/info.py
petstore_api/models/inner_dict_with_property.py
petstore_api/models/input_all_of.py
Expand Down Expand Up @@ -246,4 +248,5 @@ setup.cfg
setup.py
test-requirements.txt
test/__init__.py
test/test_hunting_dog.py
tox.ini
1 change: 1 addition & 0 deletions samples/openapi3/client/petstore/python-aiohttp/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,7 @@ Class | Method | HTTP request | Description
- [FormatTest](docs/FormatTest.md)
- [HasOnlyReadOnly](docs/HasOnlyReadOnly.md)
- [HealthCheckResult](docs/HealthCheckResult.md)
- [HuntingDog](docs/HuntingDog.md)
- [Info](docs/Info.md)
- [InnerDictWithProperty](docs/InnerDictWithProperty.md)
- [InputAllOf](docs/InputAllOf.md)
Expand Down
29 changes: 29 additions & 0 deletions samples/openapi3/client/petstore/python-aiohttp/docs/HuntingDog.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# HuntingDog


## Properties

Name | Type | Description | Notes
------------ | ------------- | ------------- | -------------
**is_trained** | **bool** | | [optional]

## Example

```python
from petstore_api.models.hunting_dog import HuntingDog

# TODO update the JSON string below
json = "{}"
# create an instance of HuntingDog from a JSON string
hunting_dog_instance = HuntingDog.from_json(json)
# print the JSON string representation of the object
print(HuntingDog.to_json())

# convert the object into a dict
hunting_dog_dict = hunting_dog_instance.to_dict()
# create an instance of HuntingDog from a dict
hunting_dog_from_dict = HuntingDog.from_dict(hunting_dog_dict)
```
[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md)


Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@
from petstore_api.models.format_test import FormatTest
from petstore_api.models.has_only_read_only import HasOnlyReadOnly
from petstore_api.models.health_check_result import HealthCheckResult
from petstore_api.models.hunting_dog import HuntingDog
from petstore_api.models.info import Info
from petstore_api.models.inner_dict_with_property import InnerDictWithProperty
from petstore_api.models.input_all_of import InputAllOf
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@
from petstore_api.models.format_test import FormatTest
from petstore_api.models.has_only_read_only import HasOnlyReadOnly
from petstore_api.models.health_check_result import HealthCheckResult
from petstore_api.models.hunting_dog import HuntingDog
from petstore_api.models.info import Info
from petstore_api.models.inner_dict_with_property import InnerDictWithProperty
from petstore_api.models.input_all_of import InputAllOf
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
if TYPE_CHECKING:
from petstore_api.models.cat import Cat
from petstore_api.models.dog import Dog
from petstore_api.models.hunting_dog import HuntingDog

class Animal(BaseModel):
"""
Expand All @@ -48,7 +49,7 @@ class Animal(BaseModel):

# discriminator mappings
__discriminator_value_class_map: ClassVar[Dict[str, str]] = {
'Cat': 'Cat','Dog': 'Dog'
'Cat': 'Cat','Dog': 'Dog','Hunting__Dog': 'HuntingDog'
}

@classmethod
Expand All @@ -70,7 +71,7 @@ def to_json(self) -> str:
return json.dumps(self.to_dict())

@classmethod
def from_json(cls, json_str: str) -> Optional[Union[Cat, Dog]]:
def from_json(cls, json_str: str) -> Optional[Union[Cat, Dog, HuntingDog]]:
"""Create an instance of Animal from a JSON string"""
return cls.from_dict(json.loads(json_str))

Expand All @@ -95,14 +96,16 @@ def to_dict(self) -> Dict[str, Any]:
return _dict

@classmethod
def from_dict(cls, obj: Dict[str, Any]) -> Optional[Union[Cat, Dog]]:
def from_dict(cls, obj: Dict[str, Any]) -> Optional[Union[Cat, Dog, HuntingDog]]:
"""Create an instance of Animal from a dict"""
# look up the object type based on discriminator mapping
object_type = cls.get_discriminator_value(obj)
if object_type == 'Cat':
return import_module("petstore_api.models.cat").Cat.from_dict(obj)
if object_type == 'Dog':
return import_module("petstore_api.models.dog").Dog.from_dict(obj)
if object_type == 'HuntingDog':
return import_module("petstore_api.models.hunting_dog").HuntingDog.from_dict(obj)

raise ValueError("Animal failed to lookup discriminator value from " +
json.dumps(obj) + ". Discriminator property name: " + cls.__discriminator_property_name +
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
# coding: utf-8

"""
OpenAPI Petstore
This spec is mainly for testing Petstore server and contains fake endpoints, models. Please do not use this for any other purpose. Special characters: \" \\
The version of the OpenAPI document: 1.0.0
Generated by OpenAPI Generator (https://openapi-generator.tech)
Do not edit the class manually.
""" # noqa: E501


from __future__ import annotations
import pprint
import re # noqa: F401
import json

from pydantic import ConfigDict, Field, StrictBool
from typing import Any, ClassVar, Dict, List, Optional
from petstore_api.models.animal import Animal
from typing import Optional, Set
from typing_extensions import Self

class HuntingDog(Animal):
"""
HuntingDog
""" # noqa: E501
is_trained: Optional[StrictBool] = Field(default=None, alias="isTrained")
__properties: ClassVar[List[str]] = ["className", "color", "isTrained"]

model_config = ConfigDict(
populate_by_name=True,
validate_assignment=True,
protected_namespaces=(),
)


def to_str(self) -> str:
"""Returns the string representation of the model using alias"""
return pprint.pformat(self.model_dump(by_alias=True))

def to_json(self) -> str:
"""Returns the JSON representation of the model using alias"""
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
return json.dumps(self.to_dict())

@classmethod
def from_json(cls, json_str: str) -> Optional[Self]:
"""Create an instance of HuntingDog from a JSON string"""
return cls.from_dict(json.loads(json_str))

def to_dict(self) -> Dict[str, Any]:
"""Return the dictionary representation of the model using alias.
This has the following differences from calling pydantic's
`self.model_dump(by_alias=True)`:
* `None` is only added to the output dict for nullable fields that
were set at model initialization. Other fields with value `None`
are ignored.
"""
excluded_fields: Set[str] = set([
])

_dict = self.model_dump(
by_alias=True,
exclude=excluded_fields,
exclude_none=True,
)
return _dict

@classmethod
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
"""Create an instance of HuntingDog from a dict"""
if obj is None:
return None

if not isinstance(obj, dict):
return cls.model_validate(obj)

_obj = cls.model_validate({
"className": obj.get("className"),
"color": obj.get("color") if obj.get("color") is not None else 'red',
"isTrained": obj.get("isTrained")
})
return _obj


Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
# coding: utf-8

"""
OpenAPI Petstore
This spec is mainly for testing Petstore server and contains fake endpoints, models. Please do not use this for any other purpose. Special characters: \" \\
The version of the OpenAPI document: 1.0.0
Generated by OpenAPI Generator (https://openapi-generator.tech)
Do not edit the class manually.
""" # noqa: E501


import unittest

from petstore_api.models.hunting_dog import HuntingDog

class TestHuntingDog(unittest.TestCase):
"""HuntingDog unit test stubs"""

def setUp(self):
pass

def tearDown(self):
pass

def make_instance(self, include_optional) -> HuntingDog:
"""Test HuntingDog
include_optional is a boolean, when False only required
params are included, when True both required and
optional params are included """
# uncomment below to create an instance of `HuntingDog`
"""
model = HuntingDog()
if include_optional:
return HuntingDog(
is_trained = True
)
else:
return HuntingDog(
)
"""

def testHuntingDog(self):
"""Test HuntingDog"""
# inst_req_only = self.make_instance(include_optional=False)
# inst_req_and_optional = self.make_instance(include_optional=True)

if __name__ == '__main__':
unittest.main()
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ docs/FooGetDefaultResponse.md
docs/FormatTest.md
docs/HasOnlyReadOnly.md
docs/HealthCheckResult.md
docs/HuntingDog.md
docs/ImportTestDatetimeApi.md
docs/Info.md
docs/InnerDictWithProperty.md
Expand Down Expand Up @@ -180,6 +181,7 @@ petstore_api/models/foo_get_default_response.py
petstore_api/models/format_test.py
petstore_api/models/has_only_read_only.py
petstore_api/models/health_check_result.py
petstore_api/models/hunting_dog.py
petstore_api/models/info.py
petstore_api/models/inner_dict_with_property.py
petstore_api/models/input_all_of.py
Expand Down Expand Up @@ -246,4 +248,5 @@ setup.cfg
setup.py
test-requirements.txt
test/__init__.py
test/test_hunting_dog.py
tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,7 @@ Class | Method | HTTP request | Description
- [FormatTest](docs/FormatTest.md)
- [HasOnlyReadOnly](docs/HasOnlyReadOnly.md)
- [HealthCheckResult](docs/HealthCheckResult.md)
- [HuntingDog](docs/HuntingDog.md)
- [Info](docs/Info.md)
- [InnerDictWithProperty](docs/InnerDictWithProperty.md)
- [InputAllOf](docs/InputAllOf.md)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# HuntingDog


## Properties
Name | Type | Description | Notes
------------ | ------------- | ------------- | -------------
**is_trained** | **bool** | | [optional]

## Example

```python
from petstore_api.models.hunting_dog import HuntingDog

# TODO update the JSON string below
json = "{}"
# create an instance of HuntingDog from a JSON string
hunting_dog_instance = HuntingDog.from_json(json)
# print the JSON string representation of the object
print HuntingDog.to_json()

# convert the object into a dict
hunting_dog_dict = hunting_dog_instance.to_dict()
# create an instance of HuntingDog from a dict
hunting_dog_from_dict = HuntingDog.from_dict(hunting_dog_dict)
```
[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md)


Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@
from petstore_api.models.format_test import FormatTest
from petstore_api.models.has_only_read_only import HasOnlyReadOnly
from petstore_api.models.health_check_result import HealthCheckResult
from petstore_api.models.hunting_dog import HuntingDog
from petstore_api.models.info import Info
from petstore_api.models.inner_dict_with_property import InnerDictWithProperty
from petstore_api.models.input_all_of import InputAllOf
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@
from petstore_api.models.format_test import FormatTest
from petstore_api.models.has_only_read_only import HasOnlyReadOnly
from petstore_api.models.health_check_result import HealthCheckResult
from petstore_api.models.hunting_dog import HuntingDog
from petstore_api.models.info import Info
from petstore_api.models.inner_dict_with_property import InnerDictWithProperty
from petstore_api.models.input_all_of import InputAllOf
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
if TYPE_CHECKING:
from petstore_api.models.cat import Cat
from petstore_api.models.dog import Dog
from petstore_api.models.hunting_dog import HuntingDog

class Animal(BaseModel):
"""
Expand All @@ -46,7 +47,8 @@ class Config:
# discriminator mappings
__discriminator_value_class_map = {
'Cat': 'Cat',
'Dog': 'Dog'
'Dog': 'Dog',
'Hunting__Dog': 'HuntingDog'
}

@classmethod
Expand All @@ -67,7 +69,7 @@ def to_json(self) -> str:
return json.dumps(self.to_dict())

@classmethod
def from_json(cls, json_str: str) -> Union(Cat, Dog):
def from_json(cls, json_str: str) -> Union(Cat, Dog, HuntingDog):
"""Create an instance of Animal from a JSON string"""
return cls.from_dict(json.loads(json_str))

Expand All @@ -80,14 +82,16 @@ def to_dict(self):
return _dict

@classmethod
def from_dict(cls, obj: dict) -> Union(Cat, Dog):
def from_dict(cls, obj: dict) -> Union(Cat, Dog, HuntingDog):
"""Create an instance of Animal from a dict"""
# look up the object type based on discriminator mapping
object_type = cls.get_discriminator_value(obj)
if object_type == 'Cat':
return import_module("petstore_api.models.cat").Cat.from_dict(obj)
if object_type == 'Dog':
return import_module("petstore_api.models.dog").Dog.from_dict(obj)
if object_type == 'HuntingDog':
return import_module("petstore_api.models.hunting_dog").HuntingDog.from_dict(obj)
raise ValueError("Animal failed to lookup discriminator value from " +
json.dumps(obj) + ". Discriminator property name: " + cls.__discriminator_property_name +
", mapping: " + json.dumps(cls.__discriminator_value_class_map))
Expand Down
Loading

0 comments on commit ab4f245

Please sign in to comment.