d8bad7377b
Due to the not strict handling of uninitialized fields during notification payload population it is possible that the emitted notification missing some of the fields defined in the schema. There are two problematic cases: 1) no load tirggered for lazy loaded fields. If the field was not loaded it is not added to the payload. 2) uninitialized, not lazy loadable fields are not added to the payload. This patch makes sure that lazy load is triggered. If the field is not lazy loadable and also not initialized then related payload field will be set to None. If the payload field is not nullable the code will fail to make sure that the inconsistency is detected. The following changes cannot be split to different commits because as soon as the generic schema population code is fixed every listed notification starts behaving differently. In some cases the availability_zone field of the Service object is left unitialized by both the constructor and the obj_load_attr function this caused that the availability_zone field of the service.update notification was missing from the emitted notification payload. The extra_specs field of the Flavor object is not lazy loadable and not initialized in the Flavor destroy case. So the extra_specs field of the FlavorPayload needed to be made nullable. The projects field of the Flavor object is lazy loaded but when the Flavor object is loaded as part of an Instance object Flavor is orphaned and no lazy load is allowed on that Flavor object. In this case the projects field of the FlavorPayload will be set to None to signal that the information is not available. This also means that the projects field of the FlavorPayload needed to be changed to nullable. The hosts and id fields of the Aggregate object is not initialized during the create of the Aggregate before the aggregate.create.start needs to be sent. Therefore these fields needs to be nullable. Closes-Bug: #1653221 Change-Id: Ib122cd98ee0cc31938d5ff1d5c753053267a3bd4
20 lines
535 B
JSON
20 lines
535 B
JSON
{
|
|
"priority": "INFO",
|
|
"payload": {
|
|
"nova_object.version": "1.1",
|
|
"nova_object.namespace": "nova",
|
|
"nova_object.name": "AggregatePayload",
|
|
"nova_object.data": {
|
|
"name": "my-aggregate",
|
|
"metadata": {
|
|
"availability_zone": "nova"
|
|
},
|
|
"hosts": null,
|
|
"id": null,
|
|
"uuid": "788608ec-ebdc-45c5-bc7f-e5f24ab92c80"
|
|
}
|
|
},
|
|
"event_type": "aggregate.create.start",
|
|
"publisher_id": "nova-api:fake-mini"
|
|
}
|