mypy: coordination.py

Change-Id: Iad0b5c7e689b2e524071322bfa59e789e1cc42a1
This commit is contained in:
Eric Harney 2021-04-27 13:08:18 -04:00
parent b5ac2af0c2
commit 61335da5bc
2 changed files with 13 additions and 7 deletions

View File

@ -21,6 +21,7 @@ import inspect
import os import os
import re import re
import sys import sys
from typing import Callable
import uuid import uuid
import decorator import decorator
@ -55,7 +56,7 @@ class Coordinator(object):
meaningful prefix. meaningful prefix.
""" """
def __init__(self, agent_id=None, prefix=''): def __init__(self, agent_id: str = None, prefix: str = ''):
self.coordinator = None self.coordinator = None
self.agent_id = agent_id or str(uuid.uuid4()) self.agent_id = agent_id or str(uuid.uuid4())
self.started = False self.started = False
@ -71,7 +72,7 @@ class Coordinator(object):
return os.path.abspath(os.path.join(path, self.prefix)) return os.path.abspath(os.path.join(path, self.prefix))
return None return None
def start(self): def start(self) -> None:
if self.started: if self.started:
return return
@ -80,18 +81,20 @@ class Coordinator(object):
# NOTE(bluex): Tooz expects member_id as a byte string. # NOTE(bluex): Tooz expects member_id as a byte string.
member_id = (self.prefix + self.agent_id).encode('ascii') member_id = (self.prefix + self.agent_id).encode('ascii')
self.coordinator = coordination.get_coordinator(backend_url, member_id) self.coordinator = coordination.get_coordinator(backend_url, member_id)
assert self.coordinator is not None
self.coordinator.start(start_heart=True) self.coordinator.start(start_heart=True)
self._file_path = self._get_file_path(backend_url) self._file_path = self._get_file_path(backend_url)
self.started = True self.started = True
def stop(self): def stop(self) -> None:
"""Disconnect from coordination backend and stop heartbeat.""" """Disconnect from coordination backend and stop heartbeat."""
if self.started: if self.started:
if self.coordinator is not None:
self.coordinator.stop() self.coordinator.stop()
self.coordinator = None self.coordinator = None
self.started = False self.started = False
def get_lock(self, name): def get_lock(self, name: str):
"""Return a Tooz backend lock. """Return a Tooz backend lock.
:param str name: The lock name that is used to identify it :param str name: The lock name that is used to identify it
@ -126,7 +129,9 @@ def synchronized_remove(glob_name, coordinator=COORDINATOR):
coordinator.remove_lock(glob_name) coordinator.remove_lock(glob_name)
def synchronized(lock_name, blocking=True, coordinator=COORDINATOR): def synchronized(lock_name: str,
blocking: bool = True,
coordinator: Coordinator = COORDINATOR) -> Callable:
"""Synchronization decorator. """Synchronization decorator.
:param str lock_name: Lock name. :param str lock_name: Lock name.
@ -169,7 +174,7 @@ def synchronized(lock_name, blocking=True, coordinator=COORDINATOR):
""" """
@decorator.decorator @decorator.decorator
def _synchronized(f, *a, **k): def _synchronized(f, *a, **k) -> Callable:
call_args = inspect.getcallargs(f, *a, **k) call_args = inspect.getcallargs(f, *a, **k)
call_args['f_name'] = f.__name__ call_args['f_name'] = f.__name__
lock = coordinator.get_lock(lock_name.format(**call_args)) lock = coordinator.get_lock(lock_name.format(**call_args))

View File

@ -1,6 +1,7 @@
cinder/backup/manager.py cinder/backup/manager.py
cinder/common/constants.py cinder/common/constants.py
cinder/context.py cinder/context.py
cinder/coordination.py
cinder/i18n.py cinder/i18n.py
cinder/image/cache.py cinder/image/cache.py
cinder/image/glance.py cinder/image/glance.py