Justin Black 6cc270633b
[python] Fixes additional_properties_type for models (#8802)
* Fixes additionalProperties values for models, updates docs, adds tag test of it, fixes frit and gmfruit tests

* Moves this.setDisallowAdditionalPropertiesIfNotPresent higher

* Makes setting additional_properties_model_instances contingent on the presence of addprosp in schema, updates sample spec composed schemas to remove addprops False form two

* Fixes oneOf anyOf allOf instantiation logic

* Removes Address from Cat definition

* Adds required vars for apple and banana, removes required vars from composed schema init sig

* Updates composed schema vars to be set on self and all composed instances

* Removes get_unused_args, get_var_name_to_model_instances, and get_additional_properties_model_instances

* Fixes fruit + deserilization tests, creates ComposedSchemaWithPropsAndNoAddProps

* Fixes FruitReq tests

* Fixes GmFruit tests

* Fixes discard_unknown_keys tests

* Samples updated

* Removes additionalproperties False in Child

* Samples updated

* Improves handling of v2 and v3 specs for isFreeFormObject, v2 sample spec updated with link to bug

* Adds cli option disallowAdditionalPropertiesIfNotPresent to python

* Adds getAdditionalProperties method so the value for addProps will be correct

* Reverts file

* Reverts file

* Updates python doc

* Reverted anytype_3 definition

* Updates test_deserialize_lizard

* Updates test_deserialize_dict_str_dog

* Updates testDog

* Updates testChild

* Adds v2 python_composition sample

* Adds needed files for python testing

* Adds existing tests into the new python sample

* Fixes test_dog

* Removes addProps false form Dog

* Fixes testChild

* Updates how additionalProperties are set

* Fixes empty_map type

* Type generation fixed for v2 and v3 specs

* Refactors getTypeString, updates artifactids in pom.xml files

* Adds new python sample to CI testing I think

* Fixes artifactId collision, regenrates docs
2021-03-31 08:48:12 -07:00

152 lines
4.8 KiB
Python

# 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: \" \\ # noqa: E501
The version of the OpenAPI document: 1.0.0
Generated by: https://openapi-generator.tech
"""
from __future__ import absolute_import
import sys
import unittest
import petstore_api
try:
from petstore_api.model import animal
except ImportError:
animal = sys.modules[
'petstore_api.model.animal']
try:
from petstore_api.model import dog_all_of
except ImportError:
dog_all_of = sys.modules[
'petstore_api.model.dog_all_of']
from petstore_api.model.dog import Dog
class TestDog(unittest.TestCase):
"""Dog unit test stubs"""
def setUp(self):
pass
def tearDown(self):
pass
def testDog(self):
"""Test Dog"""
# make an instance of dog, a composed schema model
class_name = 'Dog'
color = 'white'
breed = 'Jack Russel Terrier'
dog = Dog(
class_name=class_name,
color=color,
breed=breed
)
# check its properties
self.assertEqual(dog.class_name, class_name)
self.assertEqual(dog.color, color)
self.assertEqual(dog.breed, breed)
# access them with keys
self.assertEqual(dog['class_name'], class_name)
self.assertEqual(dog['color'], color)
self.assertEqual(dog['breed'], breed)
# access them with getattr
self.assertEqual(getattr(dog, 'class_name'), class_name)
self.assertEqual(getattr(dog, 'color'), color)
self.assertEqual(getattr(dog, 'breed'), breed)
# check the model's to_dict result
self.assertEqual(
dog.to_dict(),
{
'class_name': class_name,
'color': color,
'breed': breed,
}
)
# getting a value that doesn't exist raises an exception
# with a key
with self.assertRaises(AttributeError):
invalid_variable = dog['not_here_a']
# with getattr
self.assertEqual(getattr(dog, 'not_here_a', 'some value'), 'some value')
with self.assertRaises(AttributeError):
invalid_variable = getattr(dog, 'not_here_a')
# make sure that the ModelComposed class properties are correct
# model.composed_schemas() stores the anyOf/allOf/oneOf info
self.assertEqual(
dog._composed_schemas,
{
'anyOf': [],
'allOf': [
animal.Animal,
dog_all_of.DogAllOf,
],
'oneOf': [],
}
)
# model._composed_instances is a list of the instances that were
# made from the anyOf/allOf/OneOf classes in model._composed_schemas()
for composed_instance in dog._composed_instances:
if composed_instance.__class__ == animal.Animal:
animal_instance = composed_instance
elif composed_instance.__class__ == dog_all_of.DogAllOf:
dog_allof_instance = composed_instance
self.assertEqual(
dog._composed_instances,
[animal_instance, dog_allof_instance]
)
# model._var_name_to_model_instances maps the variable name to the
# model instances which store that variable
self.assertEqual(
dog._var_name_to_model_instances,
{
'breed': [dog, animal_instance, dog_allof_instance],
'class_name': [dog, animal_instance, dog_allof_instance],
'color': [dog, animal_instance, dog_allof_instance]
}
)
# model._additional_properties_model_instances stores a list of
# models which have the property additional_properties_type != None
self.assertEqual(
dog._additional_properties_model_instances, [dog]
)
# setting a value that doesn't exist works
dog['invalid_variable'] = 'a'
assert dog.invalid_variable == 'a'
# with setattr
setattr(dog, 'invalid_variable', 'b')
assert dog.invalid_variable == 'b'
# if we modify one of the properties owned by multiple
# model_instances we get an exception when we try to access that
# property because the retrieved values are not all the same
dog_allof_instance.breed = 'Golden Retriever'
with self.assertRaises(petstore_api.ApiValueError):
breed = dog.breed
# including extra parameters works
dog = Dog(
class_name=class_name,
color=color,
breed=breed,
unknown_property='some value'
)
assert dog.unknown_property == 'some value'
if __name__ == '__main__':
unittest.main()