diff options
Diffstat (limited to 'WebKitTools/QueueStatusServer/handlers/statusbubble.py')
-rw-r--r-- | WebKitTools/QueueStatusServer/handlers/statusbubble.py | 37 |
1 files changed, 35 insertions, 2 deletions
diff --git a/WebKitTools/QueueStatusServer/handlers/statusbubble.py b/WebKitTools/QueueStatusServer/handlers/statusbubble.py index d52509f..0e2b8de 100644 --- a/WebKitTools/QueueStatusServer/handlers/statusbubble.py +++ b/WebKitTools/QueueStatusServer/handlers/statusbubble.py @@ -26,17 +26,50 @@ # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +import operator + from google.appengine.ext import webapp from google.appengine.ext.webapp import template from model.attachment import Attachment +from model.workitems import WorkItems +from model.queues import queues, name_with_underscores class StatusBubble(webapp.RequestHandler): + # FIXME: This list probably belongs as part of a Queue object in queues.py + # Arrays are bubble_name, queue_name + _queues_to_display = [ + ["style", "style-queue"], + ["cr-linux", "chromium-ews"], + ["cr-win", "cr-win-ews"], + ["gtk", "gtk-ews"], + ["qt", "qt-ews"], + ["mac", "mac-ews"], + ["win", "win-ews"], + ] + + # This asserts that all of the queues listed above are valid queue names. + assert(reduce(operator.and_, map(lambda name_pair: name_pair[1] in queues, _queues_to_display))) + + def _build_bubble(self, queue_name_pair, attachment): + bubble_name = queue_name_pair[0] + queue_name = queue_name_pair[1] + + queue_status = attachment.status_for_queue(queue_name) + bubble = { + "name": bubble_name, + "attachment_id": attachment.id, + "queue_position": attachment.position_in_queue(queue_name), + "state": attachment.state_from_queue_status(queue_status) if queue_status else "none", + "status": queue_status, + } + return bubble + def get(self, attachment_id): attachment = Attachment(int(attachment_id)) - + bubbles = [self._build_bubble(name_pair, attachment) for name_pair in self._queues_to_display] template_values = { - "summary" : attachment.summary() + "bubbles": bubbles, } self.response.out.write(template.render("templates/statusbubble.html", template_values)) |