Remove deprecated old attribute schema
This change is a part of changes discussed here: https://etherpad.openstack.org/p/YVR-heat-liberty-deprecation - Removed deprecation warning - Removed hook for old attribute schema - Re-factored test for type property of attribute schema Change-Id: Ie48754943386755224a4e19d87bbd083b1b91d1b
This commit is contained in:
parent
e4264917fa
commit
3c38459c3f
|
@ -12,7 +12,6 @@
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import collections
|
import collections
|
||||||
import warnings
|
|
||||||
|
|
||||||
import six
|
import six
|
||||||
|
|
||||||
|
@ -78,12 +77,9 @@ class Schema(constr.Schema):
|
||||||
"""
|
"""
|
||||||
Return a Property Schema corresponding to a Attribute Schema.
|
Return a Property Schema corresponding to a Attribute Schema.
|
||||||
"""
|
"""
|
||||||
if isinstance(schema_dict, cls):
|
assert (isinstance(schema_dict, cls),
|
||||||
|
'Old attribute schema is not supported')
|
||||||
return schema_dict
|
return schema_dict
|
||||||
warnings.warn('<name>: <description> schema definition is deprecated. '
|
|
||||||
'Use <name>: attributes.Schema(<description>) instead.',
|
|
||||||
DeprecationWarning)
|
|
||||||
return cls(schema_dict)
|
|
||||||
|
|
||||||
|
|
||||||
def schemata(schema):
|
def schemata(schema):
|
||||||
|
|
|
@ -71,13 +71,6 @@ class AttributeSchemaTest(common.HeatTestCase):
|
||||||
self.assertEqual('Do not use this ever',
|
self.assertEqual('Do not use this ever',
|
||||||
attrs._attributes['bar_dep'].support_status().message)
|
attrs._attributes['bar_dep'].support_status().message)
|
||||||
|
|
||||||
def test_old_attribute_schema_format(self):
|
|
||||||
s = 'Test description.'
|
|
||||||
self.assertIsInstance(attributes.Schema.from_attribute(s),
|
|
||||||
attributes.Schema)
|
|
||||||
self.assertEqual('Test description.',
|
|
||||||
attributes.Schema.from_attribute(s).description)
|
|
||||||
|
|
||||||
|
|
||||||
class AttributeTest(common.HeatTestCase):
|
class AttributeTest(common.HeatTestCase):
|
||||||
"""Test the Attribute class."""
|
"""Test the Attribute class."""
|
||||||
|
@ -188,28 +181,31 @@ class AttributesTest(common.HeatTestCase):
|
||||||
value = 'value3 changed'
|
value = 'value3 changed'
|
||||||
self.assertEqual("value3 changed", attribs['test3'])
|
self.assertEqual("value3 changed", attribs['test3'])
|
||||||
|
|
||||||
def test_validate_type_invalid(self):
|
|
||||||
|
class AttributesTypeTest(common.HeatTestCase):
|
||||||
|
scenarios = [
|
||||||
|
('string_type',
|
||||||
|
dict(a_type=attributes.Schema.STRING,
|
||||||
|
value='correct value',
|
||||||
|
invalid_value=[])),
|
||||||
|
('list_type',
|
||||||
|
dict(a_type=attributes.Schema.LIST,
|
||||||
|
value=[],
|
||||||
|
invalid_value='invalid_value')),
|
||||||
|
('map_type',
|
||||||
|
dict(a_type=attributes.Schema.MAP,
|
||||||
|
value={},
|
||||||
|
invalid_value='invalid_value'))
|
||||||
|
]
|
||||||
|
|
||||||
|
def test_validate_type(self):
|
||||||
resolver = mock.Mock()
|
resolver = mock.Mock()
|
||||||
# Test invalid string type attribute
|
msg = 'Attribute test1 is not of type %s' % self.a_type
|
||||||
attr_schema = attributes.Schema("Test attribute",
|
attr_schema = attributes.Schema("Test attribute", type=self.a_type)
|
||||||
type=attributes.Schema.STRING)
|
attrs_schema = {'res1': attr_schema}
|
||||||
attr = attributes.Attribute("test1", attr_schema)
|
attr = attributes.Attribute("test1", attr_schema)
|
||||||
attribs = attributes.Attributes('test resource', attr_schema, resolver)
|
attribs = attributes.Attributes('test res1', attrs_schema, resolver)
|
||||||
attribs._validate_type(attr, [])
|
attribs._validate_type(attr, self.value)
|
||||||
self.assertIn("Attribute test1 is not of type String", self.LOG.output)
|
self.assertNotIn(msg, self.LOG.output)
|
||||||
|
attribs._validate_type(attr, self.invalid_value)
|
||||||
# Test invalid list type attribute
|
self.assertIn(msg, self.LOG.output)
|
||||||
attr_schema = attributes.Schema("Test attribute",
|
|
||||||
type=attributes.Schema.LIST)
|
|
||||||
attr = attributes.Attribute("test1", attr_schema)
|
|
||||||
attribs = attributes.Attributes('test resource', attr_schema, resolver)
|
|
||||||
attribs._validate_type(attr, 'invalid')
|
|
||||||
self.assertIn("Attribute test1 is not of type List", self.LOG.output)
|
|
||||||
|
|
||||||
# Test invalid map type attribute
|
|
||||||
attr_schema = attributes.Schema("Test attribute",
|
|
||||||
type=attributes.Schema.MAP)
|
|
||||||
attr = attributes.Attribute("test1", attr_schema)
|
|
||||||
attribs = attributes.Attributes('test resource', attr_schema, resolver)
|
|
||||||
attribs._validate_type(attr, 'invalid')
|
|
||||||
self.assertIn("Attribute test1 is not of type Map", self.LOG.output)
|
|
||||||
|
|
Loading…
Reference in New Issue