def get(self): self.response.headers['Content-Type'] = 'application/json; charset=utf-8' try: testId = int(self.request.get('id', 0)) branchId = int(self.request.get('branchid', 0)) platformId = int(self.request.get('platformid', 0)) except TypeError: # FIXME: Output an error here testId = 0 branchId = 0 platformId = 0 # FIXME: Just fetch builds specified by "days" # days = self.request.get('days', 365) cacheKey = Test.cacheKey(testId, branchId, platformId) cache = memcache.get(cacheKey) if cache: self.response.out.write(cache) return builds = Build.all() builds.filter('branch =', modelFromNumericId(branchId, Branch)) builds.filter('platform =', modelFromNumericId(platformId, Platform)) test = modelFromNumericId(testId, Test) testName = test.name if test else None test_runs = [] averages = {} values = [] timestamps = [] for build in builds: results = TestResult.all() results.filter('name =', testName) results.filter('build =', build) for result in results: builderId = build.builder.key().id() posixTimestamp = mktime(build.timestamp.timetuple()) test_runs.append([result.key().id(), [build.key().id(), build.buildNumber, build.revision], posixTimestamp, result.value, 0, [], builderId]) # FIXME: Calculate the average; in practice, we wouldn't have more than one value for a given revision averages[build.revision] = result.value values.append(result.value) timestamps.append(posixTimestamp) result = json.dumps({ 'test_runs': test_runs, 'averages': averages, 'min': min(values) if values else None, 'max': max(values) if values else None, 'date_range': [min(timestamps), max(timestamps)] if timestamps else None, 'stat': 'ok'}) self.response.out.write(result) memcache.add(cacheKey, result)
def post(self): self.response.headers['Content-Type'] = 'text/plain; charset=utf-8' try: test_id = int(self.request.get('id', 0)) branch_id = int(self.request.get('branchid', 0)) platform_id = int(self.request.get('platformid', 0)) except TypeError: # FIXME: Output an error here test_id = 0 branch_id = 0 platform_id = 0 # FIXME: Just fetch builds specified by "days" # days = self.request.get('days', 365) builds = Build.all() builds.filter('branch =', modelFromNumericId(branch_id, Branch)) builds.filter('platform =', modelFromNumericId(platform_id, Platform)) test = modelFromNumericId(test_id, Test) test_name = test.name if test else None test_runs = [] averages = {} values = [] timestamps = [] for build in builds: results = TestResult.all() results.filter('name =', test_name) results.filter('build =', build) for result in results: builderId = build.builder.key().id() posixTimestamp = mktime(build.timestamp.timetuple()) statistics = None if result.valueStdev != None and result.valueMin != None and result.valueMax != None: statistics = {'stdev': result.valueStdev, 'min': result.valueMin, 'max': result.valueMax} test_runs.append([result.key().id(), [build.key().id(), build.buildNumber, build.revision], posixTimestamp, result.value, 0, # runNumber [], # annotations builderId, statistics]) # FIXME: Calculate the average; in practice, we wouldn't have more than one value for a given revision averages[build.revision] = result.value values.append(result.value) timestamps.append(posixTimestamp) result = json.dumps({ 'test_runs': test_runs, 'averages': averages, 'min': min(values) if values else None, 'max': max(values) if values else None, 'date_range': [min(timestamps), max(timestamps)] if timestamps else None, 'stat': 'ok'}) cache_runs(test_id, branch_id, platform_id, result) self.response.out.write('OK')
def _generate_runs(branch, platform, test_name): builds = Build.all() builds.filter('branch =', branch) builds.filter('platform =', platform) for build in builds: results = TestResult.all() results.filter('name =', test_name) results.filter('build =', build) for result in results: yield build, result raise StopIteration