Source code for spinn_front_end_common.abstract_models.impl.machine_allocation_controller
# Copyright (c) 2017-2019 The University of Manchester
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import logging
import sys
from threading import Thread
from six import add_metaclass
from spinn_utilities.overrides import overrides
from spinn_utilities.abstract_base import AbstractBase, abstractmethod
from spinn_front_end_common.abstract_models import (
AbstractMachineAllocationController)
logger = logging.getLogger(__name__)
[docs]@add_metaclass(AbstractBase)
class MachineAllocationController(AbstractMachineAllocationController):
""" How to manage the allocation of a machine so that it gets cleaned up\
neatly when the script dies.
"""
__slots__ = [
#: boolean flag for telling this thread when the system has ended
"_exited"
]
def __init__(self, thread_name):
thread = Thread(name=thread_name, target=self.__manage_allocation)
thread.daemon = True
self._exited = False
thread.start()
[docs] @overrides(AbstractMachineAllocationController.close)
def close(self):
self._exited = True
@abstractmethod
def _wait(self):
""" Wait for some bounded amount of time for a change in the status\
of the machine allocation.
:return: Whether the machine is still (believed to be) allocated.
:rtype: bool
"""
def _teardown(self):
""" Perform any extra teardown that the thread requires. Does not\
need to be overridden if no action is desired."""
def __manage_allocation(self):
machine_still_allocated = True
while machine_still_allocated and not self._exited:
machine_still_allocated = self._wait()
self._teardown()
if not self._exited:
logger.error(
"The allocated machine has been released before the end of"
" the script; this script will now exit")
sys.exit(1)