Excise use of non-timezone aware utcnow()
Replace all instances of `datetime.datetime.utcnow()`, which is deprecated, with the timezone-aware oslo's `timeutils.utcnow()` method, across the Ironic project. Closes-Bug: #2067740 Change-Id: I998681c14f945846f58e723b9be2202dbe8ea12c
This commit is contained in:
parent
2f41bf1a0d
commit
b5b7e60c47
@ -12,12 +12,12 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import datetime
|
|
||||||
import json
|
import json
|
||||||
|
|
||||||
import openstack
|
import openstack
|
||||||
from openstack.connection import exceptions as openstack_exc
|
from openstack.connection import exceptions as openstack_exc
|
||||||
from oslo_log import log
|
from oslo_log import log
|
||||||
|
from oslo_utils import timeutils
|
||||||
|
|
||||||
from ironic.common import context as ironic_context
|
from ironic.common import context as ironic_context
|
||||||
from ironic.common import exception
|
from ironic.common import exception
|
||||||
@ -164,7 +164,7 @@ def _create_metadata_dictionary(node, action):
|
|||||||
"""
|
"""
|
||||||
label = "ironic_node_%s" % node.uuid
|
label = "ironic_node_%s" % node.uuid
|
||||||
data = {'instance_uuid': node.instance_uuid or node.uuid,
|
data = {'instance_uuid': node.instance_uuid or node.uuid,
|
||||||
'last_seen': datetime.datetime.utcnow().isoformat(),
|
'last_seen': timeutils.utcnow().isoformat(),
|
||||||
'last_action': action}
|
'last_action': action}
|
||||||
return {label: json.dumps(data)}
|
return {label: json.dumps(data)}
|
||||||
|
|
||||||
|
@ -12,10 +12,9 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import datetime
|
|
||||||
|
|
||||||
import jsonschema
|
import jsonschema
|
||||||
from jsonschema import exceptions as json_schema_exc
|
from jsonschema import exceptions as json_schema_exc
|
||||||
|
from oslo_utils import timeutils
|
||||||
|
|
||||||
from ironic.common import exception
|
from ironic.common import exception
|
||||||
from ironic.common.i18n import _
|
from ironic.common.i18n import _
|
||||||
@ -113,7 +112,7 @@ def update_raid_info(node, raid_config):
|
|||||||
one root volume or if node.properties['capabilities'] is malformed.
|
one root volume or if node.properties['capabilities'] is malformed.
|
||||||
"""
|
"""
|
||||||
current = raid_config.copy()
|
current = raid_config.copy()
|
||||||
current['last_updated'] = str(datetime.datetime.utcnow())
|
current['last_updated'] = str(timeutils.utcnow())
|
||||||
node.raid_config = current
|
node.raid_config = current
|
||||||
|
|
||||||
# Current RAID configuration can have 0 or 1 root volumes. If there
|
# Current RAID configuration can have 0 or 1 root volumes. If there
|
||||||
|
@ -41,7 +41,6 @@ notifying Neutron of a change, etc.
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
import collections
|
import collections
|
||||||
import datetime
|
|
||||||
import queue
|
import queue
|
||||||
|
|
||||||
import eventlet
|
import eventlet
|
||||||
@ -50,6 +49,7 @@ from ironic_lib import metrics_utils
|
|||||||
from oslo_log import log
|
from oslo_log import log
|
||||||
import oslo_messaging as messaging
|
import oslo_messaging as messaging
|
||||||
from oslo_utils import excutils
|
from oslo_utils import excutils
|
||||||
|
from oslo_utils import timeutils
|
||||||
from oslo_utils import uuidutils
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
from ironic.common import boot_devices
|
from ironic.common import boot_devices
|
||||||
@ -2602,7 +2602,7 @@ class ConductorManager(base_manager.BaseConductorManager):
|
|||||||
message = {'message_id': uuidutils.generate_uuid(),
|
message = {'message_id': uuidutils.generate_uuid(),
|
||||||
'instance_uuid': instance_uuid,
|
'instance_uuid': instance_uuid,
|
||||||
'node_uuid': node_uuid,
|
'node_uuid': node_uuid,
|
||||||
'timestamp': datetime.datetime.utcnow()}
|
'timestamp': timeutils.utcnow()}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
lock_purpose = 'getting sensors data'
|
lock_purpose = 'getting sensors data'
|
||||||
@ -2672,7 +2672,7 @@ class ConductorManager(base_manager.BaseConductorManager):
|
|||||||
# populate the message which will be sent to ceilometer
|
# populate the message which will be sent to ceilometer
|
||||||
# or other data consumer
|
# or other data consumer
|
||||||
message = {'message_id': uuidutils.generate_uuid(),
|
message = {'message_id': uuidutils.generate_uuid(),
|
||||||
'timestamp': datetime.datetime.utcnow(),
|
'timestamp': timeutils.utcnow(),
|
||||||
'hostname': self.host}
|
'hostname': self.host}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -19,6 +19,8 @@ import datetime
|
|||||||
import hashlib
|
import hashlib
|
||||||
import json
|
import json
|
||||||
|
|
||||||
|
from oslo_utils import timeutils
|
||||||
|
|
||||||
from ironic.api.controllers.v1 import allocation as al_controller
|
from ironic.api.controllers.v1 import allocation as al_controller
|
||||||
from ironic.api.controllers.v1 import chassis as chassis_controller
|
from ironic.api.controllers.v1 import chassis as chassis_controller
|
||||||
from ironic.api.controllers.v1 import deploy_template as dt_controller
|
from ironic.api.controllers.v1 import deploy_template as dt_controller
|
||||||
@ -82,7 +84,7 @@ class FakeMemcache(object):
|
|||||||
self.token_expiration = None
|
self.token_expiration = None
|
||||||
|
|
||||||
def get(self, key):
|
def get(self, key):
|
||||||
dt = datetime.datetime.utcnow() + datetime.timedelta(minutes=5)
|
dt = timeutils.utcnow() + datetime.timedelta(minutes=5)
|
||||||
return json.dumps((self._cache.get(key), dt.isoformat()))
|
return json.dumps((self._cache.get(key), dt.isoformat()))
|
||||||
|
|
||||||
def set(self, key, value, time=0, min_compress_len=0):
|
def set(self, key, value, time=0, min_compress_len=0):
|
||||||
|
@ -11,13 +11,13 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import datetime
|
|
||||||
import json
|
import json
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
from keystoneauth1 import loading as ks_loading
|
from keystoneauth1 import loading as ks_loading
|
||||||
import openstack
|
import openstack
|
||||||
from openstack.connection import exceptions as openstack_exc
|
from openstack.connection import exceptions as openstack_exc
|
||||||
|
from oslo_utils import timeutils
|
||||||
from oslo_utils import uuidutils
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
from ironic.common import cinder
|
from ironic.common import cinder
|
||||||
@ -144,12 +144,14 @@ class TestCinderUtils(db_base.DbTestCase):
|
|||||||
self.assertIsNone(cinder._get_attachment_id(self.node, unattached))
|
self.assertIsNone(cinder._get_attachment_id(self.node, unattached))
|
||||||
self.assertIsNone(cinder._get_attachment_id(self.node, no_attachment))
|
self.assertIsNone(cinder._get_attachment_id(self.node, no_attachment))
|
||||||
|
|
||||||
@mock.patch.object(datetime, 'datetime', autospec=True)
|
@mock.patch.object(timeutils, 'utcnow', autospec=True)
|
||||||
def test__create_metadata_dictionary(self, mock_datetime):
|
def test__create_metadata_dictionary(self, mock_utcnow):
|
||||||
fake_time = '2017-06-05T00:33:26.574676'
|
fake_time = '2017-06-05T00:33:26.574676'
|
||||||
mock_utcnow = mock.Mock()
|
mock_datetime = mock.Mock()
|
||||||
mock_datetime.utcnow.return_value = mock_utcnow
|
mock_datetime.isoformat.return_value = fake_time
|
||||||
mock_utcnow.isoformat.return_value = fake_time
|
|
||||||
|
mock_utcnow.return_value = mock_datetime
|
||||||
|
|
||||||
expected_key = ("ironic_node_%s" % self.node.uuid)
|
expected_key = ("ironic_node_%s" % self.node.uuid)
|
||||||
expected_data = {
|
expected_data = {
|
||||||
'instance_uuid': self.node.instance_uuid,
|
'instance_uuid': self.node.instance_uuid,
|
||||||
|
@ -235,7 +235,8 @@ class DbConductorTestCase(base.DbTestCase):
|
|||||||
h = 'fake-host'
|
h = 'fake-host'
|
||||||
expected = {}
|
expected = {}
|
||||||
|
|
||||||
mock_utcnow.return_value = datetime.datetime.utcnow()
|
mock_utcnow.return_value = datetime.datetime.now(
|
||||||
|
datetime.timezone.utc).replace(tzinfo=None)
|
||||||
self._create_test_cdr(hostname=h, drivers=[], hardware_types=[])
|
self._create_test_cdr(hostname=h, drivers=[], hardware_types=[])
|
||||||
result = self.dbapi.get_active_hardware_type_dict()
|
result = self.dbapi.get_active_hardware_type_dict()
|
||||||
self.assertEqual(expected, result)
|
self.assertEqual(expected, result)
|
||||||
@ -246,7 +247,8 @@ class DbConductorTestCase(base.DbTestCase):
|
|||||||
ht = 'hardware-type'
|
ht = 'hardware-type'
|
||||||
expected = {ht: {h}}
|
expected = {ht: {h}}
|
||||||
|
|
||||||
mock_utcnow.return_value = datetime.datetime.utcnow()
|
mock_utcnow.return_value = datetime.datetime.now(
|
||||||
|
datetime.timezone.utc).replace(tzinfo=None)
|
||||||
self._create_test_cdr(hostname=h, drivers=[], hardware_types=[ht])
|
self._create_test_cdr(hostname=h, drivers=[], hardware_types=[ht])
|
||||||
result = self.dbapi.get_active_hardware_type_dict()
|
result = self.dbapi.get_active_hardware_type_dict()
|
||||||
self.assertEqual(expected, result)
|
self.assertEqual(expected, result)
|
||||||
@ -260,7 +262,8 @@ class DbConductorTestCase(base.DbTestCase):
|
|||||||
key = '%s:%s' % (group, ht)
|
key = '%s:%s' % (group, ht)
|
||||||
expected = {key: {h}}
|
expected = {key: {h}}
|
||||||
|
|
||||||
mock_utcnow.return_value = datetime.datetime.utcnow()
|
mock_utcnow.return_value = datetime.datetime.now(
|
||||||
|
datetime.timezone.utc).replace(tzinfo=None)
|
||||||
self._create_test_cdr(hostname=h, drivers=[], hardware_types=[ht],
|
self._create_test_cdr(hostname=h, drivers=[], hardware_types=[ht],
|
||||||
conductor_group=group)
|
conductor_group=group)
|
||||||
result = self.dbapi.get_active_hardware_type_dict(use_groups=True)
|
result = self.dbapi.get_active_hardware_type_dict(use_groups=True)
|
||||||
@ -273,7 +276,8 @@ class DbConductorTestCase(base.DbTestCase):
|
|||||||
ht2 = 'another-hardware-type'
|
ht2 = 'another-hardware-type'
|
||||||
expected = {ht1: {h}, ht2: {h}}
|
expected = {ht1: {h}, ht2: {h}}
|
||||||
|
|
||||||
mock_utcnow.return_value = datetime.datetime.utcnow()
|
mock_utcnow.return_value = datetime.datetime.now(
|
||||||
|
datetime.timezone.utc).replace(tzinfo=None)
|
||||||
self._create_test_cdr(hostname=h, drivers=[],
|
self._create_test_cdr(hostname=h, drivers=[],
|
||||||
hardware_types=[ht1, ht2])
|
hardware_types=[ht1, ht2])
|
||||||
result = self.dbapi.get_active_hardware_type_dict()
|
result = self.dbapi.get_active_hardware_type_dict()
|
||||||
@ -286,7 +290,8 @@ class DbConductorTestCase(base.DbTestCase):
|
|||||||
ht = 'hardware-type'
|
ht = 'hardware-type'
|
||||||
expected = {ht: {h1, h2}}
|
expected = {ht: {h1, h2}}
|
||||||
|
|
||||||
mock_utcnow.return_value = datetime.datetime.utcnow()
|
mock_utcnow.return_value = datetime.datetime.now(
|
||||||
|
datetime.timezone.utc).replace(tzinfo=None)
|
||||||
self._create_test_cdr(id=1, hostname=h1, drivers=[],
|
self._create_test_cdr(id=1, hostname=h1, drivers=[],
|
||||||
hardware_types=[ht])
|
hardware_types=[ht])
|
||||||
self._create_test_cdr(id=2, hostname=h2, drivers=[],
|
self._create_test_cdr(id=2, hostname=h2, drivers=[],
|
||||||
@ -303,7 +308,8 @@ class DbConductorTestCase(base.DbTestCase):
|
|||||||
ht2 = 'another-hardware-type'
|
ht2 = 'another-hardware-type'
|
||||||
expected = {ht1: {h1, h2}, ht2: {h1, h2}}
|
expected = {ht1: {h1, h2}, ht2: {h1, h2}}
|
||||||
|
|
||||||
mock_utcnow.return_value = datetime.datetime.utcnow()
|
mock_utcnow.return_value = datetime.datetime.now(
|
||||||
|
datetime.timezone.utc).replace(tzinfo=None)
|
||||||
self._create_test_cdr(id=1, hostname=h1, drivers=[],
|
self._create_test_cdr(id=1, hostname=h1, drivers=[],
|
||||||
hardware_types=[ht1, ht2])
|
hardware_types=[ht1, ht2])
|
||||||
self._create_test_cdr(id=2, hostname=h2, drivers=[],
|
self._create_test_cdr(id=2, hostname=h2, drivers=[],
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
import datetime
|
import datetime
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
|
from oslo_utils import timeutils
|
||||||
import sushy
|
import sushy
|
||||||
|
|
||||||
from ironic.common import exception
|
from ironic.common import exception
|
||||||
@ -314,7 +315,7 @@ class RedfishFirmwareTestCase(db_base.DbTestCase):
|
|||||||
bmc_component = {'component': 'bmc', 'url': 'https://bmc/v1.0.1'}
|
bmc_component = {'component': 'bmc', 'url': 'https://bmc/v1.0.1'}
|
||||||
bios_component = {'component': 'bios', 'url': 'https://bios/v1.0.1'}
|
bios_component = {'component': 'bios', 'url': 'https://bios/v1.0.1'}
|
||||||
if add_wait:
|
if add_wait:
|
||||||
wait_start_time = datetime.datetime.utcnow() -\
|
wait_start_time = timeutils.utcnow() -\
|
||||||
datetime.timedelta(minutes=1)
|
datetime.timedelta(minutes=1)
|
||||||
bmc_component['wait_start_time'] = wait_start_time.isoformat()
|
bmc_component['wait_start_time'] = wait_start_time.isoformat()
|
||||||
bios_component['wait_start_time'] = wait_start_time.isoformat()
|
bios_component['wait_start_time'] = wait_start_time.isoformat()
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
import datetime
|
import datetime
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
|
from oslo_utils import timeutils
|
||||||
from oslo_utils import units
|
from oslo_utils import units
|
||||||
import sushy
|
import sushy
|
||||||
|
|
||||||
@ -1281,8 +1282,7 @@ class RedfishManagementTestCase(db_base.DbTestCase):
|
|||||||
mock_update_service = mock.Mock()
|
mock_update_service = mock.Mock()
|
||||||
mock_get_update_service.return_value = mock_update_service
|
mock_get_update_service.return_value = mock_update_service
|
||||||
|
|
||||||
wait_start_time = datetime.datetime.utcnow() -\
|
wait_start_time = timeutils.utcnow() - datetime.timedelta(minutes=15)
|
||||||
datetime.timedelta(minutes=15)
|
|
||||||
driver_internal_info = {
|
driver_internal_info = {
|
||||||
'firmware_updates': [
|
'firmware_updates': [
|
||||||
{'task_monitor': '/task/123',
|
{'task_monitor': '/task/123',
|
||||||
@ -1312,8 +1312,7 @@ class RedfishManagementTestCase(db_base.DbTestCase):
|
|||||||
mock_update_service = mock.Mock()
|
mock_update_service = mock.Mock()
|
||||||
mock_get_update_service.return_value = mock_update_service
|
mock_get_update_service.return_value = mock_update_service
|
||||||
|
|
||||||
wait_start_time = datetime.datetime.utcnow() -\
|
wait_start_time = timeutils.utcnow() - datetime.timedelta(minutes=1)
|
||||||
datetime.timedelta(minutes=1)
|
|
||||||
driver_internal_info = {
|
driver_internal_info = {
|
||||||
'firmware_updates': [
|
'firmware_updates': [
|
||||||
{'task_monitor': '/task/123',
|
{'task_monitor': '/task/123',
|
||||||
|
@ -13,6 +13,8 @@
|
|||||||
import datetime
|
import datetime
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
|
from oslo_utils import timeutils
|
||||||
|
|
||||||
from ironic.common import exception
|
from ironic.common import exception
|
||||||
from ironic.common import states
|
from ironic.common import states
|
||||||
from ironic.conductor import task_manager
|
from ironic.conductor import task_manager
|
||||||
@ -30,7 +32,7 @@ class AgentPowerTest(db_base.DbTestCase):
|
|||||||
self.config(fast_track=True, group='deploy')
|
self.config(fast_track=True, group='deploy')
|
||||||
self.power = agent_power.AgentPower()
|
self.power = agent_power.AgentPower()
|
||||||
dii = {
|
dii = {
|
||||||
'agent_last_heartbeat': datetime.datetime.utcnow().strftime(
|
'agent_last_heartbeat': timeutils.utcnow().strftime(
|
||||||
"%Y-%m-%dT%H:%M:%S.%f"),
|
"%Y-%m-%dT%H:%M:%S.%f"),
|
||||||
'deployment_reboot': True,
|
'deployment_reboot': True,
|
||||||
'agent_url': 'http://url',
|
'agent_url': 'http://url',
|
||||||
|
@ -23,6 +23,7 @@ import time
|
|||||||
from unittest import mock
|
from unittest import mock
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
|
from oslo_utils import timeutils
|
||||||
from oslo_utils import uuidutils
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
from ironic.common import exception
|
from ironic.common import exception
|
||||||
@ -336,7 +337,7 @@ class TestUpdateImages(BaseTest):
|
|||||||
touch(self.master_path)
|
touch(self.master_path)
|
||||||
href = 'http://awesomefreeimages.al/img999'
|
href = 'http://awesomefreeimages.al/img999'
|
||||||
self.img_info = {
|
self.img_info = {
|
||||||
'updated_at': datetime.datetime((datetime.datetime.utcnow().year
|
'updated_at': datetime.datetime((timeutils.utcnow().year
|
||||||
+ 1), 11, 15, 8, 12, 31)
|
+ 1), 11, 15, 8, 12, 31)
|
||||||
}
|
}
|
||||||
res = image_cache._delete_master_path_if_stale(self.master_path, href,
|
res = image_cache._delete_master_path_if_stale(self.master_path, href,
|
||||||
|
Loading…
Reference in New Issue
Block a user