| #!/usr/bin/env python |
| #-*- coding: utf-8 -*- |
| # Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| # |
| # Use of this source code is governed by a BSD-style license |
| # that can be found in the LICENSE file in the root of the source |
| # tree. An additional intellectual property rights grant can be found |
| # in the file PATENTS. All contributing project authors may |
| # be found in the AUTHORS file in the root of the source tree. |
| |
| """Implements a handler for adding coverage data.""" |
| |
| from datetime import datetime |
| import logging |
| |
| from google.appengine.ext import db |
| |
| import oauth_post_request_handler |
| |
| REPORT_CATEGORIES = ('small_medium_tests', 'large_tests') |
| |
| |
| class CoverageData(db.Model): |
| """This represents one coverage report from the build bot.""" |
| # The date the report was made. |
| date = db.DateTimeProperty(required=True) |
| |
| # Coverage percentages. |
| line_coverage = db.FloatProperty(required=True) |
| function_coverage = db.FloatProperty(required=True) |
| branch_coverage = db.FloatProperty() |
| |
| # The report category must be one of the REPORT_CATEGORIES. |
| report_category = db.CategoryProperty() |
| |
| |
| class AddCoverageData(oauth_post_request_handler.OAuthPostRequestHandler): |
| """Used to report coverage data. |
| |
| Coverage data is reported as a POST request and should contain, aside from |
| the regular oauth_* parameters, these values: |
| |
| date: The POSIX timestamp for when the coverage observation was made. |
| report_category: A value in REPORT_CATEGORIES which characterizes the |
| coverage information (e.g. is the coverage from small / medium tests |
| or large tests?) |
| |
| line_coverage: Line coverage percentage. |
| function_coverage: Function coverage percentage. |
| branch_coverage: Branch coverage percentage. |
| """ |
| def _parse_and_store_data(self): |
| try: |
| request_posix_timestamp = float(self.request.get('oauth_timestamp')) |
| parsed_date = datetime.fromtimestamp(request_posix_timestamp) |
| |
| line_coverage = self._parse_percentage('line_coverage') |
| function_coverage = self._parse_percentage('function_coverage') |
| branch_coverage = self._parse_percentage('branch_coverage') |
| report_category = self._parse_category('report_category') |
| |
| except ValueError as error: |
| logging.warn('Invalid parameter in request: %s.' % error) |
| self.response.set_status(400) |
| return |
| |
| item = CoverageData(date=parsed_date, |
| line_coverage=line_coverage, |
| function_coverage=function_coverage, |
| branch_coverage=branch_coverage, |
| report_category=report_category) |
| item.put() |
| |
| def _parse_percentage(self, key): |
| """Parses out a percentage value from the request.""" |
| string_value = self.request.get(key) |
| percentage = float(string_value) |
| if percentage < 0.0 or percentage > 100.0: |
| raise ValueError('%s is not a valid percentage.' % string_value) |
| return percentage |
| |
| def _parse_category(self, key): |
| value = self.request.get(key) |
| if value in REPORT_CATEGORIES: |
| return value |
| else: |
| raise ValueError("Invalid category %s." % value) |