Merge changes Ic2023940,Iaa349e67,I7a26c160
[releng/builder.git] / scripts / jjblib.py
1 import argparse
2 import collections
3 import os
4
5 import yaml
6
7
8 def parse_jjb_args():
9     parser = argparse.ArgumentParser()
10     parser.add_argument("project", help="project")
11     parser.add_argument("-c", "--conf", help="Config file")
12     parser.add_argument("-d", "--dependencies",
13                         help=("Project dependencies\n\n"
14                               "A comma-seperated (no spaces) list of projects "
15                               "your project depends on. "
16                               "This is used to create an integration job that "
17                               "will trigger when a dependent project-merge "
18                               "job is built successfully.\n\n"
19                               "Example: aaa,controller,yangtools"))
20     parser.add_argument("-t", "--templates", help="Job templates to use")
21     parser.add_argument("-s", "--streams",
22                         help="Release streams to fill with default options")
23     parser.add_argument("-p", "--pom", help="Path to pom.xml to use in Maven "
24                                             "build (Default: pom.xml")
25     parser.add_argument("-g", "--mvn-goals", help="Maven Goals")
26     parser.add_argument("-o", "--mvn-opts", help="Maven Options")
27     parser.add_argument("-a", "--archive-artifacts",
28                         help="Comma-seperated list of patterns of artifacts "
29                              "to archive on build completion. "
30                              "See: http://ant.apache.org/manual/Types/fileset.html")  # noqa
31     return parser.parse_args()
32
33
34 STREAM_DEFAULTS = collections.OrderedDict([
35     ("boron", {"branch": "master", "jdks": "openjdk8"}),
36     ("beryllium", {"branch": "stable/beryllium", "jdks": "openjdk8"}),
37     ("stable-lithium", {"branch": "stable/lithium", "jdks": "openjdk7"}),
38 ])
39
40
41 def create_template_config(project_dir, args):
42     cfg_data = dict()
43
44     if args.templates:
45         cfg_data["JOB_TEMPLATES"] = args.templates
46
47     if args.streams:
48         stream_list = list()
49         for stream in args.streams.split(","):
50             stream_list.append({stream: STREAM_DEFAULTS[stream]})
51         cfg_data["STREAMS"] = stream_list
52
53     if args.pom:
54         cfg_data["POM"] = args.pom
55
56     if args.mvn_goals:
57         cfg_data["MAVEN_GOALS"] = args.mvn_goals
58
59     if args.mvn_opts:
60         cfg_data["MAVEN_OPTS"] = args.mvn_opts
61
62     if args.dependencies:
63         cfg_data["DEPENDENCIES"] = args.dependencies
64
65     if args.archive_artifacts:
66         cfg_data["ARCHIVE"] = args.archive_artifacts
67
68     if cfg_data:
69         # Create project directory if it doesn't exist
70         if not os.path.exists(project_dir):
71             os.makedirs(project_dir)
72
73         print("Creating %s.cfg file" % args.project)
74         cfg_file = os.path.join(project_dir, "%s.cfg" % args.project)
75
76         with open(cfg_file, "w") as outstream:
77             outstream.write(yaml.dump(cfg_data, default_flow_style=False))
78
79
80 class Project:
81     """Represents a Gerrit Project
82
83     Attributes:
84         path(str): The full Gerrit path to a project
85         meta_project(str): The top-level project name in Gerrit
86         project(str): The subproject name or project shortname
87     """
88
89     def __init__(self, project):
90         self.path = project
91         self.meta_project = None
92         self.project = project
93
94         if project.find('/') >= 0:
95             s = project.rsplit('/', 1)
96             self.meta_project = s[0]
97             self.project = s[1]
98
99     def __str__(self):
100         return self.project