Change to using management jobs.

master
Simon Quigley 6 years ago
parent eb286afbdd
commit 685228adfc

@ -147,6 +147,8 @@ class Generator:
PACKAGING_BRANCH_S=s_branch, PACKAGING_BRANCH_S=s_branch,
NAME=data["name"], NAME=data["name"],
DEFAULT_BRANCH=default_branch) DEFAULT_BRANCH=default_branch)
elif job_type == "release-mgmt":
package_config = template.render()
else: else:
raise ValueError("Invalid job type") raise ValueError("Invalid job type")
@ -194,7 +196,13 @@ class Generator:
view = server.views.create("merger") view = server.views.create("merger")
view.add_job(job_name) view.add_job(job_name)
total_rel = set()
for release in package["releases"]: for release in package["releases"]:
# Add the release to the total release set, which is used to
# generate the management jobs
total_rel.add(release)
# Load the config given the current data # Load the config given the current data
package["release"] = release package["release"] = release
for jobtype in ["unstable", "stable"]: for jobtype in ["unstable", "stable"]:
@ -206,16 +214,31 @@ class Generator:
job.update_config(package_config) job.update_config(package_config)
else: else:
job = server.create_job(job_name, str(package_config)) job = server.create_job(job_name, str(package_config))
# With an existing job we can assume it's already in an
# appropriate view. With new jobs, we should see if the viewname = release + " " + jobtype
# view exists, and if it doesn't, create it if viewname in server.views:
viewname = release + " " + jobtype view = server.views[viewname]
if viewname in server.views: else:
view = server.views[viewname] view = server.views.create(viewname)
else:
view = server.views.create(viewname) view.add_job(job_name)
view.add_job(job_name) # Generate a management job for every release, stable and unstable
for release in total_rel:
for jobtype in ["unstable", "stable"]:
package_config = self.load_config("release-mgmt")
jobname = "mgmt_build_" + release + "_" + jobtype
if job_name in jobs:
job = server.get_job(job_name)
job.update_config(package_config)
else:
job = server.create_job(job_name, str(package_config))
# The mgmt view should be the first view created, we don't
# have to create it if it doesn't exist because that's a
# Huge Problem anyway
view = server.views["mgmt"]
view.addjob(jobname)
if __name__ == "__main__": if __name__ == "__main__":

@ -37,7 +37,7 @@
<triggers> <triggers>
<jenkins.triggers.ReverseBuildTrigger> <jenkins.triggers.ReverseBuildTrigger>
<spec></spec> <spec></spec>
<upstreamProjects>jobgenerator</upstreamProjects> <upstreamProjects>merger</upstreamProjects>
<threshold> <threshold>
<name>SUCCESS</name> <name>SUCCESS</name>
<ordinal>0</ordinal> <ordinal>0</ordinal>

@ -31,7 +31,7 @@
<triggers> <triggers>
<jenkins.triggers.ReverseBuildTrigger> <jenkins.triggers.ReverseBuildTrigger>
<spec></spec> <spec></spec>
<upstreamProjects>merger_{{ NAME }}</upstreamProjects> <upstreamProjects>merger_{{ NAME }}, mgmt_build_{{ RELEASE }}_stable</upstreamProjects>
<threshold> <threshold>
<name>SUCCESS</name> <name>SUCCESS</name>
<ordinal>0</ordinal> <ordinal>0</ordinal>

@ -31,7 +31,7 @@
<triggers> <triggers>
<jenkins.triggers.ReverseBuildTrigger> <jenkins.triggers.ReverseBuildTrigger>
<spec></spec> <spec></spec>
<upstreamProjects>merger_{{ NAME }}</upstreamProjects> <upstreamProjects>merger_{{ NAME }}, mgmt_build_{{ RELEASE }}_unstable</upstreamProjects>
<threshold> <threshold>
<name>SUCCESS</name> <name>SUCCESS</name>
<ordinal>0</ordinal> <ordinal>0</ordinal>

@ -0,0 +1,26 @@
<?xml version='1.1' encoding='UTF-8'?>
<project>
<description></description>
<keepDependencies>false</keepDependencies>
<properties/>
<scm class="hudson.scm.NullSCM"/>
<canRoam>true</canRoam>
<disabled>false</disabled>
<blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
<blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
<triggers>
<jenkins.triggers.ReverseBuildTrigger>
<spec></spec>
<upstreamProjects>jobgenerator</upstreamProjects>
<threshold>
<name>SUCCESS</name>
<ordinal>0</ordinal>
<color>BLUE</color>
<completeBuild>true</completeBuild>
</threshold>
</jenkins.triggers.ReverseBuildTrigger>
</triggers>
<concurrentBuild>false</concurrentBuild>
<builders/>
<publishers/>
<buildWrappers/>
Loading…
Cancel
Save