blob: 6d7840b36a676004956857cb821d0a3c251a58c3 [file] [log] [blame]
Oleksii Petrenko24f1f8f2020-06-26 18:09:43 +03001from django.core.files.storage import FileSystemStorage
2from django.db import models
Anna Arhipova22ea6bf2024-02-20 15:25:30 +01003from django.utils.timezone import now, timedelta
4from django_celery_beat.models import PeriodicTask
Anna Arhipovae9258f32023-11-04 12:31:19 +01005
6
7class IntegerListField(models.Field):
8 def __init__(self, *args, **kwargs):
9 kwargs['editable'] = False
10 super(IntegerListField, self).__init__(*args, **kwargs)
11
12 def db_type(self, connection):
13 return 'text'
14
15 def from_db_value(self, value, expression, connection):
16 if not value:
17 return []
18 return [int(x) for x in value.split(',')]
19
20 def to_python(self, value):
21 if isinstance(value, list):
22 return value
23 if not value:
24 return []
25 return [int(x) for x in value.split(',')]
26
27 def get_prep_value(self, value):
28 if not value:
29 return ''
30 return ','.join(str(int(x)) for x in value)
Oleksii Petrenko24f1f8f2020-06-26 18:09:43 +030031
32
Anna Arhipova22ea6bf2024-02-20 15:25:30 +010033def default_created_after():
34 return now() + timedelta(days=-3 * 30)
35
36
Oleksii Petrenko68268172020-09-28 16:58:13 +030037class TestRailTestRun(models.Model):
Anna Arhipovae9258f32023-11-04 12:31:19 +010038 project_name = models.CharField(max_length=300,
39 default="Mirantis Cloud Platform")
Sofiia Andriichenko4b440da2023-02-10 12:29:46 +010040 plan_name = models.CharField(max_length=300, default="[MCP2.0]OSCORE")
41 run_name = models.CharField(max_length=300, blank=True)
Anna Arhipovaf1ea3ee2024-01-24 13:29:09 +010042 testrun_pattern = models.CharField(max_length=300, blank=True)
Sofiia Andriichenko4b440da2023-02-10 12:29:46 +010043 run_id = models.CharField(max_length=300)
Anna Arhipovae9258f32023-11-04 12:31:19 +010044 checked_tests = IntegerListField(default=list())
Anna Arhipovaec725222024-01-21 00:10:37 +010045 caching_tests_enabled = models.BooleanField(default=False)
Sofiia Andriichenko4b440da2023-02-10 12:29:46 +010046 created_by_id = models.IntegerField(default='109')
Oleksii Petrenko24f1f8f2020-06-26 18:09:43 +030047 filter_func = models.TextField(null=True, blank=True)
Sofiia Andriichenko4b440da2023-02-10 12:29:46 +010048 ip_filter = models.BooleanField(default=True)
49 uuid_filter = models.BooleanField(default=True)
Anna Arhipova53461592024-01-10 11:18:05 +010050 filter_last_traceback = models.BooleanField(default=True)
51 created_before = models.DateField(default=now)
Anna Arhipova22ea6bf2024-02-20 15:25:30 +010052 created_after = models.DateField(default=default_created_after)
Oleksii Petrenko24f1f8f2020-06-26 18:09:43 +030053
Anna Arhipovae9258f32023-11-04 12:31:19 +010054 @property
55 def text_filters(self):
56 return {
57 "filter_last_traceback": self.filter_last_traceback,
58 "uuid_filter": self.uuid_filter,
59 "ip_filter": self.ip_filter,
60 "filter_func": self.filter_func,
61 }
62
63 @property
64 def testrail_filters(self):
65 return {
66 "created_by_id": self.created_by_id,
Anna Arhipova62760612023-11-28 23:20:38 +010067 "created_after": self.created_after,
68 "created_before": self.created_before,
Anna Arhipovaf1ea3ee2024-01-24 13:29:09 +010069 "testrun_pattern": self.testrun_pattern,
Anna Arhipovae9258f32023-11-04 12:31:19 +010070 "plan_name": self.plan_name,
Anna Arhipovae9258f32023-11-04 12:31:19 +010071 }
72
Oleksii Petrenko24f1f8f2020-06-26 18:09:43 +030073
74fs = FileSystemStorage()
75
76
Oleksii Petrenko68268172020-09-28 16:58:13 +030077class TestRailReport(models.Model):
Oleksii Petrenko1de4bab2020-07-21 15:49:04 +030078 path = models.FileField(storage=fs, null=True, blank=True, max_length=500)
Oleksii Petrenko24f1f8f2020-06-26 18:09:43 +030079 report_name = models.CharField(max_length=300)
80 finished = models.BooleanField(default=False)
Oleksii Petrenko7118f8c2020-07-17 12:45:09 +030081 created_at = models.DateTimeField(auto_now_add=True)
Oleksii Petrenko68268172020-09-28 16:58:13 +030082
83
84class ActionLog(models.Model):
85 name = models.CharField(max_length=500)
86 date = models.DateTimeField(null=True)
Anna Arhipova7cdcc852023-11-15 18:20:45 +010087
88
89class SuitePassRate(models.Model):
90 SUITE_CHOICES = [
Anna Arhipova29ee6182023-11-30 14:06:05 +010091 ("Tempest", (
92 ("10651", "[MCP2.0_ROCKY]Tempest"),
93 ("10635", "[MCP2.0_STEIN]Tempest"),
94 ("10653", "[MCP2.0_TRAIN]Tempest"),
95 ("10710", "[MCP2.0_USSURI]Tempest"),
96 ("10888", "[MCP2.0_VICTORIA]Tempest"),
97 ("11167", "[MCP2.0_WALLABY]Tempest"),
98 ("11188", "[MCP2.0_XENA]Tempest"),
99 ("11170", "[MCP2.0_YOGA]Tempest"),
100 ("11192", "[MCP2.0_ANTELOPE]Tempest"))
Anna Arhipovaec725222024-01-21 00:10:37 +0100101 ),
Anna Arhipova29ee6182023-11-30 14:06:05 +0100102 ("Stepler", (
103 ("10886", "[MCP2.0_USSURI]Stepler"),
104 ("10887", "[MCP2.0_VICTORIA]Stepler"),
105 ("11171", "[MCP2.0_YOGA]Stepler"),
106 ("11193", "[MCP2.0_ANTELOPE]Stepler"))
Anna Arhipovaec725222024-01-21 00:10:37 +0100107 ),
Anna Arhipova7cdcc852023-11-15 18:20:45 +0100108 ]
109 suite_id = models.CharField(max_length=20, choices=SUITE_CHOICES)
110 suite_name = models.CharField(max_length=100, blank=True)
111 passrate_by_tests = models.JSONField(default="{}", blank=True)
112 status = models.TextField(max_length=300, blank=True)
113 finished = models.BooleanField(default=False, blank=True)
114
115
116class DiffOfSuitesPassRates(models.Model):
117 limit = models.IntegerField(default=10, blank=True)
118 test_keyword = models.CharField(default="", max_length=300, blank=True)
119 report1 = models.ForeignKey(to=SuitePassRate,
120 related_name="report1",
121 on_delete=models.CASCADE,
122 blank=True)
123 report2 = models.ForeignKey(to=SuitePassRate,
124 related_name="report2",
125 on_delete=models.CASCADE,
126 blank=True)
127 started_at = models.DateTimeField(auto_created=True,
128 auto_now=True)
Anna Arhipova22ea6bf2024-02-20 15:25:30 +0100129
130
131TASK_CHOICES = [
132 ("control.celery_tasks.tasks.check_today_testplan",
133 "Check today testplan",
134 []
135 ),
136 ("control.celery_tasks.tasks.task_to_check_testplan",
137 "Check testplan",
138 ["testplan_id"]
139 ),
140 ]
141
142
143class CronPeriodicTask(PeriodicTask):
144 cron = models.CharField(default="",
145 max_length=300,
146 blank=False)
147
148 class Meta:
149 ordering = ["id"]