From 61a7dd85ca2e7fb376e292197f076a3372536671 Mon Sep 17 00:00:00 2001 From: Takashi Natsume Date: Wed, 2 Oct 2024 22:17:02 +0900 Subject: [PATCH] Replace deprecated datetime.utcnow() The datetime.utcnow() is deprecated in Python 3.12. Replace datetime.utcnow() with oslo_utils.timeutils.utcnow(). This bumps oslo.utils to 7.0.0. Change-Id: Icccbb0549add686a744a72b354932471cbf91c92 Signed-off-by: Takashi Natsume --- requirements.txt | 2 +- watcher/api/controllers/v1/action.py | 7 +++---- watcher/api/controllers/v1/action_plan.py | 7 +++---- watcher/api/controllers/v1/audit.py | 20 +++++++++---------- watcher/api/controllers/v1/audit_template.py | 7 +++---- watcher/common/service.py | 3 ++- watcher/decision_engine/audit/continuous.py | 13 ++++++------ .../decision_engine/datasources/ceilometer.py | 2 +- .../decision_engine/datasources/gnocchi.py | 4 ++-- .../decision_engine/datasources/monasca.py | 6 +++--- watcher/objects/action_plan.py | 4 +++- watcher/tests/api/test_scheduling.py | 9 +++++---- watcher/tests/api/utils.py | 4 +++- .../audit/test_audit_handlers.py | 3 ++- .../notification/test_cinder_notifications.py | 4 ++-- .../test_service_notifications.py | 4 ++-- watcher/tests/objects/test_action.py | 8 ++++---- .../tests/objects/test_action_description.py | 8 ++++---- watcher/tests/objects/test_action_plan.py | 14 ++++++------- watcher/tests/objects/test_audit.py | 16 +++++++-------- watcher/tests/objects/test_audit_template.py | 14 ++++++------- watcher/tests/objects/test_goal.py | 8 ++++---- watcher/tests/objects/test_scoring_engine.py | 8 ++++---- watcher/tests/objects/test_service.py | 8 ++++---- 24 files changed, 94 insertions(+), 89 deletions(-) diff --git a/requirements.txt b/requirements.txt index a5c9930dc..b669bfaf6 100644 --- a/requirements.txt +++ b/requirements.txt @@ -22,7 +22,7 @@ oslo.reports>=1.27.0 # Apache-2.0 oslo.serialization>=2.25.0 # Apache-2.0 oslo.service>=1.30.0 # Apache-2.0 oslo.upgradecheck>=1.3.0 # Apache-2.0 -oslo.utils>=3.36.0 # Apache-2.0 +oslo.utils>=7.0.0 # Apache-2.0 oslo.versionedobjects>=1.32.0 # Apache-2.0 PasteDeploy>=1.5.2 # MIT pbr>=3.1.1 # Apache-2.0 diff --git a/watcher/api/controllers/v1/action.py b/watcher/api/controllers/v1/action.py index 3f803579d..477483509 100644 --- a/watcher/api/controllers/v1/action.py +++ b/watcher/api/controllers/v1/action.py @@ -55,9 +55,8 @@ possible to :ref:`develop new implementations ` which are dynamically loaded by Watcher at launch time. """ -import datetime - from http import HTTPStatus +from oslo_utils import timeutils import pecan from pecan import rest import wsme @@ -194,9 +193,9 @@ class Action(base.APIBase): sample = cls(uuid='27e3153e-d5bf-4b7e-b517-fb518e17f34c', description='action description', state='PENDING', - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), deleted_at=None, - updated_at=datetime.datetime.utcnow(), + updated_at=timeutils.utcnow(), parents=[]) sample._action_plan_uuid = '7ae81bb3-dec3-4289-8d6c-da80bd8001ae' return cls._convert_with_links(sample, 'http://localhost:9322', expand) diff --git a/watcher/api/controllers/v1/action_plan.py b/watcher/api/controllers/v1/action_plan.py index 0ad331ec8..01f3a674c 100644 --- a/watcher/api/controllers/v1/action_plan.py +++ b/watcher/api/controllers/v1/action_plan.py @@ -54,10 +54,9 @@ To see the life-cycle and description of state machine `. """ -import datetime - from http import HTTPStatus from oslo_log import log +from oslo_utils import timeutils import pecan from pecan import rest import wsme @@ -293,9 +292,9 @@ class ActionPlan(base.APIBase): def sample(cls, expand=True): sample = cls(uuid='9ef4d84c-41e8-4418-9220-ce55be0436af', state='ONGOING', - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), deleted_at=None, - updated_at=datetime.datetime.utcnow()) + updated_at=timeutils.utcnow()) sample._audit_uuid = 'abcee106-14d3-4515-b744-5a26885cf6f6' sample._efficacy_indicators = [{'description': 'Test indicator', 'name': 'test_indicator', diff --git a/watcher/api/controllers/v1/audit.py b/watcher/api/controllers/v1/audit.py index e998bc203..d9ef67d2d 100644 --- a/watcher/api/controllers/v1/audit.py +++ b/watcher/api/controllers/v1/audit.py @@ -33,6 +33,8 @@ import datetime from dateutil import tz from http import HTTPStatus +from oslo_log import log +from oslo_utils import timeutils import pecan from pecan import rest import wsme @@ -40,8 +42,6 @@ from wsme import types as wtypes from wsme import utils as wutils import wsmeext.pecan as wsme_pecan -from oslo_log import log - from watcher._i18n import _ from watcher.api.controllers import base from watcher.api.controllers import link @@ -171,16 +171,16 @@ class AuditPostType(wtypes.Base): strategy = _get_object_by_value(context, objects.Strategy, self.strategy) self.name = "%s-%s" % (strategy.name, - datetime.datetime.utcnow().isoformat()) + timeutils.utcnow().isoformat()) elif self.audit_template_uuid: audit_template = objects.AuditTemplate.get( context, self.audit_template_uuid) self.name = "%s-%s" % (audit_template.name, - datetime.datetime.utcnow().isoformat()) + timeutils.utcnow().isoformat()) else: goal = _get_object_by_value(context, objects.Goal, self.goal) self.name = "%s-%s" % (goal.name, - datetime.datetime.utcnow().isoformat()) + timeutils.utcnow().isoformat()) # No more than 63 characters if len(self.name) > 63: LOG.warning("Audit: %s length exceeds 63 characters", @@ -424,15 +424,15 @@ class Audit(base.APIBase): name='My Audit', audit_type='ONESHOT', state='PENDING', - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), deleted_at=None, - updated_at=datetime.datetime.utcnow(), + updated_at=timeutils.utcnow(), interval='7200', scope=[], auto_trigger=False, - next_run_time=datetime.datetime.utcnow(), - start_time=datetime.datetime.utcnow(), - end_time=datetime.datetime.utcnow()) + next_run_time=timeutils.utcnow(), + start_time=timeutils.utcnow(), + end_time=timeutils.utcnow()) sample.goal_id = '7ae81bb3-dec3-4289-8d6c-da80bd8001ae' sample.strategy_id = '7ae81bb3-dec3-4289-8d6c-da80bd8001ff' diff --git a/watcher/api/controllers/v1/audit_template.py b/watcher/api/controllers/v1/audit_template.py index ac57c0bba..57756729e 100644 --- a/watcher/api/controllers/v1/audit_template.py +++ b/watcher/api/controllers/v1/audit_template.py @@ -43,9 +43,8 @@ will be launched automatically or will need a manual confirmation from the :ref:`Administrator `. """ -import datetime - from http import HTTPStatus +from oslo_utils import timeutils import pecan from pecan import rest import wsme @@ -440,9 +439,9 @@ class AuditTemplate(base.APIBase): description='Description of my audit template', goal_uuid='83e44733-b640-40e2-8d8a-7dd3be7134e6', strategy_uuid='367d826e-b6a4-4b70-bc44-c3f6fe1c9986', - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), deleted_at=None, - updated_at=datetime.datetime.utcnow(), + updated_at=timeutils.utcnow(), scope=[],) return cls._convert_with_links(sample, 'http://localhost:9322', expand) diff --git a/watcher/common/service.py b/watcher/common/service.py index 816b05533..8dbc9627f 100644 --- a/watcher/common/service.py +++ b/watcher/common/service.py @@ -26,6 +26,7 @@ from oslo_reports import guru_meditation_report as gmr from oslo_reports import opts as gmr_opts from oslo_service import service from oslo_service import wsgi +from oslo_utils import timeutils from watcher._i18n import _ from watcher.api import app @@ -120,7 +121,7 @@ class ServiceHeartbeat(scheduling.BackgroundSchedulerService): 'host': host}) if watcher_list: watcher_service = watcher_list[0] - watcher_service.last_seen_up = datetime.datetime.utcnow() + watcher_service.last_seen_up = timeutils.utcnow() watcher_service.save() else: watcher_service = objects.Service(self.context) diff --git a/watcher/decision_engine/audit/continuous.py b/watcher/decision_engine/audit/continuous.py index 391d817e1..cc4b14b8f 100644 --- a/watcher/decision_engine/audit/continuous.py +++ b/watcher/decision_engine/audit/continuous.py @@ -19,9 +19,10 @@ import datetime -from dateutil import tz from croniter import croniter +from dateutil import tz +from oslo_utils import timeutils from watcher.common import context from watcher.common import scheduling @@ -97,7 +98,7 @@ class ContinuousAuditHandler(base.AuditHandler): @staticmethod def _next_cron_time(audit): if utils.is_cron_like(audit.interval): - return croniter(audit.interval, datetime.datetime.utcnow() + return croniter(audit.interval, timeutils.utcnow() ).get_next(datetime.datetime) @classmethod @@ -111,7 +112,7 @@ class ContinuousAuditHandler(base.AuditHandler): finally: if utils.is_int_like(audit.interval): audit.next_run_time = ( - datetime.datetime.utcnow() + + timeutils.utcnow() + datetime.timedelta(seconds=int(audit.interval))) else: audit.next_run_time = self._next_cron_time(audit) @@ -129,7 +130,7 @@ class ContinuousAuditHandler(base.AuditHandler): **trigger_args) def check_audit_expired(self, audit): - current = datetime.datetime.utcnow() + current = timeutils.utcnow() # Note: if audit still didn't get into the timeframe, # skip it if audit.start_time and audit.start_time > current: @@ -196,7 +197,7 @@ class ContinuousAuditHandler(base.AuditHandler): # to restore it after shutdown if audit.next_run_time is not None: old_run_time = audit.next_run_time - current = datetime.datetime.utcnow() + current = timeutils.utcnow() if old_run_time < current: delta = datetime.timedelta( seconds=(int(audit.interval) - ( @@ -206,7 +207,7 @@ class ContinuousAuditHandler(base.AuditHandler): next_run_time = audit.next_run_time # if audit is new one else: - next_run_time = datetime.datetime.utcnow() + next_run_time = timeutils.utcnow() self._add_job('interval', audit, audit_context, seconds=int(audit.interval), next_run_time=next_run_time) diff --git a/watcher/decision_engine/datasources/ceilometer.py b/watcher/decision_engine/datasources/ceilometer.py index a20fd42c4..b7df09b6a 100644 --- a/watcher/decision_engine/datasources/ceilometer.py +++ b/watcher/decision_engine/datasources/ceilometer.py @@ -158,7 +158,7 @@ class CeilometerHelper(base.DataSourceBase): def statistic_aggregation(self, resource=None, resource_type=None, meter_name=None, period=300, granularity=300, aggregate='mean'): - end_time = datetime.datetime.utcnow() + end_time = timeutils.utcnow() start_time = end_time - datetime.timedelta(seconds=int(period)) meter = self._get_meter(meter_name) diff --git a/watcher/decision_engine/datasources/gnocchi.py b/watcher/decision_engine/datasources/gnocchi.py index 8261d381c..fc9920ded 100644 --- a/watcher/decision_engine/datasources/gnocchi.py +++ b/watcher/decision_engine/datasources/gnocchi.py @@ -16,12 +16,12 @@ # See the License for the specific language governing permissions and # limitations under the License. -from datetime import datetime from datetime import timedelta from gnocchiclient import exceptions as gnc_exc from oslo_config import cfg from oslo_log import log +from oslo_utils import timeutils from watcher.common import clients from watcher.decision_engine.datasources import base @@ -69,7 +69,7 @@ class GnocchiHelper(base.DataSourceBase): def statistic_aggregation(self, resource=None, resource_type=None, meter_name=None, period=300, aggregate='mean', granularity=300): - stop_time = datetime.utcnow() + stop_time = timeutils.utcnow() start_time = stop_time - timedelta(seconds=(int(period))) meter = self._get_meter(meter_name) diff --git a/watcher/decision_engine/datasources/monasca.py b/watcher/decision_engine/datasources/monasca.py index 951a62835..d1e9f6d4b 100644 --- a/watcher/decision_engine/datasources/monasca.py +++ b/watcher/decision_engine/datasources/monasca.py @@ -19,6 +19,7 @@ import datetime from monascaclient import exc +from oslo_utils import timeutils from watcher.common import clients from watcher.decision_engine.datasources import base @@ -58,8 +59,7 @@ class MonascaHelper(base.DataSourceBase): period = int(datetime.timedelta(hours=3).total_seconds()) if not start_time: start_time = ( - datetime.datetime.utcnow() - - datetime.timedelta(seconds=period)) + timeutils.utcnow() - datetime.timedelta(seconds=period)) start_timestamp = None if not start_time else start_time.isoformat() end_timestamp = None if not end_time else end_time.isoformat() @@ -86,7 +86,7 @@ class MonascaHelper(base.DataSourceBase): def statistic_aggregation(self, resource=None, resource_type=None, meter_name=None, period=300, aggregate='mean', granularity=300): - stop_time = datetime.datetime.utcnow() + stop_time = timeutils.utcnow() start_time = stop_time - datetime.timedelta(seconds=(int(period))) meter = self._get_meter(meter_name) diff --git a/watcher/objects/action_plan.py b/watcher/objects/action_plan.py index 1807d900e..c35e8e4a6 100644 --- a/watcher/objects/action_plan.py +++ b/watcher/objects/action_plan.py @@ -73,6 +73,8 @@ state may be one of the following: """ import datetime +from oslo_utils import timeutils + from watcher.common import exception from watcher.common import utils from watcher import conf @@ -332,7 +334,7 @@ class StateManager(object): def check_expired(self, context): action_plan_expiry = ( CONF.watcher_decision_engine.action_plan_expiry) - date_created = datetime.datetime.utcnow() - datetime.timedelta( + date_created = timeutils.utcnow() - datetime.timedelta( hours=action_plan_expiry) filters = {'state__eq': State.RECOMMENDED, 'created_at__lt': date_created} diff --git a/watcher/tests/api/test_scheduling.py b/watcher/tests/api/test_scheduling.py index bdbcb900e..f18e97f23 100644 --- a/watcher/tests/api/test_scheduling.py +++ b/watcher/tests/api/test_scheduling.py @@ -12,11 +12,12 @@ # License for the specific language governing permissions and limitations # under the License. -from apscheduler.schedulers import background -import datetime -import freezegun from unittest import mock +from apscheduler.schedulers import background +import freezegun +from oslo_utils import timeutils + from watcher.api import scheduling from watcher.notifications import service from watcher import objects @@ -41,7 +42,7 @@ class TestSchedulingServiceFunctions(db_base.DbTestCase): def setUp(self): super(TestSchedulingServiceFunctions, self).setUp() fake_service = utils.get_test_service( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) self.fake_service = objects.Service(**fake_service) @mock.patch.object(scheduling.APISchedulingService, 'get_service_status') diff --git a/watcher/tests/api/utils.py b/watcher/tests/api/utils.py index 221eb7697..4766be6de 100644 --- a/watcher/tests/api/utils.py +++ b/watcher/tests/api/utils.py @@ -16,7 +16,9 @@ Utils for testing the API service. """ import datetime + from oslo_serialization import jsonutils +from oslo_utils import timeutils from watcher.api.controllers.v1 import action as action_ctrl from watcher.api.controllers.v1 import action_plan as action_plan_ctrl @@ -65,7 +67,7 @@ class FakeMemcache(object): self.token_expiration = None def get(self, key): - dt = datetime.datetime.utcnow() + datetime.timedelta(minutes=5) + dt = timeutils.utcnow() + datetime.timedelta(minutes=5) return jsonutils.dumps((self._cache.get(key), dt.isoformat())) def set(self, key, value, time=0, min_compress_len=0): diff --git a/watcher/tests/decision_engine/audit/test_audit_handlers.py b/watcher/tests/decision_engine/audit/test_audit_handlers.py index d9f67532d..58becc3a8 100644 --- a/watcher/tests/decision_engine/audit/test_audit_handlers.py +++ b/watcher/tests/decision_engine/audit/test_audit_handlers.py @@ -18,6 +18,7 @@ import datetime from unittest import mock from oslo_config import cfg +from oslo_utils import timeutils from oslo_utils import uuidutils from apscheduler import job @@ -486,7 +487,7 @@ class TestContinuousAuditHandler(base.DbTestCase): self.assertFalse(is_inactive) def test_check_audit_expired(self): - current = datetime.datetime.utcnow() + current = timeutils.utcnow() # start_time and end_time are None audit_handler = continuous.ContinuousAuditHandler() diff --git a/watcher/tests/decision_engine/model/notification/test_cinder_notifications.py b/watcher/tests/decision_engine/model/notification/test_cinder_notifications.py index 439ff43d8..22c73429f 100644 --- a/watcher/tests/decision_engine/model/notification/test_cinder_notifications.py +++ b/watcher/tests/decision_engine/model/notification/test_cinder_notifications.py @@ -14,11 +14,11 @@ # See the License for the specific language governing permissions and # limitations under the License. -import datetime import os from unittest import mock from oslo_serialization import jsonutils +from oslo_utils import timeutils from watcher.common import cinder_helper from watcher.common import context @@ -64,7 +64,7 @@ class TestReceiveCinderNotifications(NotificationTestCase): m_get_service_list = p_get_service_list.start() m_update_service = p_update_service.start() fake_service = utils.get_test_service( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) m_get_service_list.return_value = [fake_service] m_update_service.return_value = fake_service.copy() diff --git a/watcher/tests/notifications/test_service_notifications.py b/watcher/tests/notifications/test_service_notifications.py index 9298a93d2..201d8d04a 100644 --- a/watcher/tests/notifications/test_service_notifications.py +++ b/watcher/tests/notifications/test_service_notifications.py @@ -14,11 +14,11 @@ # See the License for the specific language governing permissions and # limitations under the License. -import datetime from unittest import mock import freezegun import oslo_messaging as om +from oslo_utils import timeutils from watcher.common import rpc from watcher import notifications @@ -45,7 +45,7 @@ class TestActionPlanNotification(base.DbTestCase): def test_service_failed(self): service = utils.get_test_service(mock.Mock(), - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) state = w_service.ServiceStatus.FAILED notifications.service.send_service_update(mock.MagicMock(), service, diff --git a/watcher/tests/objects/test_action.py b/watcher/tests/objects/test_action.py index 462588d86..04b5e1eca 100644 --- a/watcher/tests/objects/test_action.py +++ b/watcher/tests/objects/test_action.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.common import exception from watcher.common import utils as c_utils @@ -123,7 +123,7 @@ class TestActionObject(base.DbTestCase): uuid=c_utils.generate_uuid()) mock_get_strategy.return_value = mock.PropertyMock( uuid=c_utils.generate_uuid()) - fake_saved_action['updated_at'] = datetime.datetime.utcnow() + fake_saved_action['updated_at'] = timeutils.utcnow() mock_update_action.return_value = fake_saved_action uuid = self.fake_action['uuid'] action = objects.Action.get_by_uuid( @@ -172,7 +172,7 @@ class TestCreateDeleteActionObject(base.DbTestCase): self.fake_audit = utils.create_test_audit() self.fake_action_plan = utils.create_test_action_plan() self.fake_action = utils.get_test_action( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'create_action') def test_create(self, mock_create_action): @@ -195,7 +195,7 @@ class TestCreateDeleteActionObject(base.DbTestCase): mock_send_update, mock_send_delete): mock_get_action.return_value = self.fake_action fake_deleted_action = self.fake_action.copy() - fake_deleted_action['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_action['deleted_at'] = timeutils.utcnow() mock_soft_delete_action.return_value = fake_deleted_action mock_update_action.return_value = fake_deleted_action diff --git a/watcher/tests/objects/test_action_description.py b/watcher/tests/objects/test_action_description.py index 966808684..f017a4b86 100644 --- a/watcher/tests/objects/test_action_description.py +++ b/watcher/tests/objects/test_action_description.py @@ -14,10 +14,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.db.sqlalchemy import api as db_api from watcher import objects @@ -30,7 +30,7 @@ class TestActionDescriptionObject(base.DbTestCase): def setUp(self): super(TestActionDescriptionObject, self).setUp() self.fake_action_desc = utils.get_test_action_desc( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'get_action_description_by_id') def test_get_by_id(self, mock_get_action_desc): @@ -70,7 +70,7 @@ class TestActionDescriptionObject(base.DbTestCase): def test_save(self, mock_get_action_desc, mock_update_action_desc): mock_get_action_desc.return_value = self.fake_action_desc fake_saved_action_desc = self.fake_action_desc.copy() - fake_saved_action_desc['updated_at'] = datetime.datetime.utcnow() + fake_saved_action_desc['updated_at'] = timeutils.utcnow() mock_update_action_desc.return_value = fake_saved_action_desc _id = self.fake_action_desc['id'] action_desc = objects.ActionDescription.get(self.context, _id) @@ -102,7 +102,7 @@ class TestActionDescriptionObject(base.DbTestCase): def test_soft_delete(self, mock_get_action_desc, mock_soft_delete): mock_get_action_desc.return_value = self.fake_action_desc fake_deleted_action_desc = self.fake_action_desc.copy() - fake_deleted_action_desc['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_action_desc['deleted_at'] = timeutils.utcnow() mock_soft_delete.return_value = fake_deleted_action_desc expected_action_desc = fake_deleted_action_desc.copy() diff --git a/watcher/tests/objects/test_action_plan.py b/watcher/tests/objects/test_action_plan.py index a25e8720d..6b40a19a5 100644 --- a/watcher/tests/objects/test_action_plan.py +++ b/watcher/tests/objects/test_action_plan.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.common import exception from watcher.common import utils as common_utils @@ -39,19 +39,19 @@ class TestActionPlanObject(base.DbTestCase): ('non_eager', dict( eager=False, fake_action_plan=utils.get_test_action_plan( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), audit_id=audit_id, strategy_id=strategy_id))), ('eager_with_non_eager_load', dict( eager=True, fake_action_plan=utils.get_test_action_plan( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), audit_id=audit_id, strategy_id=strategy_id))), ('eager_with_eager_load', dict( eager=True, fake_action_plan=utils.get_test_action_plan( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), strategy_id=strategy_id, strategy=utils.get_test_strategy(id=strategy_id), audit_id=audit_id, @@ -132,7 +132,7 @@ class TestActionPlanObject(base.DbTestCase): mock_get_action_plan.return_value = self.fake_action_plan fake_saved_action_plan = self.fake_action_plan.copy() fake_saved_action_plan['state'] = objects.action_plan.State.SUCCEEDED - fake_saved_action_plan['updated_at'] = datetime.datetime.utcnow() + fake_saved_action_plan['updated_at'] = timeutils.utcnow() mock_update_action_plan.return_value = fake_saved_action_plan @@ -197,7 +197,7 @@ class TestCreateDeleteActionPlanObject(base.DbTestCase): self.fake_strategy = utils.create_test_strategy(name="DUMMY") self.fake_audit = utils.create_test_audit() self.fake_action_plan = utils.get_test_action_plan( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'create_action_plan') def test_create(self, mock_create_action_plan): @@ -234,7 +234,7 @@ class TestCreateDeleteActionPlanObject(base.DbTestCase): m_get_action_plan.return_value = self.fake_action_plan fake_deleted_action_plan = self.fake_action_plan.copy() - fake_deleted_action_plan['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_action_plan['deleted_at'] = timeutils.utcnow() m_update_action_plan.return_value = fake_deleted_action_plan m_soft_delete_action_plan.return_value = fake_deleted_action_plan expected_action_plan = fake_deleted_action_plan.copy() diff --git a/watcher/tests/objects/test_audit.py b/watcher/tests/objects/test_audit.py index d16dbb3e4..ae69e4e2b 100644 --- a/watcher/tests/objects/test_audit.py +++ b/watcher/tests/objects/test_audit.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.common import exception from watcher.common import rpc @@ -40,17 +40,17 @@ class TestAuditObject(base.DbTestCase): ('non_eager', dict( eager=False, fake_audit=utils.get_test_audit( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), goal_id=goal_id))), ('eager_with_non_eager_load', dict( eager=True, fake_audit=utils.get_test_audit( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), goal_id=goal_id))), ('eager_with_eager_load', dict( eager=True, fake_audit=utils.get_test_audit( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), goal_id=goal_id, goal=goal_data))), ] @@ -125,7 +125,7 @@ class TestAuditObject(base.DbTestCase): mock_get_audit.return_value = self.fake_audit fake_saved_audit = self.fake_audit.copy() fake_saved_audit['state'] = objects.audit.State.SUCCEEDED - fake_saved_audit['updated_at'] = datetime.datetime.utcnow() + fake_saved_audit['updated_at'] = timeutils.utcnow() mock_update_audit.return_value = fake_saved_audit expected_audit = fake_saved_audit.copy() @@ -184,7 +184,7 @@ class TestCreateDeleteAuditObject(base.DbTestCase): self.goal_id = 1 self.goal = utils.create_test_goal(id=self.goal_id, name="DUMMY") self.fake_audit = utils.get_test_audit( - goal_id=self.goal_id, created_at=datetime.datetime.utcnow()) + goal_id=self.goal_id, created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'create_audit') def test_create(self, mock_create_audit): @@ -204,7 +204,7 @@ class TestCreateDeleteAuditObject(base.DbTestCase): mock_soft_delete_audit, mock_update_audit): mock_get_audit.return_value = self.fake_audit fake_deleted_audit = self.fake_audit.copy() - fake_deleted_audit['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_audit['deleted_at'] = timeutils.utcnow() mock_soft_delete_audit.return_value = fake_deleted_audit mock_update_audit.return_value = fake_deleted_audit @@ -305,7 +305,7 @@ class TestAuditObjectSendNotifications(base.DbTestCase): strategy=self.fake_strategy.as_dict()) m_get_audit.return_value = fake_audit fake_deleted_audit = self.fake_audit.copy() - fake_deleted_audit['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_audit['deleted_at'] = timeutils.utcnow() expected_audit = fake_deleted_audit.copy() expected_audit['deleted_at'] = expected_audit['deleted_at'].replace( tzinfo=iso8601.UTC) diff --git a/watcher/tests/objects/test_audit_template.py b/watcher/tests/objects/test_audit_template.py index 8d62cef11..4403c4aea 100644 --- a/watcher/tests/objects/test_audit_template.py +++ b/watcher/tests/objects/test_audit_template.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.common import exception from watcher.common import utils as w_utils @@ -37,17 +37,17 @@ class TestAuditTemplateObject(base.DbTestCase): ('non_eager', dict( eager=False, fake_audit_template=utils.get_test_audit_template( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), goal_id=goal_id))), ('eager_with_non_eager_load', dict( eager=True, fake_audit_template=utils.get_test_audit_template( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), goal_id=goal_id))), ('eager_with_eager_load', dict( eager=True, fake_audit_template=utils.get_test_audit_template( - created_at=datetime.datetime.utcnow(), + created_at=timeutils.utcnow(), goal_id=goal_id, goal=goal_data))), ] @@ -127,7 +127,7 @@ class TestAuditTemplateObject(base.DbTestCase): def test_save(self, mock_get_audit_template, mock_update_audit_template): mock_get_audit_template.return_value = self.fake_audit_template fake_saved_audit_template = self.fake_audit_template.copy() - fake_saved_audit_template['updated_at'] = datetime.datetime.utcnow() + fake_saved_audit_template['updated_at'] = timeutils.utcnow() mock_update_audit_template.return_value = fake_saved_audit_template uuid = self.fake_audit_template['uuid'] audit_template = objects.AuditTemplate.get_by_uuid( @@ -165,7 +165,7 @@ class TestCreateDeleteAuditTemplateObject(base.DbTestCase): def setUp(self): super(TestCreateDeleteAuditTemplateObject, self).setUp() self.fake_audit_template = utils.get_test_audit_template( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'create_audit_template') def test_create(self, mock_create_audit_template): @@ -188,7 +188,7 @@ class TestCreateDeleteAuditTemplateObject(base.DbTestCase): m_soft_delete_audit_template): m_get_audit_template.return_value = self.fake_audit_template fake_deleted_audit_template = self.fake_audit_template.copy() - fake_deleted_audit_template['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_audit_template['deleted_at'] = timeutils.utcnow() m_soft_delete_audit_template.return_value = fake_deleted_audit_template expected_audit_template = fake_deleted_audit_template.copy() diff --git a/watcher/tests/objects/test_goal.py b/watcher/tests/objects/test_goal.py index 23297483f..521b691d2 100644 --- a/watcher/tests/objects/test_goal.py +++ b/watcher/tests/objects/test_goal.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.db.sqlalchemy import api as db_api from watcher import objects @@ -29,7 +29,7 @@ class TestGoalObject(base.DbTestCase): def setUp(self): super(TestGoalObject, self).setUp() self.fake_goal = utils.get_test_goal( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'get_goal_by_id') def test_get_by_id(self, mock_get_goal): @@ -93,7 +93,7 @@ class TestGoalObject(base.DbTestCase): mock_get_goal.return_value = self.fake_goal goal_uuid = self.fake_goal['uuid'] fake_saved_goal = self.fake_goal.copy() - fake_saved_goal['updated_at'] = datetime.datetime.utcnow() + fake_saved_goal['updated_at'] = timeutils.utcnow() mock_update_goal.return_value = fake_saved_goal goal = objects.Goal.get_by_uuid(self.context, goal_uuid) @@ -125,7 +125,7 @@ class TestGoalObject(base.DbTestCase): def test_soft_delete(self, mock_get_goal, mock_soft_delete_goal): mock_get_goal.return_value = self.fake_goal fake_deleted_goal = self.fake_goal.copy() - fake_deleted_goal['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_goal['deleted_at'] = timeutils.utcnow() mock_soft_delete_goal.return_value = fake_deleted_goal expected_goal = fake_deleted_goal.copy() diff --git a/watcher/tests/objects/test_scoring_engine.py b/watcher/tests/objects/test_scoring_engine.py index fbe5da344..2726a8c37 100644 --- a/watcher/tests/objects/test_scoring_engine.py +++ b/watcher/tests/objects/test_scoring_engine.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.db.sqlalchemy import api as db_api from watcher import objects @@ -29,7 +29,7 @@ class TestScoringEngineObject(base.DbTestCase): def setUp(self): super(TestScoringEngineObject, self).setUp() self.fake_scoring_engine = utils.get_test_scoring_engine( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'get_scoring_engine_by_id') def test_get_by_id(self, mock_get_scoring_engine): @@ -100,7 +100,7 @@ class TestScoringEngineObject(base.DbTestCase): def test_save(self, mock_get_scoring_engine, mock_update_scoring_engine): mock_get_scoring_engine.return_value = self.fake_scoring_engine fake_saved_scoring_engine = self.fake_scoring_engine.copy() - fake_saved_scoring_engine['updated_at'] = datetime.datetime.utcnow() + fake_saved_scoring_engine['updated_at'] = timeutils.utcnow() mock_update_scoring_engine.return_value = fake_saved_scoring_engine uuid = self.fake_scoring_engine['uuid'] @@ -134,7 +134,7 @@ class TestScoringEngineObject(base.DbTestCase): def test_soft_delete(self, mock_get_scoring_engine, mock_soft_delete): mock_get_scoring_engine.return_value = self.fake_scoring_engine fake_deleted_scoring_engine = self.fake_scoring_engine.copy() - fake_deleted_scoring_engine['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_scoring_engine['deleted_at'] = timeutils.utcnow() mock_soft_delete.return_value = fake_deleted_scoring_engine expected_scoring_engine = fake_deleted_scoring_engine.copy() diff --git a/watcher/tests/objects/test_service.py b/watcher/tests/objects/test_service.py index 87abda369..83ee05e46 100644 --- a/watcher/tests/objects/test_service.py +++ b/watcher/tests/objects/test_service.py @@ -13,10 +13,10 @@ # License for the specific language governing permissions and limitations # under the License. -import datetime from unittest import mock import iso8601 +from oslo_utils import timeutils from watcher.db.sqlalchemy import api as db_api from watcher import objects @@ -29,7 +29,7 @@ class TestServiceObject(base.DbTestCase): def setUp(self): super(TestServiceObject, self).setUp() self.fake_service = utils.get_test_service( - created_at=datetime.datetime.utcnow()) + created_at=timeutils.utcnow()) @mock.patch.object(db_api.Connection, 'get_service_by_id') def test_get_by_id(self, mock_get_service): @@ -66,7 +66,7 @@ class TestServiceObject(base.DbTestCase): def test_save(self, mock_get_service, mock_update_service): mock_get_service.return_value = self.fake_service fake_saved_service = self.fake_service.copy() - fake_saved_service['updated_at'] = datetime.datetime.utcnow() + fake_saved_service['updated_at'] = timeutils.utcnow() mock_update_service.return_value = fake_saved_service _id = self.fake_service['id'] service = objects.Service.get(self.context, _id) @@ -98,7 +98,7 @@ class TestServiceObject(base.DbTestCase): def test_soft_delete(self, mock_get_service, mock_soft_delete): mock_get_service.return_value = self.fake_service fake_deleted_service = self.fake_service.copy() - fake_deleted_service['deleted_at'] = datetime.datetime.utcnow() + fake_deleted_service['deleted_at'] = timeutils.utcnow() mock_soft_delete.return_value = fake_deleted_service expected_service = fake_deleted_service.copy()