bower2bazel: don't specify versions for non-seed packages.

The 'seed' packages are the ones whose versions are set by us in
WORKSPACE. We should not set the versions for the rest of the packages
in the bower input JSON, so bower can suggest the right versions to
use.

Change-Id: I9b75f16655d049e2064726862980a339c91dd534
This commit is contained in:
Han-Wen Nienhuys 2017-02-01 13:33:19 +01:00
parent a461a3d45a
commit 3dede1653a
3 changed files with 31 additions and 8 deletions

View File

@ -2,9 +2,11 @@ package(default_visibility = ["//visibility:public"])
load("//tools/bzl:js.bzl", "bower_component", "js_component") load("//tools/bzl:js.bzl", "bower_component", "js_component")
# For updating the bower versions, run # For importing new versions of existing bower packages,
# #
# python tools/js/bower2bazel.py -w lib/js/bower_archives.bzl -b lib/js/bower_components.bzl # 1) edit the versions of 'seed' components in WORKSPACE as desired
#
# 2) Run: 'python tools/js/bower2bazel.py -w lib/js/bower_archives.bzl -b lib/js/bower_components.bzl', to update dependency versions.
# #
# For adding a new component as dependency to a bower_component_bundle # For adding a new component as dependency to a bower_component_bundle

View File

@ -268,6 +268,15 @@ bower_component_bundle = rule(
"version_json": "%{name}-versions.json", "version_json": "%{name}-versions.json",
}, },
) )
"""Groups a set of bower components together in a zip file.
Outputs:
NAME-versions.json:
a JSON file containing a PKG-NAME => PKG-NAME#VERSION mapping for the
transitive dependencies.
NAME.zip:
a zip file containing the transitive dependencies for this bundle.
"""
def _vulcanize_impl(ctx): def _vulcanize_impl(ctx):
# intermediate artifact. # intermediate artifact.

View File

@ -59,15 +59,22 @@ package_licenses = {
} }
def build_bower_json(version_targets): def build_bower_json(version_targets, seeds):
"""Generate bower JSON file, return its path.""" """Generate bower JSON file, return its path.
Args:
version_targets: bazel target names of the versions.json file.
seeds: an iterable of bower package names of the seed packages, ie.
the packages whose versions we control manually.
"""
bower_json = collections.OrderedDict() bower_json = collections.OrderedDict()
bower_json['name'] = 'bower2buck-output' bower_json['name'] = 'bower2bazel-output'
bower_json['version'] = '0.0.0' bower_json['version'] = '0.0.0'
bower_json['description'] = 'Auto-generated bower.json for dependency management' bower_json['description'] = 'Auto-generated bower.json for dependency management'
bower_json['private'] = True bower_json['private'] = True
bower_json['dependencies'] = {} bower_json['dependencies'] = {}
seeds = set(seeds)
for v in version_targets: for v in version_targets:
fn = os.path.join("bazel-out/local-fastbuild/bin", v.lstrip("/").replace(":", "/")) fn = os.path.join("bazel-out/local-fastbuild/bin", v.lstrip("/").replace(":", "/"))
with open(fn) as f: with open(fn) as f:
@ -75,7 +82,13 @@ def build_bower_json(version_targets):
if "" in j: if "" in j:
# drop dummy entries. # drop dummy entries.
del j[""] del j[""]
bower_json['dependencies'].update(j)
trimmed = {}
for k, v in j.items():
if k in seeds:
trimmed[k] = v
bower_json['dependencies'].update(trimmed)
tmpdir = tempfile.mkdtemp() tmpdir = tempfile.mkdtemp()
ret = os.path.join(tmpdir, 'bower.json') ret = os.path.join(tmpdir, 'bower.json')
@ -110,9 +123,8 @@ def main(args):
seeds = set([s[len(prefix):] for s in seeds]) seeds = set([s[len(prefix):] for s in seeds])
version_targets = [t + "-versions.json" for t in targets] version_targets = [t + "-versions.json" for t in targets]
subprocess.check_call(['bazel', 'build'] + version_targets) subprocess.check_call(['bazel', 'build'] + version_targets)
bower_json_path = build_bower_json(version_targets) bower_json_path = build_bower_json(version_targets, seeds)
dir = os.path.dirname(bower_json_path) dir = os.path.dirname(bower_json_path)
cmd = bower_command(["install"]) cmd = bower_command(["install"])