mirror of https://github.com/sipwise/repoapi.git
* release-tools-runner sends a note "hotfix <projectname> <version> triggered" * TODO: how to be sure that version reaches public release ?? Change-Id: Ib220f36d642172d8c89f4df35543193be16d37cechanges/26/7326/8
parent
80970c9270
commit
d85f9e0af7
@ -0,0 +1,34 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Generated by Django 1.9 on 2016-07-26 12:58
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
initial = True
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='WorkfrontNoteInfo',
|
||||||
|
fields=[
|
||||||
|
('id', models.AutoField(
|
||||||
|
auto_created=True,
|
||||||
|
primary_key=True,
|
||||||
|
serialize=False,
|
||||||
|
verbose_name='ID')),
|
||||||
|
('workfront_id', models.CharField(max_length=50)),
|
||||||
|
('projectname', models.CharField(max_length=50)),
|
||||||
|
('version', models.CharField(max_length=50)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.AlterUniqueTogether(
|
||||||
|
name='workfrontnoteinfo',
|
||||||
|
unique_together=set(
|
||||||
|
[('workfront_id', 'projectname', 'version')]),
|
||||||
|
),
|
||||||
|
]
|
@ -0,0 +1,48 @@
|
|||||||
|
# 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.signals import post_save
|
||||||
|
from django.conf import settings
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
workfront_re = re.compile(r"TT#(\d+)")
|
||||||
|
|
||||||
|
|
||||||
|
class WorkfrontNoteInfo(models.Model):
|
||||||
|
workfront_id = models.CharField(max_length=50, null=False)
|
||||||
|
projectname = models.CharField(max_length=50, null=False)
|
||||||
|
version = models.CharField(max_length=50, null=False)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
unique_together = [
|
||||||
|
"workfront_id",
|
||||||
|
"projectname",
|
||||||
|
"version"
|
||||||
|
]
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def getIds(change):
|
||||||
|
"""
|
||||||
|
parses text searching for Workfront TT# ocurrences
|
||||||
|
returns a list of IDs
|
||||||
|
"""
|
||||||
|
if change:
|
||||||
|
res = workfront_re.findall(change)
|
||||||
|
return set(res)
|
||||||
|
else:
|
||||||
|
return set()
|
@ -0,0 +1,32 @@
|
|||||||
|
# Copyright (C) 2016 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 __future__ import absolute_import
|
||||||
|
|
||||||
|
import logging
|
||||||
|
from celery import shared_task
|
||||||
|
from django.conf import settings
|
||||||
|
from .utils import parse_changelog, create_note
|
||||||
|
from repoapi.models import JenkinsBuildInfo
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
@shared_task(ignore_result=True)
|
||||||
|
def hotfix_released(jbi_id, path):
|
||||||
|
jbi = JenkinsBuildInfo.objects.get(pk=jbi_id)
|
||||||
|
logger.info('hotfix_released[%s] %s', jbi, path)
|
||||||
|
wids, changelog = parse_changelog(path)
|
||||||
|
for wid in wids:
|
||||||
|
create_note(wid, jbi.projectname, changelog.full_version)
|
@ -0,0 +1,94 @@
|
|||||||
|
# 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 os
|
||||||
|
import shutil
|
||||||
|
|
||||||
|
from django.test import TestCase, override_settings
|
||||||
|
from django.conf import settings
|
||||||
|
from mock import patch, call, mock_open
|
||||||
|
from hotfix import tasks, utils, models
|
||||||
|
from repoapi.models import JenkinsBuildInfo
|
||||||
|
|
||||||
|
debian_changelog = """ngcp-fake (3.8.7.4+0~mr3.8.7.4) unstable; urgency=medium
|
||||||
|
|
||||||
|
[ Kirill Solomko ]
|
||||||
|
* [ee3c706] MT#21499 add mysql replication options
|
||||||
|
|
||||||
|
[ Victor Seva ]
|
||||||
|
* [aabb345] TT#345 fake comment
|
||||||
|
* [aabb123] MT#8989 TT#123 fake comment
|
||||||
|
|
||||||
|
[ Sipwise Jenkins Builder ]
|
||||||
|
|
||||||
|
-- whatever <jenkins@sipwise.com> Fri, 22 Jul 2016 17:29:27 +0200
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
@override_settings(CELERY_EAGER_PROPAGATES_EXCEPTIONS=True)
|
||||||
|
class TestHotfixReleased(TestCase):
|
||||||
|
|
||||||
|
def get_defaults(self):
|
||||||
|
defaults = {
|
||||||
|
'tag': "edc90cd9-37f3-4613-9748-ed05a32031c2",
|
||||||
|
'projectname': "fake",
|
||||||
|
'jobname': "release-tools-runner",
|
||||||
|
'buildnumber': 1,
|
||||||
|
'result': "SUCCESS",
|
||||||
|
'job_url': "https://jenkins.mgm.sipwise.com/job/real-fake-gerrit/",
|
||||||
|
'param_tag': "none",
|
||||||
|
'param_branch': "mr4.5",
|
||||||
|
'param_release': "none",
|
||||||
|
'param_distribution': "wheezy",
|
||||||
|
'param_ppa': "gerrit_MT10339_review2054",
|
||||||
|
'git_commit_msg': "7fg4567 TT#0001 whatever",
|
||||||
|
}
|
||||||
|
return defaults
|
||||||
|
|
||||||
|
@patch('__builtin__.open', mock_open(read_data=debian_changelog))
|
||||||
|
def test_parse_changelog(self):
|
||||||
|
ids, changelog = utils.parse_changelog("/tmp/fake.txt")
|
||||||
|
self.assertItemsEqual(ids, ["345", "123"])
|
||||||
|
self.assertEquals(changelog.full_version, "3.8.7.4+0~mr3.8.7.4")
|
||||||
|
self.assertEquals(changelog.package, "ngcp-fake")
|
||||||
|
|
||||||
|
@patch('__builtin__.open', mock_open(read_data=debian_changelog))
|
||||||
|
@patch('repoapi.utils.dlfile')
|
||||||
|
@patch('repoapi.utils.workfront_note_send')
|
||||||
|
def test_hotfixreleased(self, wns, dlfile):
|
||||||
|
param = self.get_defaults()
|
||||||
|
jbi = JenkinsBuildInfo.objects.create(**param)
|
||||||
|
tasks.hotfix_released.delay(jbi.pk, "/tmp/fake.txt")
|
||||||
|
projectname = "fake"
|
||||||
|
version = "3.8.7.4+0~mr3.8.7.4"
|
||||||
|
gri = models.WorkfrontNoteInfo.objects.filter(
|
||||||
|
projectname=projectname,
|
||||||
|
version=version)
|
||||||
|
self.assertEquals(gri.count(), 2)
|
||||||
|
gri = models.WorkfrontNoteInfo.objects.filter(
|
||||||
|
workfront_id="345",
|
||||||
|
projectname=projectname,
|
||||||
|
version=version)
|
||||||
|
self.assertEquals(gri.count(), 1)
|
||||||
|
msg = "hotfix %s %s triggered" % (projectname, version)
|
||||||
|
calls = [call("345", msg), ]
|
||||||
|
gri = models.WorkfrontNoteInfo.objects.filter(
|
||||||
|
workfront_id="123",
|
||||||
|
projectname=projectname,
|
||||||
|
version=version)
|
||||||
|
self.assertEquals(gri.count(), 1)
|
||||||
|
msg = "hotfix %s %s triggered" % (projectname, version)
|
||||||
|
calls.append(call("123", msg))
|
||||||
|
wns.assert_has_calls(calls)
|
@ -0,0 +1,44 @@
|
|||||||
|
# Copyright (C) 2016 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 __future__ import absolute_import
|
||||||
|
import logging
|
||||||
|
from debian.changelog import Changelog
|
||||||
|
from .models import WorkfrontNoteInfo
|
||||||
|
from repoapi import utils
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
def parse_changelog(path):
|
||||||
|
changelog = Changelog()
|
||||||
|
with open(path, 'r') as file_changelog:
|
||||||
|
changelog.parse_changelog(file_changelog.read())
|
||||||
|
set_ids = set()
|
||||||
|
for block in changelog:
|
||||||
|
for change in block.changes():
|
||||||
|
set_ids = set_ids.union(WorkfrontNoteInfo.getIds(change))
|
||||||
|
return (set_ids, changelog)
|
||||||
|
|
||||||
|
|
||||||
|
def create_note(wid, projectname, version):
|
||||||
|
wni = WorkfrontNoteInfo.objects
|
||||||
|
|
||||||
|
note, created = wni.get_or_create(
|
||||||
|
workfront_id=wid,
|
||||||
|
projectname=projectname,
|
||||||
|
version=version)
|
||||||
|
if created:
|
||||||
|
msg = "hotfix %s %s triggered" % (projectname, version)
|
||||||
|
utils.workfront_note_send(wid, msg)
|
Loading…
Reference in new issue