Adds support for tracking an upstream repos.
Change-Id: I3c92c19cf2c2fd6a911fbdbf4aeeb66e53cf07e0
This commit is contained in:
parent
dd2c31b263
commit
6fdebcf5af
@ -143,6 +143,10 @@ node "gerrit.openstack.org", "review.openstack.org" {
|
|||||||
name => 'openstack/python-cinderclient',
|
name => 'openstack/python-cinderclient',
|
||||||
close_pull => 'true'
|
close_pull => 'true'
|
||||||
} ],
|
} ],
|
||||||
|
upstream_projects => [ {
|
||||||
|
name => 'openstack-ci/gerrit',
|
||||||
|
remote => 'https://gerrit.googlesource.com/gerrit'
|
||||||
|
} ],
|
||||||
logo => 'openstack.png',
|
logo => 'openstack.png',
|
||||||
war => 'http://ci.openstack.org/tarballs/gerrit-2.3-7-g1f029ab.war',
|
war => 'http://ci.openstack.org/tarballs/gerrit-2.3-7-g1f029ab.war',
|
||||||
}
|
}
|
||||||
|
79
modules/gerrit/files/scripts/fetch_remotes.py
Executable file
79
modules/gerrit/files/scripts/fetch_remotes.py
Executable file
@ -0,0 +1,79 @@
|
|||||||
|
#! /usr/bin/env python
|
||||||
|
# Copyright (C) 2011 OpenStack, LLC.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
# Ensure that the specified remote exists in the repo and pull revisions
|
||||||
|
# from upstream
|
||||||
|
|
||||||
|
# [project "UPSTREAM_PROJECT"]
|
||||||
|
# remote = https://gerrit.googlesource.com/gerrit
|
||||||
|
|
||||||
|
import ConfigParser
|
||||||
|
import StringIO
|
||||||
|
import logging
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
|
||||||
|
def run_command(cmd, status=False, env={}):
|
||||||
|
if VERBOSE:
|
||||||
|
print datetime.datetime.now(), "Running:", cmd
|
||||||
|
cmd_list = shlex.split(str(cmd))
|
||||||
|
newenv = os.environ
|
||||||
|
newenv.update(env)
|
||||||
|
p = subprocess.Popen(cmd_list, stdout=subprocess.PIPE,
|
||||||
|
stderr=subprocess.STDOUT, env=newenv)
|
||||||
|
(out, nothing) = p.communicate()
|
||||||
|
if status:
|
||||||
|
return (p.returncode, out.strip())
|
||||||
|
return out.strip()
|
||||||
|
|
||||||
|
|
||||||
|
def run_command_status(cmd, env={}):
|
||||||
|
return run_command(cmd, True, env)
|
||||||
|
|
||||||
|
|
||||||
|
logging.basicConfig(level=logging.ERROR)
|
||||||
|
|
||||||
|
REPO_ROOT = os.environ.get('REPO_ROOT',
|
||||||
|
'/home/gerrit2/git')
|
||||||
|
REMOTES_CONFIG = os.environ.get('REMOTES_CONFIG',
|
||||||
|
'/home/gerrit2/remote.config')
|
||||||
|
|
||||||
|
PROJECT_RE = re.compile(r'^project\s+"(.*)"$')
|
||||||
|
|
||||||
|
config = ConfigParser.ConfigParser()
|
||||||
|
config.read(REMOTES_CONFIG)
|
||||||
|
|
||||||
|
|
||||||
|
for section in config.sections():
|
||||||
|
# Each section looks like [project "openstack/project"]
|
||||||
|
m = PROJECT_RE.match(section)
|
||||||
|
if not m:
|
||||||
|
continue
|
||||||
|
project = m.group(1)
|
||||||
|
project_git = "%s.git" % project
|
||||||
|
os.chdir(os.path.join(REPO_ROOT, project_git))
|
||||||
|
|
||||||
|
if not (config.has_option(section, "remote")):
|
||||||
|
continue
|
||||||
|
|
||||||
|
# Make sure that the specified remote exists
|
||||||
|
remote_url = config.get(section, "remote")
|
||||||
|
# We could check if it exists first, but we're ignoring output anyway
|
||||||
|
# So just try to make it, and it'll either make a new one or do nothing
|
||||||
|
run_command("git remote add -f upstream %s" % remote_url)
|
||||||
|
# Fetch new revs from it
|
||||||
|
run_command("git remote update upstream")
|
@ -49,6 +49,7 @@ class gerrit($virtual_hostname='',
|
|||||||
$openidssourl="https://login.launchpad.net/+openid",
|
$openidssourl="https://login.launchpad.net/+openid",
|
||||||
$email='',
|
$email='',
|
||||||
$github_projects = [],
|
$github_projects = [],
|
||||||
|
$upstream_projects = [],
|
||||||
$commentlinks = [ { name => 'changeid',
|
$commentlinks = [ { name => 'changeid',
|
||||||
match => '(I[0-9a-f]{8,40})',
|
match => '(I[0-9a-f]{8,40})',
|
||||||
link => '#q,$1,n,z' },
|
link => '#q,$1,n,z' },
|
||||||
@ -149,6 +150,13 @@ class gerrit($virtual_hostname='',
|
|||||||
environment => "PATH=/usr/bin:/bin:/usr/sbin:/sbin",
|
environment => "PATH=/usr/bin:/bin:/usr/sbin:/sbin",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cron { "gerritfetchremotes":
|
||||||
|
user => gerrit2,
|
||||||
|
minute => "*/30",
|
||||||
|
command => 'sleep $((RANDOM\%60+90)) && python /usr/local/gerrit/scripts/fetch_remotes.py',
|
||||||
|
require => File['/usr/local/gerrit/scripts'],
|
||||||
|
}
|
||||||
|
|
||||||
file { "/usr/local/gerrit/gerritbot":
|
file { "/usr/local/gerrit/gerritbot":
|
||||||
owner => 'root',
|
owner => 'root',
|
||||||
group => 'root',
|
group => 'root',
|
||||||
@ -225,6 +233,16 @@ class gerrit($virtual_hostname='',
|
|||||||
require => User["gerrit2"]
|
require => User["gerrit2"]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
file { '/home/gerrit2/remotes.config':
|
||||||
|
owner => 'root',
|
||||||
|
group => 'root',
|
||||||
|
mode => 444,
|
||||||
|
ensure => 'present',
|
||||||
|
content => template('gerrit/remotes.config.erb'),
|
||||||
|
replace => 'true',
|
||||||
|
require => User["gerrit2"]
|
||||||
|
}
|
||||||
|
|
||||||
file { '/home/gerrit2/review_site/static/title.png':
|
file { '/home/gerrit2/review_site/static/title.png':
|
||||||
ensure => 'present',
|
ensure => 'present',
|
||||||
source => "puppet:///modules/gerrit/${logo}",
|
source => "puppet:///modules/gerrit/${logo}",
|
||||||
|
7
modules/gerrit/templates/remotes.config.erb
Normal file
7
modules/gerrit/templates/remotes.config.erb
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
# This file is managed by puppet.
|
||||||
|
# https://github.com/openstack/openstack-ci-puppet
|
||||||
|
|
||||||
|
<% upstream_projects.each do |project| -%>
|
||||||
|
[project "<%= project['name'] %>"]
|
||||||
|
remote = <%= project['remote'] %>
|
||||||
|
<% end -%>
|
Loading…
x
Reference in New Issue
Block a user