Files
deb-python-taskflow/taskflow/job.py
2013-05-07 10:49:44 -07:00

60 lines
1.9 KiB
Python

# -*- coding: utf-8 -*-
# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright (C) 2012 Yahoo! Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import abc
CLAIMED = 'claimed'
UNCLAIMED = 'unclaimed'
class Job(object):
__metaclass__ = abc.ABCMeta
def __init__(self, name, type, reservation):
self.name = name
# A link back to the reservation which
# can be used to query information about
# this job (and its subsequent
# workflows and tasks).
self.reservation = reservation
# TBD - likely more details about this job
self.details = None
self.state = UNCLAIMED
self.owner = None
@abc.abstractproperty
def type(self):
# Returns which type of job this is.
#
# For example, a 'run_instance' job, or a 'delete_instance' job could
# be possible types.
raise NotImplementedError()
@abc.abstractmethod
def claim(self, owner):
# This can be used to transition this job from unclaimed to claimed.
raise NotImplementedError()
@abc.abstractmethod
def consume(self):
# This can be used to transition this job from active to finished.
#
# During said transition the job and any details of it may be removed
# from some backing storage (if applicable).
raise NotImplementedError()