You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

202 lines
7.2 KiB

# Copyright (C) 2015 The Sipwise Team - http://sipwise.com
# This program is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by the Free
# Software Foundation, either version 3 of the License, or (at your option)
# any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
# more details.
# You should have received a copy of the GNU General Public License along
# with this program. If not, see <http://www.gnu.org/licenses/>.
import logging
import re
from collections import OrderedDict
from datetime import datetime, timedelta
from django.db import models
from django.forms.models import model_to_dict
from django.conf import settings
from repoapi.tasks import get_jbi_files
from urlparse import urlparse
logger = logging.getLogger(__name__)
workfront_re = re.compile(r"TT#(\d+)")
commit_re = re.compile(r"^(\w{7}) ")
class JenkinsBuildInfoManager(models.Manager):
def release_projects_full(self, release):
res = dict()
for project in self.release_projects(release):
res[project] = dict()
uuids = self.release_project_uuids(release, project)
for uuid in uuids:
res[project][uuid] = OrderedDict()
jobs = self.jobs_by_uuid(release, project, uuid)
for job in jobs:
key = str(job.date)
res[project][uuid][key] = model_to_dict(job)
# date is not editable... so not in the result
res[project][uuid][key]['date'] = job.date
uuid = self.latest_uuid(release, project)
if uuid:
res[project][uuid['tag']]['latest'] = True
return res
def releases(self, flat=True):
qs = self.get_queryset().filter(tag__isnull=False)
res = qs.values('param_release').distinct()
if res.exists():
if flat:
return res.values_list('param_release', flat=True)
else:
return res.values('param_release')
def is_release(self, release):
res = self.get_queryset().filter(
param_release=release,
tag__isnull=False)
return res.exists()
def release_projects(self, release, flat=True):
res = self.get_queryset().filter(
param_release=release,
tag__isnull=False).values('projectname').distinct()
if res.exists():
if flat:
return res.values_list('projectname', flat=True)
else:
return res.values('projectname')
def is_project(self, release, project):
res = self.get_queryset().filter(
param_release=release,
projectname=project,
tag__isnull=False)
return res.exists()
def release_project_uuids_set(self, release, project):
res = self.get_queryset().filter(
param_release=release,
projectname=project,
tag__isnull=False).distinct()
if res.exists():
return res.order_by('projectname')
def release_project_uuids(self, release, project, flat=True):
res = self.get_queryset().filter(
param_release=release,
projectname=project,
tag__isnull=False).distinct()
if flat:
return res.order_by('projectname').values_list('tag', flat=True)
else:
return res.order_by('projectname').values('tag')
def is_uuid(self, release, project, uuid):
res = self.get_queryset().filter(
param_release=release,
projectname=project,
tag=uuid)
return res.exists()
def jobs_by_uuid(self, release, project, uuid):
return self.get_queryset().filter(tag=uuid, param_release=release,
projectname=project).order_by('date')
def _latest_uuid(self, release, project):
qs = self.get_queryset()
res = qs.filter(
param_release=release,
projectname=project,
tag__isnull=False)
if res.exists():
return res.latest('date')
def latest_uuid(self, release, project):
res = self._latest_uuid(release, project)
if res is not None:
return {'tag': res.tag, 'date': res.date}
def latest_uuid_js(self, release, project):
res = self._latest_uuid(release, project)
if res is not None:
return {'tag': res.tag, 'latest': True}
def is_latest_uuid_js(self, release, project, uuid):
res = self._latest_uuid(release, project)
latest_uuid = {'tag': uuid, 'latest': False}
if res is not None:
latest_uuid['latest'] = (res.tag == uuid)
return latest_uuid
def purge_release(self, release, _timedelta=timedelta(weeks=3)):
_date = datetime.now() - _timedelta
if release is None:
self.get_queryset().filter(
param_release__isnull=True,
date__date__lt=_date).delete()
else:
self.get_queryset().filter(
param_release=release,
date__date__lt=_date).delete()
class JenkinsBuildInfo(models.Model):
tag = models.CharField(max_length=64, null=True)
projectname = models.CharField(max_length=100)
jobname = models.CharField(max_length=100)
buildnumber = models.IntegerField()
date = models.DateTimeField(auto_now_add=True)
result = models.CharField(max_length=50)
job_url = models.URLField()
gerrit_patchset = models.CharField(max_length=50, null=True)
gerrit_change = models.CharField(max_length=50, null=True)
gerrit_eventtype = models.CharField(max_length=50, null=True)
param_tag = models.CharField(max_length=50, null=True)
param_branch = models.CharField(max_length=50, null=True)
param_release = models.CharField(max_length=50, null=True,
db_index=True)
param_release_uuid = models.CharField(max_length=64, null=True)
param_distribution = models.CharField(max_length=50, null=True)
param_ppa = models.CharField(max_length=50, null=True)
repo_name = models.CharField(max_length=50, null=True)
git_commit_msg = models.TextField(null=True)
objects = JenkinsBuildInfoManager()
class Meta:
index_together = [
["param_release", "projectname"],
["param_release", "projectname", "tag"],
["param_release_uuid", "tag"],
]
def is_job_url_allowed(self):
if self.job_url:
parsed = urlparse(self.job_url)
if parsed.netloc in settings.JBI_ALLOWED_HOSTS:
return True
return False
def __str__(self):
return "[%s]%s:%d[%s]" % (self.param_release_uuid, self.jobname,
self.buildnumber, self.tag)
def jbi_manage(sender, **kwargs):
if kwargs["created"]:
instance = kwargs["instance"]
if instance.is_job_url_allowed():
get_jbi_files.delay(instance.pk,
instance.jobname,
instance.buildnumber)