I request the bug reporter to close this bug as it was fixed in Mitaka version and below is the detailed analysis and the delta between the Kilo and Mitaka version related to the bug.
My Analysis:
1) Existing Code snippet in Kilo:
IN _local_delete method: (/opt/stack/nova/nova/compute/api.py)
#Here, we are passing the connector ip as 127.0.0.1 to the terminate_connection and detach methods, as this is a loop back ip, it has no effect on the server side. So, the volume was not being detached from the instance and so status is remaining the same(which is not expected).
2) Already fixed in Mitaka in the follwoing way:
#A new method was written here to get the connector ip and the fake ip(127.0.0.1) given was removed here.
IN _get_stashed_volume_connector method: (/opt/stack/nova/nova/compute/api.py)
connector = jsonutils.loads(bdm.connection_info).get('connector')
if connector:
if connector.get('host') == instance.host: return connector
# Gets the stashed connector dict out of the bdm.connection_info if set and the connector host matches the instance host. This method was called in the _local_cleanup_bdm_volumes method to perform terminate_connection and detach methods.
I request the bug reporter to close this bug as it was fixed in Mitaka version and below is the detailed analysis and the delta between the Kilo and Mitaka version related to the bug.
My Analysis:
1) Existing Code snippet in Kilo:
IN _local_delete method: (/opt/stack/ nova/nova/ compute/ api.py)
connector = {'ip': '127.0.0.1', 'initiator': 'iqn.fake'}
try:
self. volume_ api.terminate_ connection( context, bdm.volume_ id,connector)
self. volume_ api.detach( elevated, bdm.volume_id)
#Here, we are passing the connector ip as 127.0.0.1 to the terminate_ connection and detach methods, as this is a loop back ip, it has no effect on the server side. So, the volume was not being detached from the instance and so status is remaining the same(which is not expected).
2) Already fixed in Mitaka in the follwoing way:
#A new method was written here to get the connector ip and the fake ip(127.0.0.1) given was removed here.
IN _get_stashed_ volume_ connector method: (/opt/stack/ nova/nova/ compute/ api.py) loads(bdm. connection_ info).get( 'connector' ) get('host' ) == instance.host:
return connector
connector = jsonutils.
if connector:
if connector.
# Gets the stashed connector dict out of the bdm.connection_info if set and the connector host matches the instance host. This method was called in the _local_ cleanup_ bdm_volumes method to perform terminate_ connection and detach methods.
REFFERED FILES:
/opt/stack/ nova/nova/ compute/ api.py nova/nova/ compute/ manager. py
/opt/stack/