Correct the filter attribute of db model 'ResourcePropertiesData'

Make sure to delete the ResourcePropertiesData row
if the resource 'attr_data_id' has been set already.

Change-Id: I2df5dfc72d051b6619c769c1260ff24b016bc294
Closes-Bug: #1708378
This commit is contained in:
huangtianhua 2017-10-13 15:46:53 +08:00
parent c5593161d9
commit a532535b61
2 changed files with 22 additions and 1 deletions

View File

@ -304,7 +304,7 @@ def resource_attr_id_set(context, resource_id, atomic_key, attr_id):
{'rid': resource_id, 'aid': attr_id})
session.query(
models.ResourcePropertiesData).filter(
models.ResourcePropertiesData.attr_id == attr_id).delete()
models.ResourcePropertiesData.id == attr_id).delete()
return False

View File

@ -655,6 +655,27 @@ class ResourceTest(common.HeatTestCase):
self.assertEqual('word', res.attributes['string'])
self.assertEqual(0, res_attr.call_count)
def test_store_attributes_fail(self):
res_def = rsrc_defn.ResourceDefinition('test_resource',
'ResWithStringPropAndAttr')
res = generic_rsrc.ResWithStringPropAndAttr(
'test_res_attr_store', res_def, self.stack)
res.action = res.UPDATE
res.status = res.COMPLETE
res.store()
attr_data = {'string': 'word'}
# set the attr_data_id first
resource_objects.Resource.update_by_id(res.context, res.id,
{'attr_data_id': 99})
new_attr_data_id = resource_objects.Resource.store_attributes(
res.context, res.id, res._atomic_key, attr_data, None)
# fail to store new attr data
self.assertIsNone(new_attr_data_id)
res._load_data(resource_objects.Resource.get_obj(
res.context, res.id))
self.assertEqual({}, res.attributes._resolved_values)
def test_resource_object_resource_properties_data(self):
cfg.CONF.set_override('encrypt_parameters_and_properties', True)
data = {'p1': 'i see',