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.

Change-Id: I421d8e9a8e0bcee3ce3344f925a55f4f9f0d695d
This commit is contained in:
cid 2024-06-02 06:18:52 -05:00
parent 7df15bd99e
commit 2d909b4168
4 changed files with 19 additions and 18 deletions

View File

@ -14,7 +14,6 @@
"""Handling introspection data from the ramdisk."""
import copy
import datetime
import os
from oslo_config import cfg
@ -56,7 +55,7 @@ def _store_logs(introspection_data, node_info):
'uuid': node_info.uuid if node_info is not None else 'unknown',
'mac': (utils.get_pxe_mac(introspection_data) or
'unknown').replace(':', ''),
'dt': datetime.datetime.utcnow(),
'dt': timeutils.utcnow(),
'bmc': (utils.get_ipmi_address_from_data(introspection_data) or
'unknown')
}

View File

@ -37,6 +37,7 @@ from oslo_db.sqlalchemy import test_fixtures
from oslo_db.sqlalchemy import test_migrations
from oslo_db.sqlalchemy import utils as db_utils
from oslo_log import log as logging
from oslo_utils import timeutils
from oslo_utils import uuidutils
from oslotest import base as test_base
import sqlalchemy
@ -382,7 +383,7 @@ class MigrationCheckersMixin(object):
with engine.begin() as connection:
node = {
'uuid': self.node_uuid,
'started_at': datetime.datetime.utcnow(),
'started_at': timeutils.utcnow(),
'finished_at': None,
'error': None,
'state': istate.States.starting

View File

@ -401,7 +401,8 @@ class TestSync(DnsmasqTestBase):
self.mock_ironic = mock.Mock()
self.mock_utcnow = self.useFixture(
fixtures.MockPatchObject(dnsmasq.timeutils, 'utcnow')).mock
self.timestamp_start = datetime.datetime.utcnow()
self.timestamp_start = datetime.datetime.now(
datetime.timezone.utc).replace(tzinfo=None)
self.timestamp_end = (self.timestamp_start +
datetime.timedelta(seconds=42))
self.mock_utcnow.side_effect = [self.timestamp_start,

View File

@ -52,9 +52,9 @@ class TestNodeCache(test_base.NodeTestBase):
foo=None)
self.assertEqual(self.uuid, node.uuid)
self.assertTrue(
(datetime.datetime.utcnow() - datetime.timedelta(seconds=60)
(timeutils.utcnow() - datetime.timedelta(seconds=60)
< node.started_at <
datetime.datetime.utcnow() + datetime.timedelta(seconds=60)))
timeutils.utcnow() + datetime.timedelta(seconds=60)))
self.assertFalse(node._node_lock.is_locked())
res = set((r.uuid, r.started_at) for r in db.get_nodes())
@ -193,9 +193,9 @@ class TestNodeCacheFind(test_base.NodeTestBase):
self.addCleanup(res.release_lock)
self.assertEqual(self.uuid, res.uuid)
self.assertTrue(
datetime.datetime.utcnow() - datetime.timedelta(seconds=60)
timeutils.utcnow() - datetime.timedelta(seconds=60)
< res.started_at <
datetime.datetime.utcnow() + datetime.timedelta(seconds=1))
timeutils.utcnow() + datetime.timedelta(seconds=1))
self.assertTrue(res._node_lock.is_locked())
def test_same_bmc_different_macs(self):
@ -224,9 +224,9 @@ class TestNodeCacheFind(test_base.NodeTestBase):
self.addCleanup(res.release_lock)
self.assertEqual(self.uuid, res.uuid)
self.assertTrue(
datetime.datetime.utcnow() - datetime.timedelta(seconds=60)
timeutils.utcnow() - datetime.timedelta(seconds=60)
< res.started_at <
datetime.datetime.utcnow() + datetime.timedelta(seconds=1))
timeutils.utcnow() + datetime.timedelta(seconds=1))
self.assertTrue(res._node_lock.is_locked())
def test_macs_not_found(self):
@ -247,9 +247,9 @@ class TestNodeCacheFind(test_base.NodeTestBase):
self.addCleanup(res.release_lock)
self.assertEqual(self.uuid, res.uuid)
self.assertTrue(
datetime.datetime.utcnow() - datetime.timedelta(seconds=60)
timeutils.utcnow() - datetime.timedelta(seconds=60)
< res.started_at <
datetime.datetime.utcnow() + datetime.timedelta(seconds=1))
timeutils.utcnow() + datetime.timedelta(seconds=1))
self.assertTrue(res._node_lock.is_locked())
def test_inconsistency(self):
@ -258,8 +258,7 @@ class TestNodeCacheFind(test_base.NodeTestBase):
bmc_address='1.2.3.4')
def test_already_finished(self):
db.update_node(self.uuid,
finished_at=datetime.datetime.utcnow())
db.update_node(self.uuid, finished_at=timeutils.utcnow())
self.assertRaises(utils.Error, node_cache.find_node,
bmc_address='1.2.3.4')
@ -272,7 +271,7 @@ class TestNodeCacheFind(test_base.NodeTestBase):
class TestNodeCacheCleanUp(test_base.NodeTestBase):
def setUp(self):
super(TestNodeCacheCleanUp, self).setUp()
self.started_at = datetime.datetime.utcnow()
self.started_at = timeutils.utcnow()
db.create_node(uuid=self.uuid,
state=istate.States.waiting,
started_at=self.started_at)
@ -297,7 +296,8 @@ class TestNodeCacheCleanUp(test_base.NodeTestBase):
@mock.patch.object(locking, 'get_lock', autospec=True)
@mock.patch.object(timeutils, 'utcnow', autospec=True)
def test_ok(self, time_mock, get_lock_mock):
time_mock.return_value = datetime.datetime.utcnow()
time_mock.return_value = datetime.datetime.now(
datetime.timezone.utc).replace(tzinfo=None)
self.assertFalse(node_cache.clean_up())
@ -377,7 +377,7 @@ class TestNodeCacheCleanUp(test_base.NodeTestBase):
class TestNodeCacheGetNode(test_base.NodeTestBase):
def test_ok(self):
started_at = (datetime.datetime.utcnow() -
started_at = (timeutils.utcnow() -
datetime.timedelta(seconds=42))
db.create_node(uuid=self.uuid,
state=istate.States.starting,
@ -395,7 +395,7 @@ class TestNodeCacheGetNode(test_base.NodeTestBase):
uuidutils.generate_uuid())
def test_with_name(self):
started_at = (datetime.datetime.utcnow() -
started_at = (timeutils.utcnow() -
datetime.timedelta(seconds=42))
db.create_node(
uuid=self.uuid,