3 # @License EPL-1.0 <http://spdx.org/licenses/EPL-1.0>
4 ##############################################################################
5 # Copyright (c) 2014, 2015 The Linux Foundation and others.
7 # All rights reserved. This program and the accompanying materials
8 # are made available under the terms of the Eclipse Public License v1.0
9 # which accompanies this distribution, and is available at
10 # http://www.eclipse.org/legal/epl-v10.html
13 # Thanh Ha (The Linux Foundation) - Initial implementation
14 ##############################################################################
16 from collections import OrderedDict
25 args = jjblib.parse_jjb_args()
28 project = jjblib.Project(args.project)
29 if project.meta_project is not None:
30 project_dir = os.path.join("jjb", project.meta_project, project.project)
31 jenkins_settings = "%s-%s-settings" % (project.meta_project,
34 project_dir = os.path.join("jjb", project.project)
35 jenkins_settings = "%s-settings" % project.project
37 project_file = os.path.join(project_dir, "%s.yaml" % project)
39 disabled = "true" # Always disabled unless project has dependencies
40 email_prefix = "[%s]" % project
44 jjblib.create_template_config(project_dir, args)
45 project_conf = os.path.join(project_dir, "%s.cfg" % args.project)
47 project_conf = args.conf
49 cfg = dict() # Needed to skip missing project.cfg files
50 if os.path.isfile(project_conf):
51 stream = open(project_conf, "r")
52 cfg = yaml.load(stream)
57 if cfg.get("JOB_TEMPLATES"):
58 templates = cfg.get("JOB_TEMPLATES")
65 streams = OrderedDict()
66 if cfg.get("STREAMS"): # this is a list of single-key dicts
67 for stream_dict in cfg.get("STREAMS"):
68 streams.update(stream_dict)
70 streams = {"boron": jjblib.STREAM_DEFAULTS["boron"]}
72 first_stream = next(iter(streams)) # Keep master branch at top.
73 sonar_branch = streams[first_stream]["branch"]
74 # Create YAML to list branches to create jobs for
75 str_streams = "stream:\n"
76 for stream, options in streams.items():
77 str_streams += (" - %s:\n"
79 (stream, options["branch"]))
80 str_streams += " jdk: %s\n" % options["jdks"].split(',')[0].strip() # noqa
81 str_streams += " jdks:\n"
82 for jdk in options["jdks"].split(","):
83 str_streams += " - %s\n" % jdk.strip()
85 # Disable autorelease validate job unless project is participating
86 # in autorelease, JJB does not allow flipping a boolean so we have to
87 # flip it here via not operator since the JJB configuration for disabling
88 # a Jenkins Job is "disabled: bool".
89 str_streams += " disable_autorelease: %s\n" % (not options.get(
90 "autorelease", False))
92 # Disable the distribution-check job unless project enables it
93 str_streams += " disable_distribution_check: %s\n" % (
94 not options.get("distribution-check", True))
100 jdks = cfg.get('JDKS')
104 for jdk in jdks.split(","):
105 use_jdks += " - %s\n" % jdk
118 if cfg.get('MVN_GOALS'):
119 mvn_goals = cfg.get('MVN_GOALS')
121 mvn_goals = ("clean install "
122 "-Dmaven.repo.local=/tmp/r "
123 "-Dorg.ops4j.pax.url.mvn.localRepository=/tmp/r ")
128 if cfg.get('MVN_OPTS'):
129 mvn_opts = cfg.get('MVN_OPTS')
131 mvn_opts = "-Xmx1024m -XX:MaxPermSize=256m"
133 #######################
134 # Handle DEPENDENCIES #
135 #######################
136 if cfg.get('DEPENDENCIES'):
137 dependencies = cfg.get('DEPENDENCIES')
138 if dependencies.find("odlparent") < 0: # Add odlparent if not listed
139 dependencies = "odlparent," + dependencies
143 if project.project != "odlparent": # Odlparent does not depend on itself
144 dependencies = "odlparent" # All other projects depend on odlparent
148 email_prefix = (email_prefix + " " +
149 " ".join(['[%s]' % d for d in dependencies.split(",")])) # noqa
150 dependent_jobs = ",".join(
151 ['%s-merge-{stream}' % d for d in dependencies.split(",")])
153 ############################
154 # Handle ARCHIVE_ARTIFACTS #
155 ############################
157 archive_artifacts = cfg.get('ARCHIVE_ARTIFACTS', '')
159 ##############################
160 # Create configuration start #
161 ##############################
163 # Create project directory if it doesn't exist
164 if not os.path.exists(project_dir):
165 os.makedirs(project_dir)
167 print("project: %s\n"
180 # Create initial project YAML file
181 use_templates = templates.split(",")
182 use_templates.insert(0, "project")
183 job_templates_yaml = ""
184 for t in use_templates:
185 if t == "project": # This is not a job type but is used for templating
188 job_templates_yaml = job_templates_yaml + \
189 " - '%s-%s'\n" % (project, t)
191 job_templates_yaml = job_templates_yaml + \
192 " - '%s-%s-{stream}'\n" % (project, t)
194 with open(project_file, "w") as outfile:
195 for t in use_templates:
196 template_file = "jjb-templates/%s.yaml" % t
197 with open(template_file, "r") as infile:
199 if not re.match("\s*#", line):
200 line = re.sub("JOB_TEMPLATES", job_templates_yaml, line)
201 line = re.sub("PROJECT_SHORTNAME", project.project, line)
202 line = re.sub("PROJECT_PATH", project.path, line)
203 line = re.sub("JENKINS_SETTINGS", jenkins_settings, line)
204 line = re.sub("DISABLED", disabled, line)
205 line = re.sub("STREAMS", str_streams, line)
206 line = re.sub("POM", pom, line)
207 line = re.sub("MAVEN_GOALS", mvn_goals, line)
208 line = re.sub("MAVEN_OPTS", mvn_opts, line)
209 line = re.sub("DEPENDENCIES", dependent_jobs, line)
210 line = re.sub("EMAIL_PREFIX", email_prefix, line)
211 line = re.sub("SONAR_BRANCH", sonar_branch, line)
212 line = re.sub("ARCHIVE_ARTIFACTS", archive_artifacts, line)
213 # The previous command may have created superfluous lines.
214 # If a line has no non-whitespace, it has to be '\n' only.
215 line = re.sub(r'^\s+\n', "", line)