mirror of https://github.com/sipwise/repoapi.git
Change-Id: I8edf08680a1ec74e7c79b9fb18fa8d157c2d1ea5changes/51/7251/1
parent
9a8b06d1ab
commit
0c5594ce19
@ -1,242 +0,0 @@
|
|||||||
# 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 django.db import models
|
|
||||||
from django.db.models import signals
|
|
||||||
from django.conf import settings
|
|
||||||
from repoapi import utils
|
|
||||||
from .tasks import get_jbi_files
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
|
||||||
workfront_re = re.compile(r"TT#(\d+)")
|
|
||||||
commit_re = re.compile(r"^(\w{7}) ")
|
|
||||||
|
|
||||||
|
|
||||||
class JenkinsBuildInfoManager(models.Manager):
|
|
||||||
|
|
||||||
def releases(self, flat=True):
|
|
||||||
res = self.get_queryset().values('param_release').distinct()
|
|
||||||
if flat:
|
|
||||||
return res.values_list('param_release', flat=True)
|
|
||||||
else:
|
|
||||||
return res.values('param_release')
|
|
||||||
|
|
||||||
def release_projects(self, release, flat=True):
|
|
||||||
res = self.get_queryset().filter(
|
|
||||||
param_release=release).values('projectname').distinct()
|
|
||||||
if flat:
|
|
||||||
return res.values_list('projectname', flat=True)
|
|
||||||
else:
|
|
||||||
return res.values('projectname')
|
|
||||||
|
|
||||||
def release_project_uuids_set(self, release, project):
|
|
||||||
res = self.get_queryset().filter(
|
|
||||||
param_release=release, projectname=project).distinct()
|
|
||||||
return res.order_by('projectname')
|
|
||||||
|
|
||||||
def release_project_uuids(self, release, project, flat=True):
|
|
||||||
res = self.get_queryset().filter(
|
|
||||||
param_release=release, projectname=project).distinct()
|
|
||||||
if flat:
|
|
||||||
return res.order_by('projectname').values_list('tag', flat=True)
|
|
||||||
else:
|
|
||||||
return res.order_by('projectname').values('tag')
|
|
||||||
|
|
||||||
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()
|
|
||||||
latest_uuid = qs.filter(
|
|
||||||
param_release=release, projectname=project).latest('date')
|
|
||||||
return {'tag': latest_uuid.tag, 'date': latest_uuid.date}
|
|
||||||
|
|
||||||
|
|
||||||
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_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"],
|
|
||||||
]
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
return "%s:%d[%s]" % (self.jobname,
|
|
||||||
self.buildnumber, self.tag)
|
|
||||||
|
|
||||||
def jbi_manage(sender, **kwargs):
|
|
||||||
if kwargs["created"]:
|
|
||||||
instance = kwargs["instance"]
|
|
||||||
get_jbi_files.delay(instance.jobname, instance.buildnumber)
|
|
||||||
|
|
||||||
signals.post_save.connect(jbi_manage, sender=JenkinsBuildInfo)
|
|
||||||
|
|
||||||
class GerritRepoInfo(models.Model):
|
|
||||||
param_ppa = models.CharField(max_length=50, null=False)
|
|
||||||
gerrit_change = models.CharField(max_length=50, null=False)
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
unique_together = ["param_ppa", "gerrit_change"]
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
return "%s:%s" % (self.param_ppa, self.gerrit_change)
|
|
||||||
|
|
||||||
|
|
||||||
def gerrit_repo_add(instance):
|
|
||||||
gri = GerritRepoInfo.objects
|
|
||||||
ppa, created = gri.get_or_create(
|
|
||||||
param_ppa=instance.param_ppa,
|
|
||||||
gerrit_change=instance.gerrit_change)
|
|
||||||
if created:
|
|
||||||
logging.info("%s created", ppa)
|
|
||||||
|
|
||||||
|
|
||||||
def gerrit_repo_del(instance):
|
|
||||||
if instance.param_ppa == '$ppa':
|
|
||||||
logger.warn("ppa unset, skip removal")
|
|
||||||
return
|
|
||||||
gri = GerritRepoInfo.objects
|
|
||||||
try:
|
|
||||||
ppa = gri.get(param_ppa=instance.param_ppa,
|
|
||||||
gerrit_change=instance.gerrit_change)
|
|
||||||
ppa.delete()
|
|
||||||
logger.info("removed %s", ppa)
|
|
||||||
except GerritRepoInfo.DoesNotExist:
|
|
||||||
pass
|
|
||||||
if gri.filter(param_ppa=instance.param_ppa).count() == 0:
|
|
||||||
utils.jenkins_remove_ppa(instance.param_ppa)
|
|
||||||
|
|
||||||
|
|
||||||
def gerrit_repo_manage(sender, **kwargs):
|
|
||||||
if kwargs["created"]:
|
|
||||||
instance = kwargs["instance"]
|
|
||||||
if instance.jobname.endswith("-repos") and \
|
|
||||||
instance.result == "SUCCESS":
|
|
||||||
logger.info("we need to count this %s", instance.param_ppa)
|
|
||||||
if instance.gerrit_eventtype == "patchset-created":
|
|
||||||
gerrit_repo_add(instance)
|
|
||||||
elif instance.gerrit_eventtype == "change-merged":
|
|
||||||
gerrit_repo_del(instance)
|
|
||||||
elif instance.jobname.endswith("-cleanup") and \
|
|
||||||
instance.result == "SUCCESS" and \
|
|
||||||
instance.gerrit_eventtype == "change-abandoned":
|
|
||||||
logger.info("we need to count this %s", instance.param_ppa)
|
|
||||||
gerrit_repo_del(instance)
|
|
||||||
|
|
||||||
signals.post_save.connect(gerrit_repo_manage, sender=JenkinsBuildInfo)
|
|
||||||
|
|
||||||
|
|
||||||
class WorkfrontNoteInfo(models.Model):
|
|
||||||
workfront_id = models.CharField(max_length=50, null=False)
|
|
||||||
gerrit_change = models.CharField(max_length=50, null=False)
|
|
||||||
eventtype = models.CharField(max_length=50, null=False)
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
unique_together = ["workfront_id", "gerrit_change", "eventtype"]
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def getIds(git_comment):
|
|
||||||
"""
|
|
||||||
parses git_commit_msg searching for Workfront TT# ocurrences
|
|
||||||
returns a list of IDs
|
|
||||||
"""
|
|
||||||
if git_comment:
|
|
||||||
res = workfront_re.findall(git_comment)
|
|
||||||
return set(res)
|
|
||||||
else:
|
|
||||||
return set()
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def getCommit(git_comment):
|
|
||||||
"""
|
|
||||||
parses git_commit_msg searching for short GIT_COMMIT
|
|
||||||
"""
|
|
||||||
if git_comment:
|
|
||||||
res = commit_re.search(git_comment)
|
|
||||||
if res:
|
|
||||||
return res.group(1)
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
return "%s:%s" % (self.workfront_id, self.gerrit_change)
|
|
||||||
|
|
||||||
|
|
||||||
def workfront_note_add(instance, message):
|
|
||||||
wni = WorkfrontNoteInfo.objects
|
|
||||||
workfront_ids = WorkfrontNoteInfo.getIds(instance.git_commit_msg)
|
|
||||||
|
|
||||||
for wid in workfront_ids:
|
|
||||||
if not instance.gerrit_eventtype:
|
|
||||||
change = WorkfrontNoteInfo.getCommit(instance.git_commit_msg)
|
|
||||||
url = settings.GITWEB_URL.format(instance.projectname, change)
|
|
||||||
eventtype = 'git-commit'
|
|
||||||
else:
|
|
||||||
change = instance.gerrit_change
|
|
||||||
url = settings.GERRIT_URL.format(instance.gerrit_change)
|
|
||||||
eventtype = instance.gerrit_eventtype
|
|
||||||
note, created = wni.get_or_create(
|
|
||||||
workfront_id=wid,
|
|
||||||
gerrit_change=change,
|
|
||||||
eventtype=eventtype)
|
|
||||||
if created:
|
|
||||||
if not utils.workfront_note_send(wid, "%s %s" % (message, url)):
|
|
||||||
logger.error("remove releated WorkfrontNoteInfo")
|
|
||||||
note.delete()
|
|
||||||
|
|
||||||
|
|
||||||
def workfront_note_manage(sender, **kwargs):
|
|
||||||
"""
|
|
||||||
<name>-get-code job is the first in the flow that has the proper
|
|
||||||
GIT_CHANGE_SUBJECT envVar set, so git_commit_msg is fine
|
|
||||||
"""
|
|
||||||
if kwargs["created"]:
|
|
||||||
instance = kwargs["instance"]
|
|
||||||
if instance.jobname.endswith("-get-code") and \
|
|
||||||
instance.result == "SUCCESS":
|
|
||||||
if instance.gerrit_eventtype == 'change-merged':
|
|
||||||
msg = "review merged"
|
|
||||||
elif instance.gerrit_eventtype == 'patchset-created':
|
|
||||||
msg = "review created"
|
|
||||||
else:
|
|
||||||
msg = "commit created"
|
|
||||||
workfront_note_add(instance, msg)
|
|
||||||
|
|
||||||
|
|
||||||
signals.post_save.connect(workfront_note_manage, sender=JenkinsBuildInfo)
|
|
||||||
@ -0,0 +1,22 @@
|
|||||||
|
# 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/>.
|
||||||
|
from django.db.models import signals
|
||||||
|
from .jbi import JenkinsBuildInfo, jbi_manage
|
||||||
|
from .gri import GerritRepoInfo, gerrit_repo_manage
|
||||||
|
from .wni import WorkfrontNoteInfo, workfront_note_manage
|
||||||
|
|
||||||
|
signals.post_save.connect(jbi_manage, sender=JenkinsBuildInfo)
|
||||||
|
signals.post_save.connect(gerrit_repo_manage, sender=JenkinsBuildInfo)
|
||||||
|
signals.post_save.connect(workfront_note_manage, sender=JenkinsBuildInfo)
|
||||||
@ -0,0 +1,73 @@
|
|||||||
|
# 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
|
||||||
|
|
||||||
|
from django.db import models
|
||||||
|
from repoapi import utils
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class GerritRepoInfo(models.Model):
|
||||||
|
param_ppa = models.CharField(max_length=50, null=False)
|
||||||
|
gerrit_change = models.CharField(max_length=50, null=False)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
unique_together = ["param_ppa", "gerrit_change"]
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return "%s:%s" % (self.param_ppa, self.gerrit_change)
|
||||||
|
|
||||||
|
|
||||||
|
def gerrit_repo_add(instance):
|
||||||
|
gri = GerritRepoInfo.objects
|
||||||
|
ppa, created = gri.get_or_create(
|
||||||
|
param_ppa=instance.param_ppa,
|
||||||
|
gerrit_change=instance.gerrit_change)
|
||||||
|
if created:
|
||||||
|
logging.info("%s created", ppa)
|
||||||
|
|
||||||
|
|
||||||
|
def gerrit_repo_del(instance):
|
||||||
|
if instance.param_ppa == '$ppa':
|
||||||
|
logger.warn("ppa unset, skip removal")
|
||||||
|
return
|
||||||
|
gri = GerritRepoInfo.objects
|
||||||
|
try:
|
||||||
|
ppa = gri.get(param_ppa=instance.param_ppa,
|
||||||
|
gerrit_change=instance.gerrit_change)
|
||||||
|
ppa.delete()
|
||||||
|
logger.info("removed %s", ppa)
|
||||||
|
except GerritRepoInfo.DoesNotExist:
|
||||||
|
pass
|
||||||
|
if gri.filter(param_ppa=instance.param_ppa).count() == 0:
|
||||||
|
utils.jenkins_remove_ppa(instance.param_ppa)
|
||||||
|
|
||||||
|
|
||||||
|
def gerrit_repo_manage(sender, **kwargs):
|
||||||
|
if kwargs["created"]:
|
||||||
|
instance = kwargs["instance"]
|
||||||
|
if instance.jobname.endswith("-repos") and \
|
||||||
|
instance.result == "SUCCESS":
|
||||||
|
logger.info("we need to count this %s", instance.param_ppa)
|
||||||
|
if instance.gerrit_eventtype == "patchset-created":
|
||||||
|
gerrit_repo_add(instance)
|
||||||
|
elif instance.gerrit_eventtype == "change-merged":
|
||||||
|
gerrit_repo_del(instance)
|
||||||
|
elif instance.jobname.endswith("-cleanup") and \
|
||||||
|
instance.result == "SUCCESS" and \
|
||||||
|
instance.gerrit_eventtype == "change-abandoned":
|
||||||
|
logger.info("we need to count this %s", instance.param_ppa)
|
||||||
|
gerrit_repo_del(instance)
|
||||||
@ -0,0 +1,109 @@
|
|||||||
|
# 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 django.db import models
|
||||||
|
|
||||||
|
from django.conf import settings
|
||||||
|
from repoapi import utils
|
||||||
|
from repoapi.tasks import get_jbi_files
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
workfront_re = re.compile(r"TT#(\d+)")
|
||||||
|
commit_re = re.compile(r"^(\w{7}) ")
|
||||||
|
|
||||||
|
|
||||||
|
class JenkinsBuildInfoManager(models.Manager):
|
||||||
|
|
||||||
|
def releases(self, flat=True):
|
||||||
|
res = self.get_queryset().values('param_release').distinct()
|
||||||
|
if flat:
|
||||||
|
return res.values_list('param_release', flat=True)
|
||||||
|
else:
|
||||||
|
return res.values('param_release')
|
||||||
|
|
||||||
|
def release_projects(self, release, flat=True):
|
||||||
|
res = self.get_queryset().filter(
|
||||||
|
param_release=release).values('projectname').distinct()
|
||||||
|
if flat:
|
||||||
|
return res.values_list('projectname', flat=True)
|
||||||
|
else:
|
||||||
|
return res.values('projectname')
|
||||||
|
|
||||||
|
def release_project_uuids_set(self, release, project):
|
||||||
|
res = self.get_queryset().filter(
|
||||||
|
param_release=release, projectname=project).distinct()
|
||||||
|
return res.order_by('projectname')
|
||||||
|
|
||||||
|
def release_project_uuids(self, release, project, flat=True):
|
||||||
|
res = self.get_queryset().filter(
|
||||||
|
param_release=release, projectname=project).distinct()
|
||||||
|
if flat:
|
||||||
|
return res.order_by('projectname').values_list('tag', flat=True)
|
||||||
|
else:
|
||||||
|
return res.order_by('projectname').values('tag')
|
||||||
|
|
||||||
|
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()
|
||||||
|
latest_uuid = qs.filter(
|
||||||
|
param_release=release, projectname=project).latest('date')
|
||||||
|
return {'tag': latest_uuid.tag, 'date': latest_uuid.date}
|
||||||
|
|
||||||
|
|
||||||
|
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_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"],
|
||||||
|
]
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return "%s:%d[%s]" % (self.jobname,
|
||||||
|
self.buildnumber, self.tag)
|
||||||
|
|
||||||
|
|
||||||
|
def jbi_manage(sender, **kwargs):
|
||||||
|
if kwargs["created"]:
|
||||||
|
instance = kwargs["instance"]
|
||||||
|
get_jbi_files.delay(instance.jobname, instance.buildnumber)
|
||||||
@ -0,0 +1,99 @@
|
|||||||
|
# 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 django.db import models
|
||||||
|
from django.conf import settings
|
||||||
|
from repoapi import utils
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
workfront_re = re.compile(r"TT#(\d+)")
|
||||||
|
commit_re = re.compile(r"^(\w{7}) ")
|
||||||
|
|
||||||
|
|
||||||
|
class WorkfrontNoteInfo(models.Model):
|
||||||
|
workfront_id = models.CharField(max_length=50, null=False)
|
||||||
|
gerrit_change = models.CharField(max_length=50, null=False)
|
||||||
|
eventtype = models.CharField(max_length=50, null=False)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
unique_together = ["workfront_id", "gerrit_change", "eventtype"]
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def getIds(git_comment):
|
||||||
|
"""
|
||||||
|
parses git_commit_msg searching for Workfront TT# ocurrences
|
||||||
|
returns a list of IDs
|
||||||
|
"""
|
||||||
|
if git_comment:
|
||||||
|
res = workfront_re.findall(git_comment)
|
||||||
|
return set(res)
|
||||||
|
else:
|
||||||
|
return set()
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def getCommit(git_comment):
|
||||||
|
"""
|
||||||
|
parses git_commit_msg searching for short GIT_COMMIT
|
||||||
|
"""
|
||||||
|
if git_comment:
|
||||||
|
res = commit_re.search(git_comment)
|
||||||
|
if res:
|
||||||
|
return res.group(1)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return "%s:%s" % (self.workfront_id, self.gerrit_change)
|
||||||
|
|
||||||
|
|
||||||
|
def workfront_note_add(instance, message):
|
||||||
|
wni = WorkfrontNoteInfo.objects
|
||||||
|
workfront_ids = WorkfrontNoteInfo.getIds(instance.git_commit_msg)
|
||||||
|
|
||||||
|
for wid in workfront_ids:
|
||||||
|
if not instance.gerrit_eventtype:
|
||||||
|
change = WorkfrontNoteInfo.getCommit(instance.git_commit_msg)
|
||||||
|
url = settings.GITWEB_URL.format(instance.projectname, change)
|
||||||
|
eventtype = 'git-commit'
|
||||||
|
else:
|
||||||
|
change = instance.gerrit_change
|
||||||
|
url = settings.GERRIT_URL.format(instance.gerrit_change)
|
||||||
|
eventtype = instance.gerrit_eventtype
|
||||||
|
note, created = wni.get_or_create(
|
||||||
|
workfront_id=wid,
|
||||||
|
gerrit_change=change,
|
||||||
|
eventtype=eventtype)
|
||||||
|
if created:
|
||||||
|
if not utils.workfront_note_send(wid, "%s %s" % (message, url)):
|
||||||
|
logger.error("remove releated WorkfrontNoteInfo")
|
||||||
|
note.delete()
|
||||||
|
|
||||||
|
|
||||||
|
def workfront_note_manage(sender, **kwargs):
|
||||||
|
"""
|
||||||
|
<name>-get-code job is the first in the flow that has the proper
|
||||||
|
GIT_CHANGE_SUBJECT envVar set, so git_commit_msg is fine
|
||||||
|
"""
|
||||||
|
if kwargs["created"]:
|
||||||
|
instance = kwargs["instance"]
|
||||||
|
if instance.jobname.endswith("-get-code") and \
|
||||||
|
instance.result == "SUCCESS":
|
||||||
|
if instance.gerrit_eventtype == 'change-merged':
|
||||||
|
msg = "review merged"
|
||||||
|
elif instance.gerrit_eventtype == 'patchset-created':
|
||||||
|
msg = "review created"
|
||||||
|
else:
|
||||||
|
msg = "commit created"
|
||||||
|
workfront_note_add(instance, msg)
|
||||||
Loading…
Reference in new issue