jib-profiles.js revision 2655:204c708d2738
1/*
2 * Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.  Oracle designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Oracle in the LICENSE file that accompanied this code.
10 *
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
16 *
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22 * or visit www.oracle.com if you need additional information or have any
23 * questions.
24 */
25
26/*
27 * This file defines build profiles for the JIB tool and others.
28 *
29 * A build profile defines a set of configuration options and external
30 * dependencies that we for some reason or other care about specifically.
31 * Typically, build profiles are defined for the build configurations we
32 * build regularly.
33 *
34 * Contract against this file from the tools that use it, is to provide
35 * a function on the form:
36 *
37 * getJibProfiles(input)
38 *
39 * which returns an object graph describing the profiles and their
40 * dependencies. The name of the function is based on the name of this
41 * file, minus the extension and the '-', camel cased and prefixed with
42 * 'get'.
43 *
44 *
45 * The parameter 'input' is an object that optionally contains  some data.
46 * Optionally because a tool may read the configuration for different purposes.
47 * To initially get a list of available profiles, the active profile may not
48 * yet be known for instance.
49 *
50 * Data that may be set on the input object:
51 *
52 * input.profile = <name of active profile>
53 *
54 * If the active profile is set, the following data from it must also
55 * be provided:
56 *
57 * input.profile
58 * input.build_id
59 * input.target_os
60 * input.target_cpu
61 * input.build_os
62 * input.build_cpu
63 * input.target_platform
64 * input.build_platform
65 * // The build_osenv_* variables describe the unix layer on Windows systems,
66 * // i.e. Cygwin, which may also be 32 or 64 bit.
67 * input.build_osenv
68 * input.build_osenv_cpu
69 * input.build_osenv_platform
70 *
71 * For more complex nested attributes, there is a method "get":
72 *
73 * input.get("<dependency>", "<attribute>")
74 *
75 * Valid attributes are:
76 * install_path
77 * download_path
78 * download_dir
79 *
80 *
81 * The output data generated by this configuration file has the following
82 * format:
83 *
84 * data: {
85 *   // Identifies the version of this format to the tool reading it
86 *   format_version: "1.0",
87 *
88 *   // Name of base outputdir. JIB assumes the actual output dir is formed
89 *   // by adding the configuration name: <output_basedir>/<config-name>
90 *   output_basedir: "build",
91 *   // Configure argument to use to specify configuration name
92 *   configuration_configure_arg:
93 *   // Make argument to use to specify configuration name
94 *   configuration_make_arg:
95 *
96 *   profiles: {
97 *     <profile-name>: {
98 *       // Name of os the profile is built to run on
99 *       target_os; <string>
100 *       // Name of cpu the profile is built to run on
101 *       target_cpu; <string>
102 *       // Combination of target_os and target_cpu for convenience
103 *       target_platform; <string>
104 *       // Name of os the profile is built on
105 *       build_os; <string>
106 *       // Name of cpu the profile is built on
107 *       build_cpu; <string>
108 *       // Combination of build_os and build_cpu for convenience
109 *       build_platform; <string>
110 *
111 *       // List of dependencies needed to build this profile
112 *       dependencies: <Array of strings>
113 *
114 *       // List of configure args to use for this profile
115 *       configure_args: <Array of strings>
116 *
117 *       // List of free form labels describing aspects of this profile
118 *       labels: <Array of strings>
119 *     }
120 *   }
121 *
122 *   // Dependencies use a Maven like deployment structure
123 *   dependencies: {
124 *     <dependency-name>: {
125 *       // Organization part of path defining this dependency
126 *       organization: <string>
127 *       // File extension for this dependency
128 *       ext: <string>
129 *       // Module part of path for defining this dependency,
130 *       // defaults to <dependency-name>
131 *       module: <string>
132 *       // Revision part of path for defining this dependency
133 *       revision: <string>
134 *
135 *       // List of configure args to add when using this dependency,
136 *       // defaults to
137 *       // "--with-<dependency-name>=input.get("<dependency-name", "install_path")"
138 *       configure_args: <array of strings>
139 *
140 *       // Name of environment variable to set when using this dependency
141 *       // when running make
142 *       environment_name: <string>
143 *       // Value of environment variable to set when using this dependency
144 *       // when running make
145 *       environment_value: <string>
146 *
147 *       // Value to add to the PATH variable when using this dependency,
148 *       // applies to both make and configure
149 *       environment_path: <string>
150 *     }
151 *
152 *     <dependency-name>: {
153 *       // For certain dependencies where a legacy distribution mechanism is
154 *       // already in place, the "javare" server layout is also supported
155 *       // Indicate that an alternate server source and layout should be used
156 *       server: "javare"
157 *
158 *       // For "javare", a combination of module, revision,
159 *       // build number (optional), files and checksum file is possible for
160 *       // artifacts following the standard layout.
161 *       module: <string>
162 *       revision: <string>
163 *       build_number: <string>
164 *       checksum_file: <string>
165 *       file: <string>
166 *
167 *       // For other files, use checksum path and path instead
168 *       checksum_path: <string>
169 *       path: <string>
170 *     }
171 *   }
172 * }
173 */
174
175/**
176 * Main entry to generate the profile configuration
177 *
178 * @param input External data to use for generating the configuration
179 * @returns {{}} Profile configuration
180 */
181var getJibProfiles = function (input) {
182
183    var data = {};
184
185    // Identifies the version of this format to the tool reading it.
186    // 1.1 signifies that the publish, publish-src and get-src features are usable.
187    data.format_version = "1.1";
188
189    // Organization, product and version are used when uploading/publishing build results
190    data.organization = "";
191    data.product = "jdk";
192    data.version = getVersion();
193
194    // The base directory for the build output. JIB will assume that the
195    // actual build directory will be <output_basedir>/<configuration>
196    data.output_basedir = "build";
197    // The configure argument to use to specify the name of the configuration
198    data.configuration_configure_arg = "--with-conf-name=";
199    // The make argument to use to specify the name of the configuration
200    data.configuration_make_arg = "CONF_NAME=";
201
202    // Exclude list to use when Jib creates a source bundle
203    data.src_bundle_excludes = "./build webrev .hg */.hg */*/.hg */*/*/.hg";
204    // Include list to use when creating a minimal jib source bundle which
205    // contains just the jib configuration files.
206    data.conf_bundle_includes = "*/conf/jib-profiles.* common/autoconf/version-numbers"
207
208    // Define some common values
209    var common = getJibProfilesCommon(input, data);
210    // Generate the profiles part of the configuration
211    data.profiles = getJibProfilesProfiles(input, common, data);
212    // Generate the dependencies part of the configuration
213    data.dependencies = getJibProfilesDependencies(input, common, data);
214
215    return data;
216};
217
218/**
219 * Generates some common values
220 *
221 * @param input External data to use for generating the configuration
222 * @returns Common values
223 */
224var getJibProfilesCommon = function (input, data) {
225    var common = {};
226
227    common.organization = "jpg.infra.builddeps";
228    common.build_id = getBuildId(input);
229    common.build_number = input.build_number != null ? input.build_number : "0";
230
231    // List of the main profile names used for iteration
232    common.main_profile_names = [
233        "linux-x64", "linux-x86", "macosx-x64", "solaris-x64",
234        "solaris-sparcv9", "windows-x64", "windows-x86",
235        "linux-arm64", "linux-arm-vfp-hflt", "linux-arm-vfp-hflt-dyn"
236    ];
237
238    // These are the base setttings for all the main build profiles.
239    common.main_profile_base = {
240        dependencies: ["boot_jdk", "gnumake", "jtreg"],
241        default_make_targets: ["product-bundles", "test-bundles"],
242        configure_args: concat(["--enable-jtreg-failure-handler"],
243                               versionArgs(input, common))
244    };
245    // Extra settings for debug profiles
246    common.debug_suffix = "-debug";
247    common.debug_profile_base = {
248        configure_args: ["--enable-debug"],
249        labels: "debug"
250    };
251    // Extra settings for slowdebug profiles
252    common.slowdebug_suffix = "-slowdebug";
253    common.slowdebug_profile_base = {
254        configure_args: ["--with-debug-level=slowdebug"],
255        labels: "slowdebug"
256    };
257    // Extra settings for openjdk only profiles
258    common.open_suffix = "-open";
259    common.open_profile_base = {
260        configure_args: ["--enable-openjdk-only"],
261        labels: "open"
262    };
263
264    common.configure_args_64bit = ["--with-target-bits=64"];
265    common.configure_args_32bit = ["--with-target-bits=32"];
266
267    /**
268     * Define common artifacts template for all main profiles
269     * @param o - Object containing data for artifacts
270     */
271    common.main_profile_artifacts = function (o) {
272        var jdk_subdir = (o.jdk_subdir != null ? o.jdk_subdir : "jdk-" + data.version);
273        var jre_subdir = (o.jre_subdir != null ? o.jre_subdir : "jre-" + data.version);
274        var pf = o.platform
275        return {
276            artifacts: {
277                jdk: {
278                    local: "bundles/\\(jdk.*bin.tar.gz\\)",
279                    remote: [
280                        "bundles/" + pf + "/jdk-" + data.version + "_" + pf + "_bin.tar.gz",
281                        "bundles/" + pf + "/\\1"
282                    ],
283                    subdir: jdk_subdir,
284                    exploded: "images/jdk"
285                },
286                jre: {
287                    local: "bundles/\\(jre.*bin.tar.gz\\)",
288                    remote: [
289                        "bundles/" + pf + "/jre-" + data.version + "_" + pf + "_bin.tar.gz",
290                        "bundles/" + pf + "/\\1"
291                    ],
292                    subdir: jre_subdir,
293                    exploded: "images/jre"
294                },
295                test: {
296                    local: "bundles/\\(jdk.*bin-tests.tar.gz\\)",
297                    remote: [
298                        "bundles/" + pf + "/jdk-" + data.version + "_" + pf + "_bin-tests.tar.gz",
299                        "bundles/" + pf + "/\\1"
300                    ],
301                    exploded: "images/test"
302                },
303                jdk_symbols: {
304                    local: "bundles/\\(jdk.*bin-symbols.tar.gz\\)",
305                    remote: [
306                        "bundles/" + pf + "/jdk-" + data.version + "_" + pf + "_bin-symbols.tar.gz",
307                        "bundles/" + pf + "/\\1"
308                    ],
309                    subdir: jdk_subdir,
310                    exploded: "images/jdk"
311                },
312                jre_symbols: {
313                    local: "bundles/\\(jre.*bin-symbols.tar.gz\\)",
314                    remote: [
315                        "bundles/" + pf + "/jre-" + data.version + "_" + pf + "_bin-symbols.tar.gz",
316                        "bundles/" + pf + "/\\1"
317                    ],
318                    subdir: jre_subdir,
319                    exploded: "images/jre"
320                }
321            }
322        };
323    };
324
325
326    /**
327     * Define common artifacts template for all debug profiles
328     * @param o - Object containing data for artifacts
329     */
330    common.debug_profile_artifacts = function (o) {
331        var jdk_subdir = "jdk-" + data.version + "/fastdebug";
332        var jre_subdir = "jre-" + data.version + "/fastdebug";
333        var pf = o.platform
334        return {
335            artifacts: {
336                jdk: {
337                    local: "bundles/\\(jdk.*bin-debug.tar.gz\\)",
338                    remote: [
339                        "bundles/" + pf + "/jdk-" + data.version + "_" + pf + "_bin-debug.tar.gz",
340                        "bundles/" + pf + "/\\1"
341                    ],
342                    subdir: jdk_subdir,
343                    exploded: "images/jdk"
344                },
345                jre: {
346                    local: "bundles/\\(jre.*bin-debug.tar.gz\\)",
347                    remote: [
348                        "bundles/" + pf + "/jre-" + data.version + "_" + pf + "_bin-debug.tar.gz",
349                        "bundles/" + pf + "/\\1"
350                    ],
351                    subdir: jre_subdir,
352                    exploded: "images/jre"
353                },
354                test: {
355                    local: "bundles/\\(jdk.*bin-tests-debug.tar.gz\\)",
356                    remote: [
357                        "bundles/" + pf + "/jdk-" + data.version + "_" + pf + "_bin-tests-debug.tar.gz",
358                        "bundles/" + pf + "/\\1"
359                    ],
360                    exploded: "images/test"
361                },
362                jdk_symbols: {
363                    local: "bundles/\\(jdk.*bin-debug-symbols.tar.gz\\)",
364                    remote: [
365                        "bundles/" + pf + "/jdk-" + data.version + "_" + pf + "_bin-debug-symbols.tar.gz",
366                        "bundles/" + pf + "/\\1"
367                    ],
368                    subdir: jdk_subdir,
369                    exploded: "images/jdk"
370                },
371                jre_symbols: {
372                    local: "bundles/\\(jre.*bin-debug-symbols.tar.gz\\)",
373                    remote: [
374                        "bundles/" + pf + "/jre-" + data.version + "_" + pf + "_bin-debug-symbols.tar.gz",
375                        "bundles/" + pf + "/\\1"
376                    ],
377                    subdir: jre_subdir,
378                    exploded: "images/jre"
379                }
380            }
381        };
382    };
383
384    var boot_jdk_revision = "8";
385    var boot_jdk_subdirpart = "1.8.0";
386    // JDK 8 does not work on sparc M7 cpus, need a newer update when building
387    // on such hardware.
388    if (input.build_cpu == "sparcv9") {
389       var cpu_brand = $EXEC("bash -c \"kstat -m cpu_info | grep brand | head -n1 | awk '{ print \$2 }'\"");
390       if (cpu_brand.trim().match('SPARC-.[78]')) {
391           boot_jdk_revision = "8u20";
392           boot_jdk_subdirpart = "1.8.0_20";
393       }
394    }
395    common.boot_jdk_revision = boot_jdk_revision;
396    common.boot_jdk_subdirpart = boot_jdk_subdirpart;
397    common.boot_jdk_home = input.get("boot_jdk", "home_path") + "/jdk"
398        + common.boot_jdk_subdirpart
399        + (input.build_os == "macosx" ? ".jdk/Contents/Home" : "");
400    common.boot_jdk_platform = input.build_os + "-"
401        + (input.build_cpu == "x86" ? "i586" : input.build_cpu);
402
403    return common;
404};
405
406/**
407 * Generates the profiles part of the configuration.
408 *
409 * @param input External data to use for generating the configuration
410 * @param common The common values
411 * @returns {{}} Profiles part of the configuration
412 */
413var getJibProfilesProfiles = function (input, common, data) {
414    // Main SE profiles
415    var profiles = {
416
417        "linux-x64": {
418            target_os: "linux",
419            target_cpu: "x64",
420            dependencies: ["devkit", "graphviz", "pandoc"],
421            configure_args: concat(common.configure_args_64bit,
422                "--enable-full-docs", "--with-zlib=system"),
423            default_make_targets: ["docs-bundles"],
424        },
425
426        "linux-x86": {
427            target_os: "linux",
428            target_cpu: "x86",
429            build_cpu: "x64",
430            dependencies: ["devkit"],
431            configure_args: concat(common.configure_args_32bit,
432                "--with-jvm-variants=minimal,server", "--with-zlib=system"),
433        },
434
435        "macosx-x64": {
436            target_os: "macosx",
437            target_cpu: "x64",
438            dependencies: ["devkit"],
439            configure_args: concat(common.configure_args_64bit, "--with-zlib=system"),
440        },
441
442        "solaris-x64": {
443            target_os: "solaris",
444            target_cpu: "x64",
445            dependencies: ["devkit", "cups"],
446            configure_args: concat(common.configure_args_64bit,
447                "--with-zlib=system", "--enable-dtrace"),
448        },
449
450        "solaris-sparcv9": {
451            target_os: "solaris",
452            target_cpu: "sparcv9",
453            dependencies: ["devkit", "cups"],
454            configure_args: concat(common.configure_args_64bit,
455                "--with-zlib=system", "--enable-dtrace"),
456        },
457
458        "windows-x64": {
459            target_os: "windows",
460            target_cpu: "x64",
461            dependencies: ["devkit", "freetype"],
462            configure_args: concat(common.configure_args_64bit),
463        },
464
465        "windows-x86": {
466            target_os: "windows",
467            target_cpu: "x86",
468            build_cpu: "x64",
469            dependencies: ["devkit", "freetype"],
470            configure_args: concat(common.configure_args_32bit),
471        },
472
473        "linux-arm64": {
474            target_os: "linux",
475            target_cpu: "aarch64",
476            build_cpu: "x64",
477            dependencies: ["devkit", "build_devkit", "cups", "headless_stubs"],
478            configure_args: [
479                "--with-cpu-port=arm64",
480                "--with-jvm-variants=server",
481                "--openjdk-target=aarch64-linux-gnu",
482                "--enable-headless-only"
483            ],
484        },
485
486        "linux-arm-vfp-hflt": {
487            target_os: "linux",
488            target_cpu: "arm",
489            build_cpu: "x64",
490            dependencies: ["devkit", "build_devkit", "cups"],
491            configure_args: [
492                "--with-jvm-variants=minimal1,client",
493                "--with-x=" + input.get("devkit", "install_path") + "/arm-linux-gnueabihf/libc/usr/X11R6-PI",
494                "--openjdk-target=arm-linux-gnueabihf",
495                "--with-abi-profile=arm-vfp-hflt"
496            ],
497        },
498
499        // Special version of the SE profile adjusted to be testable on arm64 hardware.
500        "linux-arm-vfp-hflt-dyn": {
501            configure_args: "--with-stdc++lib=dynamic"
502        }
503    };
504    // Let linux-arm-vfp-hflt-dyn inherit everything from linux-arm-vfp-hflt
505    profiles["linux-arm-vfp-hflt-dyn"] = concatObjects(
506        profiles["linux-arm-vfp-hflt-dyn"], profiles["linux-arm-vfp-hflt"]);
507
508    // Add the base settings to all the main profiles
509    common.main_profile_names.forEach(function (name) {
510        profiles[name] = concatObjects(common.main_profile_base, profiles[name]);
511    });
512
513    // Generate debug versions of all the main profiles
514    common.main_profile_names.forEach(function (name) {
515        var debugName = name + common.debug_suffix;
516        profiles[debugName] = concatObjects(profiles[name],
517                                            common.debug_profile_base);
518    });
519    // Generate slowdebug versions of all the main profiles
520    common.main_profile_names.forEach(function (name) {
521        var debugName = name + common.slowdebug_suffix;
522        profiles[debugName] = concatObjects(profiles[name],
523                                            common.slowdebug_profile_base);
524    });
525
526    // Generate open only profiles for all the main profiles for JPRT and reference
527    // implementation builds.
528    common.main_profile_names.forEach(function (name) {
529        var openName = name + common.open_suffix;
530        profiles[openName] = concatObjects(profiles[name],
531                                           common.open_profile_base);
532    });
533    // The open only profiles on linux are used for reference builds and should
534    // produce the compact profile images by default. This adds "profiles" as an
535    // extra default target.
536    var openOnlyProfilesExtra = {
537        "linux-x86-open": {
538            default_make_targets: "profiles-bundles",
539            configure_args: "--with-jvm-variants=client,server"
540        }
541    };
542    profiles = concatObjects(profiles, openOnlyProfilesExtra);
543
544    // Generate debug profiles for the open only profiles
545    common.main_profile_names.forEach(function (name) {
546        var openName = name + common.open_suffix;
547        var openDebugName = openName + common.debug_suffix;
548        profiles[openDebugName] = concatObjects(profiles[openName],
549                                                common.debug_profile_base);
550    });
551
552    // Profiles for building the zero jvm variant. These are used for verification
553    // in JPRT.
554    var zeroProfiles = {
555        "linux-x64-zero": {
556            target_os: "linux",
557            target_cpu: "x64",
558            dependencies: ["devkit"],
559            configure_args: concat(common.configure_args_64bit, [
560                "--with-zlib=system",
561                "--with-jvm-variants=zero",
562                "--enable-libffi-bundling"
563            ])
564        },
565
566        "linux-x86-zero": {
567            target_os: "linux",
568            target_cpu: "x86",
569            build_cpu: "x64",
570            dependencies: ["devkit"],
571            configure_args:  concat(common.configure_args_32bit, [
572                "--with-zlib=system",
573                "--with-jvm-variants=zero",
574                "--enable-libffi-bundling"
575            ])
576        }
577    }
578    profiles = concatObjects(profiles, zeroProfiles);
579
580    // Add the base settings to the zero profiles and generate debug profiles
581    Object.keys(zeroProfiles).forEach(function (name) {
582        var debugName = name + common.debug_suffix;
583        profiles[name] = concatObjects(common.main_profile_base, profiles[name]);
584        profiles[debugName] = concatObjects(profiles[name], common.debug_profile_base);
585    });
586
587    // Profiles used to run tests. Used in JPRT and Mach 5.
588    var testOnlyProfiles = {
589        "run-test-jprt": {
590            target_os: input.build_os,
591            target_cpu: input.build_cpu,
592            dependencies: [ "jtreg", "gnumake", "boot_jdk" ],
593            labels: "test",
594            environment: {
595                "JT_JAVA": common.boot_jdk_home
596            }
597        },
598
599        "run-test": {
600            target_os: input.build_os,
601            target_cpu: input.build_cpu,
602            dependencies: [ "jtreg", "gnumake", "boot_jdk" ],
603            labels: "test",
604            environment: {
605                "JT_JAVA": common.boot_jdk_home
606            }
607        }
608    };
609    profiles = concatObjects(profiles, testOnlyProfiles);
610
611    // Profiles used to run tests using Jib for internal dependencies.
612    var testedProfile = input.testedProfile;
613    if (testedProfile == null) {
614        testedProfile = input.build_os + "-" + input.build_cpu;
615    }
616    var testOnlyProfilesPrebuilt = {
617        "run-test-prebuilt": {
618            src: "src.conf",
619            dependencies: [ "jtreg", "gnumake", "boot_jdk", testedProfile + ".jdk",
620                testedProfile + ".test", "src.full"
621            ],
622            work_dir: input.get("src.full", "install_path") + "/test",
623            environment: {
624                "JT_JAVA": common.boot_jdk_home,
625                "PRODUCT_HOME": input.get(testedProfile + ".jdk", "home_path"),
626                "TEST_IMAGE_DIR": input.get(testedProfile + ".test", "home_path"),
627                "TEST_OUTPUT_DIR": input.src_top_dir
628            },
629            labels: "test"
630        }
631    };
632    // If actually running the run-test-prebuilt profile, verify that the input
633    // variable is valid and if so, add the appropriate target_* values from
634    // the tested profile.
635    if (input.profile == "run-test-prebuilt") {
636        if (profiles[testedProfile] == null) {
637            error("testedProfile is not defined: " + testedProfile);
638        } else {
639            testOnlyProfilesPrebuilt["run-test-prebuilt"]["target_os"]
640                = profiles[testedProfile]["target_os"];
641            testOnlyProfilesPrebuilt["run-test-prebuilt"]["target_cpu"]
642                = profiles[testedProfile]["target_cpu"];
643        }
644    }
645    profiles = concatObjects(profiles, testOnlyProfilesPrebuilt);
646
647    // On macosx add the devkit bin dir to the path in all the run-test profiles.
648    // This gives us a guaranteed working version of lldb for the jtreg failure handler.
649    if (input.build_os == "macosx") {
650        macosxRunTestExtra = {
651            dependencies: [ "devkit" ],
652            environment_path: input.get("devkit", "install_path")
653                + "/Xcode.app/Contents/Developer/usr/bin"
654        }
655        profiles["run-test"] = concatObjects(profiles["run-test"], macosxRunTestExtra);
656        profiles["run-test-jprt"] = concatObjects(profiles["run-test-jprt"], macosxRunTestExtra);
657        profiles["run-test-prebuilt"] = concatObjects(profiles["run-test-prebuilt"], macosxRunTestExtra);
658    }
659
660    //
661    // Define artifacts for profiles
662    //
663    // Macosx bundles are named osx
664    // tar.gz.
665    var artifactData = {
666        "linux-x64": {
667            platform: "linux-x64",
668        },
669        "linux-x86": {
670            platform: "linux-x86",
671        },
672        "macosx-x64": {
673            platform: "osx-x64",
674            jdk_subdir: "jdk-" + data.version +  ".jdk/Contents/Home",
675            jre_subdir: "jre-" + data.version +  ".jre/Contents/Home"
676        },
677        "solaris-x64": {
678            platform: "solaris-x64",
679        },
680        "solaris-sparcv9": {
681            platform: "solaris-sparcv9",
682        },
683        "windows-x64": {
684            platform: "windows-x64",
685        },
686        "windows-x86": {
687            platform: "windows-x86",
688        },
689       "linux-arm64": {
690            platform: "linux-arm64-vfp-hflt",
691        },
692        "linux-arm-vfp-hflt": {
693            platform: "linux-arm32-vfp-hflt",
694        },
695        "linux-arm-vfp-hflt-dyn": {
696            platform: "linux-arm32-vfp-hflt-dyn",
697        }
698    }
699    // Generate common artifacts for all main profiles
700    Object.keys(artifactData).forEach(function (name) {
701        profiles[name] = concatObjects(profiles[name],
702            common.main_profile_artifacts(artifactData[name]));
703    });
704
705    // Generate common artifacts for all debug profiles
706    Object.keys(artifactData).forEach(function (name) {
707        var debugName = name + common.debug_suffix;
708        profiles[debugName] = concatObjects(profiles[debugName],
709            common.debug_profile_artifacts(artifactData[name]));
710    });
711
712    // Extra profile specific artifacts
713    profilesArtifacts = {
714        "linux-x64": {
715            artifacts: {
716                doc_api_spec: {
717                    local: "bundles/\\(jdk.*doc-api-spec.tar.gz\\)",
718                    remote: [
719                        "bundles/common/jdk-" + data.version + "_doc-api-spec.tar.gz",
720                        "bundles/linux-x64/\\1"
721                    ],
722                },
723            }
724        },
725
726        "linux-x64-open": {
727            artifacts: {
728                jdk: {
729                    local: "bundles/\\(jdk.*bin.tar.gz\\)",
730                    remote: [
731                        "bundles/openjdk/GPL/linux-x64/jdk-" + data.version
732                            + "_linux-x64_bin.tar.gz",
733                        "bundles/openjdk/GPL/linux-x64/\\1"
734                    ],
735                    subdir: "jdk-" + data.version
736                },
737                jre: {
738                    local: "bundles/\\(jre.*bin.tar.gz\\)",
739                    remote: "bundles/openjdk/GPL/linux-x64/\\1",
740                },
741                test: {
742                    local: "bundles/\\(jdk.*bin-tests.tar.gz\\)",
743                    remote: [
744                        "bundles/openjdk/GPL/linux-x64/jdk-" + data.version
745                            + "_linux-x64_bin-tests.tar.gz",
746                        "bundles/openjdk/GPL/linux-x64/\\1"
747                    ]
748                },
749                jdk_symbols: {
750                    local: "bundles/\\(jdk.*bin-symbols.tar.gz\\)",
751                    remote: [
752                        "bundles/openjdk/GPL/linux-x64/jdk-" + data.version
753                            + "_linux-x64_bin-symbols.tar.gz",
754                        "bundles/openjdk/GPL/linux-x64/\\1"
755                    ],
756                    subdir: "jdk-" + data.version
757                },
758                jre_symbols: {
759                    local: "bundles/\\(jre.*bin-symbols.tar.gz\\)",
760                    remote: "bundles/openjdk/GPL/linux-x64/\\1",
761                },
762                doc_api_spec: {
763                    local: "bundles/\\(jdk.*doc-api-spec.tar.gz\\)",
764                    remote: "bundles/openjdk/GPL/linux-x64/\\1",
765                },
766            }
767        },
768
769        "linux-x86-open": {
770            artifacts: {
771                jdk: {
772                    local: "bundles/\\(jdk.*bin.tar.gz\\)",
773                    remote: [
774                        "bundles/openjdk/GPL/linux-x86/jdk-" + data.version
775                            + "_linux-x86_bin.tar.gz",
776                        "bundles/openjdk/GPL/linux-x86/\\1"
777                    ],
778                    subdir: "jdk-" + data.version
779                },
780                jdk_symbols: {
781                    local: "bundles/\\(jdk.*bin-symbols.tar.gz\\)",
782                    remote: [
783                        "bundles/openjdk/GPL/linux-x86/jdk-" + data.version
784                            + "_linux-x86_bin-symbols.tar.gz",
785                        "bundles/openjdk/GPL/linux-x86/\\1"
786                    ],
787                    subdir: "jdk-" + data.version
788                },
789                test: {
790                    local: "bundles/\\(jdk.*bin-tests.tar.gz\\)",
791                    remote: [
792                        "bundles/openjdk/GPL/linux-x86/jdk-" + data.version
793                            + "_linux-x86_bin-tests.tar.gz",
794                        "bundles/openjdk/GPL/linux-x86/\\1"
795                    ]
796                },
797                jre: {
798                    // This regexp needs to not match the compact* files below
799                    local: "bundles/\\(jre.*[+][0-9]\\{1,\\}_linux-x86_bin.tar.gz\\)",
800                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
801                },
802                jre_compact1: {
803                    local: "bundles/\\(jre.*-compact1_linux-x86_bin.tar.gz\\)",
804                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
805                },
806                jre_compact2: {
807                    local: "bundles/\\(jre.*-compact2_linux-x86_bin.tar.gz\\)",
808                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
809                },
810                jre_compact3: {
811                    local: "bundles/\\(jre.*-compact3_linux-x86_bin.tar.gz\\)",
812                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
813                },
814            }
815        },
816
817        "windows-x86-open": {
818            artifacts: {
819                jdk: {
820                    local: "bundles/\\(jdk.*bin.tar.gz\\)",
821                    remote: [
822                        "bundles/openjdk/GPL/windows-x86/jdk-" + data.version
823                            + "_windows-x86_bin.tar.gz",
824                        "bundles/openjdk/GPL/windows-x86/\\1"
825                    ],
826                    subdir: "jdk-" + data.version
827                },
828                jre: {
829                    local: "bundles/\\(jre.*bin.tar.gz\\)",
830                    remote: "bundles/openjdk/GPL/windows-x86/\\1"
831                },
832                test: {
833                    local: "bundles/\\(jdk.*bin-tests.tar.gz\\)",
834                    remote: [
835                        "bundles/openjdk/GPL/windows-x86/jdk-" + data.version
836                            + "_windows-x86_bin-tests.tar.gz",
837                        "bundles/openjdk/GPL/windows-x86/\\1"
838                    ]
839                },
840                jdk_symbols: {
841                    local: "bundles/\\(jdk.*bin-symbols.tar.gz\\)",
842                    remote: [
843                        "bundles/openjdk/GPL/windows-x86/jdk-" + data.version
844                            + "_windows-x86_bin-symbols.tar.gz",
845                        "bundles/openjdk/GPL/windows-x86/\\1"
846                    ],
847                    subdir: "jdk-" + data.version
848                },
849                jre_symbols: {
850                    local: "bundles/\\(jre.*bin-symbols.tar.gz\\)",
851                    remote: "bundles/openjdk/GPL/windows-x86/\\1",
852                }
853            }
854        },
855
856        "linux-x86-open-debug": {
857            artifacts: {
858                jdk: {
859                    local: "bundles/\\(jdk.*bin-debug.tar.gz\\)",
860                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
861                },
862                jre: {
863                    local: "bundles/\\(jre.*bin-debug.tar.gz\\)",
864                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
865                },
866                jdk_symbols: {
867                    local: "bundles/\\(jdk.*bin-debug-symbols.tar.gz\\)",
868                    remote: "bundles/openjdk/GPL/profile/linux-x86/\\1",
869                },
870            }
871        },
872
873    };
874    profiles = concatObjects(profiles, profilesArtifacts);
875
876
877    // Define the reference implementation profiles. These are basically the same
878    // as the open profiles, but upload artifacts to a different location and
879    // are only defined for specific platforms.
880    profiles["linux-x64-ri"] = clone(profiles["linux-x64-open"]);
881    profiles["linux-x86-ri"] = clone(profiles["linux-x86-open"]);
882    profiles["linux-x86-ri-debug"] = clone(profiles["linux-x86-open-debug"]);
883    profiles["windows-x86-ri"] = clone(profiles["windows-x86-open"]);
884
885    // Generate artifacts for ri profiles
886    [ "linux-x64-ri", "linux-x86-ri", "linux-x86-ri-debug", "windows-x86-ri" ]
887        .forEach(function (name) {
888            // Rewrite all remote dirs to "bundles/openjdk/BCL/..."
889            for (artifactName in profiles[name].artifacts) {
890                var artifact = profiles[name].artifacts[artifactName];
891                artifact.remote = replaceAll("\/GPL\/", "/BCL/",
892                    (artifact.remote != null ? artifact.remote : artifact.local));
893            }
894        });
895
896    // Generate the missing platform attributes
897    profiles = generatePlatformAttributes(profiles);
898    profiles = generateDefaultMakeTargetsConfigureArg(common, profiles);
899    return profiles;
900};
901
902/**
903 * Generate the dependencies part of the configuration
904 *
905 * @param input External data to use for generating the configuration
906 * @param common The common values
907 * @returns {{}} Dependencies part of configuration
908 */
909var getJibProfilesDependencies = function (input, common) {
910
911    var devkit_platform_revisions = {
912        linux_x64: "gcc4.9.2-OEL6.4+1.1",
913        macosx_x64: "Xcode6.3-MacOSX10.9+1.0",
914        solaris_x64: "SS12u4-Solaris11u1+1.0",
915        solaris_sparcv9: "SS12u4-Solaris11u1+1.0",
916        windows_x64: "VS2013SP4+1.0",
917        linux_aarch64: "gcc-linaro-aarch64-linux-gnu-4.8-2013.11_linux+1.0",
918        linux_arm: (input.profile != null && input.profile.indexOf("hflt") >= 0
919                    ? "gcc-linaro-arm-linux-gnueabihf-raspbian-2012.09-20120921_linux+1.0"
920                    : "arm-linaro-4.7+1.0")
921    };
922
923    var devkit_platform = (input.target_cpu == "x86"
924        ? input.target_os + "_x64"
925        : input.target_platform);
926
927    var dependencies = {
928
929        boot_jdk: {
930            server: "javare",
931            module: "jdk",
932            revision: common.boot_jdk_revision,
933            checksum_file: common.boot_jdk_platform + "/MD5_VALUES",
934            file: common.boot_jdk_platform + "/jdk-" + common.boot_jdk_revision
935                + "-" + common.boot_jdk_platform + ".tar.gz",
936            configure_args: "--with-boot-jdk=" + common.boot_jdk_home,
937            environment_path: common.boot_jdk_home + "/bin"
938        },
939
940        devkit: {
941            organization: common.organization,
942            ext: "tar.gz",
943            module: "devkit-" + devkit_platform,
944            revision: devkit_platform_revisions[devkit_platform]
945        },
946
947        build_devkit: {
948            organization: common.organization,
949            ext: "tar.gz",
950            module: "devkit-" + input.build_platform,
951            revision: devkit_platform_revisions[input.build_platform]
952        },
953
954        cups: {
955            organization: common.organization,
956            ext: "tar.gz",
957            revision: "1.0118+1.0"
958        },
959
960        jtreg: {
961            server: "javare",
962            revision: "4.2",
963            build_number: "b07",
964            checksum_file: "MD5_VALUES",
965            file: "jtreg_bin-4.2.zip",
966            environment_name: "JT_HOME",
967            environment_path: input.get("jtreg", "install_path") + "/jtreg/bin"
968        },
969
970        gnumake: {
971            organization: common.organization,
972            ext: "tar.gz",
973            revision: "4.0+1.0",
974
975            module: (input.build_os == "windows"
976                ? "gnumake-" + input.build_osenv_platform
977                : "gnumake-" + input.build_platform),
978
979            configure_args: (input.build_os == "windows"
980                ? "MAKE=" + input.get("gnumake", "install_path") + "/cygwin/bin/make"
981                : "MAKE=" + input.get("gnumake", "install_path") + "/bin/make"),
982
983            environment_path: (input.build_os == "windows"
984                ? input.get("gnumake", "install_path") + "/cygwin/bin"
985                : input.get("gnumake", "install_path") + "/bin")
986        },
987
988        freetype: {
989            organization: common.organization,
990            ext: "tar.gz",
991            revision: "2.7.1-v120+1.0",
992            module: "freetype-" + input.target_platform
993        },
994
995        graphviz: {
996            organization: common.organization,
997            ext: "tar.gz",
998            revision: "2.38.0-1+1.1",
999            module: "graphviz-" + input.target_platform,
1000            configure_args: "DOT=" + input.get("graphviz", "install_path") + "/dot",
1001            environment_path: input.get("graphviz", "install_path")
1002        },
1003
1004        pandoc: {
1005            organization: common.organization,
1006            ext: "tar.gz",
1007            revision: "1.17.2+1.0",
1008            module: "pandoc-" + input.target_platform,
1009            configure_args: "PANDOC=" + input.get("pandoc", "install_path") + "/pandoc/pandoc",
1010            environment_path: input.get("pandoc", "install_path") + "/pandoc"
1011        },
1012    };
1013
1014    return dependencies;
1015};
1016
1017/**
1018 * Generate the missing platform attributes for profiles
1019 *
1020 * @param profiles Profiles map to generate attributes on
1021 * @returns {{}} New profiles map with platform attributes fully filled in
1022 */
1023var generatePlatformAttributes = function (profiles) {
1024    var ret = concatObjects(profiles, {});
1025    for (var profile in profiles) {
1026        if (ret[profile].build_os == null) {
1027            ret[profile].build_os = ret[profile].target_os;
1028        }
1029        if (ret[profile].build_cpu == null) {
1030            ret[profile].build_cpu = ret[profile].target_cpu;
1031        }
1032        ret[profile].target_platform = ret[profile].target_os + "_" + ret[profile].target_cpu;
1033        ret[profile].build_platform = ret[profile].build_os + "_" + ret[profile].build_cpu;
1034    }
1035    return ret;
1036};
1037
1038/**
1039 * The default_make_targets attribute on a profile is not a real Jib attribute.
1040 * This function rewrites that attribute into the corresponding configure arg.
1041 * Calling this function multiple times on the same profiles object is safe.
1042 *
1043 * @param common Common values
1044 * @param profiles Profiles map to rewrite profiles for
1045 * @returns {{}} New map of profiles with the make targets converted
1046 */
1047var generateDefaultMakeTargetsConfigureArg = function (common, profiles) {
1048    var ret = concatObjects(profiles, {});
1049    for (var profile in ret) {
1050        if (ret[profile]["default_make_targets"] != null) {
1051            var targetsString = concat(ret[profile].default_make_targets).join(" ");
1052            // Iterate over all configure args and see if --with-default-make-target
1053            // is already there and change it, otherwise add it.
1054            var found = false;
1055            for (var i in ret[profile].configure_args) {
1056                var arg = ret[profile].configure_args[i];
1057                if (arg != null && arg.startsWith("--with-default-make-target=")) {
1058                    found = true;
1059                    ret[profile].configure_args[i]
1060                        = "--with-default-make-target=" + targetsString;
1061                }
1062            }
1063            if (!found) {
1064                ret[profile].configure_args = concat(
1065                    ret[profile].configure_args,
1066                    "--with-default-make-target=" + targetsString);
1067            }
1068        }
1069    }
1070    return ret;
1071}
1072
1073var getBuildId = function (input) {
1074    if (input.build_id != null) {
1075        return input.build_id;
1076    } else {
1077        var topdir = new java.io.File(__DIR__, "../..").getCanonicalFile().getName();
1078        var userName = java.lang.System.getProperty("user.name");
1079        return userName + "." + topdir;
1080    }
1081}
1082
1083/**
1084 * Deep clones an object tree.
1085 *
1086 * @param o Object to clone
1087 * @returns {{}} Clone of o
1088 */
1089var clone = function (o) {
1090    return JSON.parse(JSON.stringify(o));
1091};
1092
1093/**
1094 * Concatenates all arguments into a new array
1095 *
1096 * @returns {Array.<T>} New array containing all arguments
1097 */
1098var concat = function () {
1099    return Array.prototype.concat.apply([], arguments);
1100};
1101
1102/**
1103 * Takes a String or Array of Strings and does a replace operation on each
1104 * of them.
1105 *
1106 * @param pattern Pattern to look for
1107 * @param replacement Replacement text to insert
1108 * @param a String or Array of Strings to replace
1109 * @returns {Array} Either a new array or a new string depending on the input
1110 */
1111var replaceAll = function (pattern, replacement, a) {
1112    // If a is an array
1113    if (Array === a.constructor) {
1114    var newA = [];
1115    for (var i in a) {
1116            newA.push(a[i].replace(pattern, replacement));
1117        }
1118        return newA;
1119        } else {
1120        return a.replace(pattern, replacement);
1121    }
1122};
1123
1124/**
1125 * Deep concatenation of two objects. For each node encountered, merge
1126 * the contents with the corresponding node in the other object tree,
1127 * treating all strings as array elements.
1128 *
1129 * @param o1 Object to concatenate
1130 * @param o2 Object to concatenate
1131 * @returns {{}} New object tree containing the concatenation of o1 and o2
1132 */
1133var concatObjects = function (o1, o2) {
1134    if (o1 == null) {
1135        return clone(o2);
1136    }
1137    if (o2 == null) {
1138        return clone(o1);
1139    }
1140    var ret = {};
1141    for (var a in o1) {
1142        if (o2[a] == null) {
1143            ret[a] = clone(o1[a]);
1144        }
1145    }
1146    for (var a in o2) {
1147        if (o1[a] == null) {
1148            ret[a] = clone(o2[a]);
1149        } else {
1150            if (typeof o1[a] == 'string') {
1151                ret[a] = clone([o1[a]].concat(o2[a]));
1152            } else if (Array.isArray(o1[a])) {
1153                ret[a] = clone(o1[a].concat(o2[a]));
1154            } else if (typeof o1[a] == 'object') {
1155                ret[a] = concatObjects(o1[a], o2[a]);
1156            }
1157        }
1158    }
1159    return ret;
1160};
1161
1162/**
1163 * Constructs the numeric version string from reading the
1164 * common/autoconf/version-numbers file and removing all trailing ".0".
1165 *
1166 * @param major Override major version
1167 * @param minor Override minor version
1168 * @param security Override security version
1169 * @param patch Override patch version
1170 * @returns {String} The numeric version string
1171 */
1172var getVersion = function (major, minor, security, patch) {
1173    var version_numbers = getVersionNumbers();
1174    var version = (major != null ? major : version_numbers.get("DEFAULT_VERSION_MAJOR"))
1175        + "." + (minor != null ? minor : version_numbers.get("DEFAULT_VERSION_MINOR"))
1176        + "." + (security != null ? security :  version_numbers.get("DEFAULT_VERSION_SECURITY"))
1177        + "." + (patch != null ? patch : version_numbers.get("DEFAULT_VERSION_PATCH"));
1178    while (version.match(".*\\.0$")) {
1179        version = version.substring(0, version.length - 2);
1180    }
1181    return version;
1182};
1183
1184/**
1185 * Constructs the common version configure args based on build type and
1186 * other version inputs
1187 */
1188var versionArgs = function(input, common) {
1189    var args = ["--with-version-build=" + common.build_number];
1190    if (input.build_type == "promoted") {
1191        args = concat(args,
1192                      // This needs to be changed when we start building release candidates
1193                      "--with-version-pre=ea",
1194                      "--without-version-opt");
1195    } else {
1196        args = concat(args, "--with-version-opt=" + common.build_id);
1197    }
1198    return args;
1199}
1200
1201// Properties representation of the common/autoconf/version-numbers file. Lazily
1202// initiated by the function below.
1203var version_numbers;
1204
1205/**
1206 * Read the common/autoconf/version-numbers file into a Properties object.
1207 *
1208 * @returns {java.utilProperties}
1209 */
1210var getVersionNumbers = function () {
1211    // Read version information from common/autoconf/version-numbers
1212    if (version_numbers == null) {
1213        version_numbers = new java.util.Properties();
1214        var stream = new java.io.FileInputStream(__DIR__ + "/../../common/autoconf/version-numbers");
1215        version_numbers.load(stream);
1216        stream.close();
1217    }
1218    return version_numbers;
1219}
1220