blob: 11186c953f8cd81ffe2380d956d7f9976bfad6df [file] [log] [blame]
Keyar Hood0f26dba2013-07-18 17:49:32 -07001# Copyright (c) 2013 The Chromium OS Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5import common
6from autotest_lib.frontend import setup_django_readonly_environment
7
8# Django and the models are only setup after
9# the setup_django_readonly_environment module is imported.
10from autotest_lib.frontend.tko import models as tko_models
11from django.db import models as django_models
12
Keyar Hood30d94bd2013-07-23 10:41:12 -070013_TEST_ERROR_STATUS = 'ERROR'
14_TEST_ABORT_STATUS = 'ABORT'
15_TEST_FAIL_STATUS = 'FAIL'
16_TEST_WARN_STATUS = 'WARN'
Keyar Hood0f26dba2013-07-18 17:49:32 -070017_TEST_PASS_STATUS = 'GOOD'
Keyar Hood30d94bd2013-07-23 10:41:12 -070018_TEST_ALERT_STATUS = 'ALERT'
19
Keyar Hood0f26dba2013-07-18 17:49:32 -070020
21def get_last_pass_times():
22 """
23 Get all the tests that have passed and the time they last passed.
24
25 @return the dict of test_name:last_finish_time pairs for tests that have
26 passed.
27
28 """
29 results = tko_models.Test.objects.values('test').filter(
30 status__word=_TEST_PASS_STATUS).annotate(
31 last_pass=django_models.Max('started_time'))
32 return {result['test']: result['last_pass'] for result in results}
33
Keyar Hood30d94bd2013-07-23 10:41:12 -070034
35def get_last_fail_times():
36 """
37 Get all the tests that have failed and the time they last failed.
38
39 @return the dict of test_name:last_finish_time pairs for tests that have
40 failed.
41
42 """
43
44 failure_clauses = (django_models.Q(status__word=_TEST_FAIL_STATUS) |
45 django_models.Q(status__word=_TEST_ERROR_STATUS) |
46 django_models.Q(status__word=_TEST_ABORT_STATUS) |
47 django_models.Q(status__word=_TEST_WARN_STATUS) |
48 django_models.Q(status__word=_TEST_ALERT_STATUS))
49
50 results = tko_models.Test.objects.values('test').filter(
51 failure_clauses).annotate(
52 last_pass=django_models.Max('started_time'))
53
54 return {result['test']: result['last_pass'] for result in results}