X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=scripts%2Fjjb-init-project.py;h=64b58210731b60bd8dd0124a8f909c6bb78b4a55;hb=1bf00abb99ad52d6d91427a7515008316eb59c1f;hp=c2ec670407bb29ba7984b09783f1cd5932c9ca48;hpb=cc052ad9de9dfedc76fad5154fad92b70eca7794;p=releng%2Fbuilder.git diff --git a/scripts/jjb-init-project.py b/scripts/jjb-init-project.py index c2ec67040..64b582107 100644 --- a/scripts/jjb-init-project.py +++ b/scripts/jjb-init-project.py @@ -28,14 +28,18 @@ args = jjblib.parse_jjb_args() project = jjblib.Project(args.project) if project.meta_project is not None: project_dir = os.path.join("jjb", project.meta_project, project.project) + jenkins_settings = "%s-%s-settings" % (project.meta_project, + project.project) else: project_dir = os.path.join("jjb", project.project) + jenkins_settings = "%s-settings" % project.project project_file = os.path.join(project_dir, "%s.yaml" % project) dependent_jobs = "" disabled = "true" # Always disabled unless project has dependencies email_prefix = "[%s]" % project + if not args.conf: jjblib.create_template_config(project_dir, args) project_conf = os.path.join(project_dir, "%s.cfg" % args.project) @@ -53,8 +57,11 @@ if os.path.isfile(project_conf): if cfg.get("JOB_TEMPLATES"): templates = cfg.get("JOB_TEMPLATES") else: - templates = "verify,merge,daily,distribution,integration,sonar" + templates = ( + "verify,merge,periodic,distribution,distribution-check,integration," + "sonar") templates += ",clm" # ensure we always create a clm job for all projects +templates += ",validate-autorelease" # Autorelease validate template ################## # Handle Streams # @@ -64,7 +71,7 @@ if cfg.get("STREAMS"): # this is a list of single-key dicts for stream_dict in cfg.get("STREAMS"): streams.update(stream_dict) else: - streams = {"beryllium": jjblib.STREAM_DEFAULTS["beryllium"]} + streams = {"boron": jjblib.STREAM_DEFAULTS["boron"]} first_stream = streams.iterkeys().next() # Keep master branch at top. sonar_branch = streams[first_stream]["branch"] @@ -79,6 +86,17 @@ for stream, options in streams.items(): for jdk in options["jdks"].split(","): str_streams += " - %s\n" % jdk.strip() + # Disable autorelease validate job unless project is participating + # in autorelease, JJB does not allow flipping a boolean so we have to + # flip it here via not operator since the JJB configuration for disabling + # a Jenkins Job is "disabled: bool". + str_streams += " disable_autorelease: %s\n" % (not options.get( + "autorelease", False)) + + # Disable the distribution-check job unless project enables it + str_streams += " disable_distribution_check: %s\n" % ( + not options.get("distribution-check", True)) + ############### # Handle JDKS # ############### @@ -126,24 +144,27 @@ if cfg.get('DEPENDENCIES'): dependencies = "odlparent," + dependencies disabled = "false" else: - dependencies = "odlparent" # All projects depend on odlparent + dependencies = None + if project.project != "odlparent": # Odlparent does not depend on itself + dependencies = "odlparent" # All other projects depend on odlparent disabled = "false" -email_prefix = (email_prefix + " " + +if dependencies: + email_prefix = (email_prefix + " " + " ".join(['[%s]' % d for d in dependencies.split(",")])) # noqa -dependent_jobs = ",".join( - ['%s-merge-{stream}' % d for d in dependencies.split(",")]) + dependent_jobs = ",".join( + ['%s-merge-{stream}' % d for d in dependencies.split(",")]) ############################ # Handle ARCHIVE_ARTIFACTS # ############################ -if cfg.get('ARCHIVE_ARTIFACTS'): - archive_artifacts = cfg.get('ARCHIVE_ARTIFACTS') - archive_artifacts = ("- archive-artifacts:\n" - " artifacts: '%s'" % archive_artifacts) -else: - archive_artifacts = "" +always_archive = "**/target/surefire-reports/*-output.txt" + +archive_artifacts = cfg.get('ARCHIVE_ARTIFACTS', '') +archive_artifacts = ("- archive-artifacts:\n" + " artifacts: '%s, %s'" % + (always_archive, archive_artifacts)) ############################## # Create configuration start # @@ -187,7 +208,9 @@ with open(project_file, "w") as outfile: for line in infile: if not re.match("\s*#", line): line = re.sub("JOB_TEMPLATES", job_templates_yaml, line) - line = re.sub("PROJECT", project.project, line) + line = re.sub("PROJECT_SHORTNAME", project.project, line) + line = re.sub("PROJECT_PATH", project.path, line) + line = re.sub("JENKINS_SETTINGS", jenkins_settings, line) line = re.sub("DISABLED", disabled, line) line = re.sub("STREAMS", str_streams, line) line = re.sub("POM", pom, line)