bazel: add rules for vulcanize & crisper, and use them in //polygerrit-ui/app.
Change-Id: Icaa15889f9963464897742c5003bbf0b15c56ffd
This commit is contained in:
parent
251b09d4c7
commit
36502628b7
31
WORKSPACE
31
WORKSPACE
@ -962,6 +962,14 @@ npm_binary(
|
|||||||
name = "bower",
|
name = "bower",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
npm_binary(
|
||||||
|
name = "vulcanize",
|
||||||
|
)
|
||||||
|
|
||||||
|
npm_binary(
|
||||||
|
name = "crisper",
|
||||||
|
)
|
||||||
|
|
||||||
# bower_archive() seed components.
|
# bower_archive() seed components.
|
||||||
bower_archive(
|
bower_archive(
|
||||||
name = 'iron-autogrow-textarea',
|
name = 'iron-autogrow-textarea',
|
||||||
@ -1040,6 +1048,29 @@ bower_archive(
|
|||||||
sha1 = 'a3b598c06cbd7f441402e666ff748326030905d6',
|
sha1 = 'a3b598c06cbd7f441402e666ff748326030905d6',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# bower test stuff
|
||||||
|
|
||||||
|
bower_archive(
|
||||||
|
name = 'iron-test-helpers',
|
||||||
|
package = 'polymerelements/iron-test-helpers',
|
||||||
|
version = '1.2.5',
|
||||||
|
sha1 = '433b03b106f5ff32049b84150cd70938e18b67ac',
|
||||||
|
)
|
||||||
|
|
||||||
|
bower_archive(
|
||||||
|
name = 'test-fixture',
|
||||||
|
package = 'polymerelements/test-fixture',
|
||||||
|
version = '1.1.1',
|
||||||
|
sha1 = 'e373bd21c069163c3a754e234d52c07c77b20d3c',
|
||||||
|
)
|
||||||
|
|
||||||
|
bower_archive(
|
||||||
|
name = 'web-component-tester',
|
||||||
|
package = 'web-component-tester',
|
||||||
|
version = '4.2.2',
|
||||||
|
sha1 = '54556000c33d9ed7949aa546c1b4a1531491a5f0',
|
||||||
|
)
|
||||||
|
|
||||||
# Bower component transitive dependencies.
|
# Bower component transitive dependencies.
|
||||||
load("//lib/js:bower_archives.bzl", "load_bower_archives")
|
load("//lib/js:bower_archives.bzl", "load_bower_archives")
|
||||||
load_bower_archives()
|
load_bower_archives()
|
||||||
|
15
lib/js/BUILD
15
lib/js/BUILD
@ -27,3 +27,18 @@ js_component(
|
|||||||
srcs = [ "//lib/highlightjs:highlight.min.js" ],
|
srcs = [ "//lib/highlightjs:highlight.min.js" ],
|
||||||
license = '//lib:LICENSE-highlightjs',
|
license = '//lib:LICENSE-highlightjs',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
bower_component(
|
||||||
|
name = 'iron-test-helpers',
|
||||||
|
seed = True,
|
||||||
|
)
|
||||||
|
|
||||||
|
bower_component(
|
||||||
|
name = 'test-fixture',
|
||||||
|
seed = True,
|
||||||
|
)
|
||||||
|
|
||||||
|
bower_component(
|
||||||
|
name = 'web-component-tester',
|
||||||
|
seed = True,
|
||||||
|
)
|
||||||
|
@ -1,9 +1,12 @@
|
|||||||
|
package(
|
||||||
|
default_visibility=["//visibility:public"]
|
||||||
|
)
|
||||||
|
|
||||||
load("//tools/bzl:js.bzl", "bower_component_bundle")
|
load("//tools/bzl:js.bzl", "bower_component_bundle")
|
||||||
load('//tools/bzl:genrule2.bzl', 'genrule2')
|
load('//tools/bzl:genrule2.bzl', 'genrule2')
|
||||||
|
|
||||||
bower_component_bundle(
|
bower_component_bundle(
|
||||||
name = "components",
|
name = "polygerrit_components",
|
||||||
deps = [
|
deps = [
|
||||||
'//lib/js:es6-promise',
|
'//lib/js:es6-promise',
|
||||||
'//lib/js:fetch',
|
'//lib/js:fetch',
|
||||||
|
37
polygerrit-ui/app/BUILD
Normal file
37
polygerrit-ui/app/BUILD
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
package(
|
||||||
|
default_visibility = ["//visibility:public"])
|
||||||
|
load("//tools/bzl:js.bzl", "bower_component_bundle", "vulcanize")
|
||||||
|
|
||||||
|
WCT_TEST_PATTERNS = [
|
||||||
|
'test/*.js',
|
||||||
|
'test/*.html',
|
||||||
|
'**/*_test.html',
|
||||||
|
]
|
||||||
|
PY_TEST_PATTERNS = ['polygerrit_wct_tests.py']
|
||||||
|
APP_SRCS = glob(
|
||||||
|
['**'],
|
||||||
|
exclude = [
|
||||||
|
'BUCK',
|
||||||
|
'*~',
|
||||||
|
'**/BUILD',
|
||||||
|
'index.html',
|
||||||
|
'test/**',
|
||||||
|
] + WCT_TEST_PATTERNS + PY_TEST_PATTERNS)
|
||||||
|
|
||||||
|
|
||||||
|
bower_component_bundle(
|
||||||
|
name = 'test_components',
|
||||||
|
deps = [
|
||||||
|
'//polygerrit-ui:polygerrit_components',
|
||||||
|
'//lib/js:iron-test-helpers',
|
||||||
|
'//lib/js:test-fixture',
|
||||||
|
'//lib/js:web-component-tester',
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
vulcanize(
|
||||||
|
name = "gr-app",
|
||||||
|
app = 'elements/gr-app.html',
|
||||||
|
srcs = APP_SRCS,
|
||||||
|
deps = [ "//polygerrit-ui:polygerrit_components"],
|
||||||
|
)
|
106
tools/bzl/js.bzl
106
tools/bzl/js.bzl
@ -39,11 +39,12 @@ def _npm_binary_impl(ctx):
|
|||||||
python = ctx.which("python")
|
python = ctx.which("python")
|
||||||
script = ctx.path(ctx.attr._download_script)
|
script = ctx.path(ctx.attr._download_script)
|
||||||
|
|
||||||
args = [python, script, "-o", dest, "-u", url]
|
sha1 = NPM_SHA1S[name]
|
||||||
|
args = [python, script, "-o", dest, "-u", url, "-v", sha1]
|
||||||
out = ctx.execute(args)
|
out = ctx.execute(args)
|
||||||
if out.return_code:
|
if out.return_code:
|
||||||
fail("failed %s: %s" % (args, out.stderr))
|
fail("failed %s: %s" % (args, out.stderr))
|
||||||
ctx.file("BUILD", "filegroup(name='tarball', srcs=['%s'])" % base, False)
|
ctx.file("BUILD", "package(default_visibility=['//visibility:public'])\nfilegroup(name='tarball', srcs=['%s'])" % base, False)
|
||||||
|
|
||||||
npm_binary = repository_rule(
|
npm_binary = repository_rule(
|
||||||
implementation=_npm_binary_impl,
|
implementation=_npm_binary_impl,
|
||||||
@ -55,12 +56,13 @@ npm_binary = repository_rule(
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
def _run_npm_binary_str(ctx, tarball, name):
|
# for use in repo rules.
|
||||||
|
def _run_npm_binary_str(ctx, tarball, args):
|
||||||
python_bin = ctx.which("python")
|
python_bin = ctx.which("python")
|
||||||
return " ".join([
|
return " ".join([
|
||||||
python_bin,
|
python_bin,
|
||||||
ctx.path(ctx.attr._run_npm),
|
ctx.path(ctx.attr._run_npm),
|
||||||
ctx.path(tarball)])
|
ctx.path(tarball)] + args)
|
||||||
|
|
||||||
|
|
||||||
def _bower_archive(ctx):
|
def _bower_archive(ctx):
|
||||||
@ -72,7 +74,7 @@ def _bower_archive(ctx):
|
|||||||
cmd = [
|
cmd = [
|
||||||
ctx.which("python"),
|
ctx.which("python"),
|
||||||
ctx.path(ctx.attr._download_bower),
|
ctx.path(ctx.attr._download_bower),
|
||||||
'-b', '%s' % _run_npm_binary_str(ctx, ctx.attr._bower_archive, "bower"),
|
'-b', '%s' % _run_npm_binary_str(ctx, ctx.attr._bower_archive, []),
|
||||||
'-n', ctx.name,
|
'-n', ctx.name,
|
||||||
'-p', ctx.attr.package,
|
'-p', ctx.attr.package,
|
||||||
'-v', ctx.attr.version,
|
'-v', ctx.attr.version,
|
||||||
@ -235,6 +237,10 @@ def _bower_component_bundle_impl(ctx):
|
|||||||
for d in ctx.attr.deps:
|
for d in ctx.attr.deps:
|
||||||
versions += d.transitive_versions
|
versions += d.transitive_versions
|
||||||
|
|
||||||
|
licenses = set([])
|
||||||
|
for d in ctx.attr.deps:
|
||||||
|
licenses += d.transitive_versions
|
||||||
|
|
||||||
out_zip = ctx.outputs.zip
|
out_zip = ctx.outputs.zip
|
||||||
out_versions = ctx.outputs.version_json
|
out_versions = ctx.outputs.version_json
|
||||||
|
|
||||||
@ -259,6 +265,11 @@ def _bower_component_bundle_impl(ctx):
|
|||||||
mnemonic="BowerVersions",
|
mnemonic="BowerVersions",
|
||||||
command="(echo '{' ; for j in %s ; do cat $j; echo ',' ; done ; echo \\\"\\\":\\\"\\\"; echo '}') > %s" % (" ".join([v.path for v in versions]), out_versions.path))
|
command="(echo '{' ; for j in %s ; do cat $j; echo ',' ; done ; echo \\\"\\\":\\\"\\\"; echo '}') > %s" % (" ".join([v.path for v in versions]), out_versions.path))
|
||||||
|
|
||||||
|
return struct(
|
||||||
|
transitive_zipfiles=zips,
|
||||||
|
transitive_versions=versions,
|
||||||
|
transitive_licenses=licenses)
|
||||||
|
|
||||||
|
|
||||||
bower_component_bundle = rule(
|
bower_component_bundle = rule(
|
||||||
_bower_component_bundle_impl,
|
_bower_component_bundle_impl,
|
||||||
@ -268,3 +279,88 @@ bower_component_bundle = rule(
|
|||||||
"version_json": "%{name}-versions.json",
|
"version_json": "%{name}-versions.json",
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def _vulcanize_impl(ctx):
|
||||||
|
destdir = ctx.outputs.vulcanized.path + ".dir"
|
||||||
|
zips = [z for d in ctx.attr.deps for z in d.transitive_zipfiles ]
|
||||||
|
|
||||||
|
hermetic_npm_binary = " ".join([
|
||||||
|
'python',
|
||||||
|
"$p/" + ctx.file._run_npm.path,
|
||||||
|
"$p/" + ctx.file._vulcanize_archive.path,
|
||||||
|
'--inline-scripts',
|
||||||
|
'--inline-css',
|
||||||
|
'--strip-comments',
|
||||||
|
'--out-html', "$p/" + ctx.outputs.vulcanized.path,
|
||||||
|
ctx.file.app.path
|
||||||
|
])
|
||||||
|
|
||||||
|
pkg_dir = ctx.attr.pkg.lstrip("/")
|
||||||
|
cmd = " && ".join([
|
||||||
|
# unpack dependencies.
|
||||||
|
"export PATH",
|
||||||
|
"p=$PWD",
|
||||||
|
"rm -rf %s" % destdir,
|
||||||
|
"mkdir -p %s/%s/bower_components" % (destdir, pkg_dir),
|
||||||
|
"for z in %s; do unzip -qd %s/%s/bower_components/ $z; done" % (
|
||||||
|
' '.join([z.path for z in zips]), destdir, pkg_dir),
|
||||||
|
"tar -cf - %s | tar -C %s -xf -" % (" ".join([s.path for s in ctx.files.srcs]), destdir),
|
||||||
|
"cd %s" % destdir,
|
||||||
|
hermetic_npm_binary,
|
||||||
|
])
|
||||||
|
ctx.action(
|
||||||
|
mnemonic = "Vulcanize",
|
||||||
|
inputs = [ctx.file._run_npm, ctx.file.app,
|
||||||
|
ctx.file._vulcanize_archive
|
||||||
|
] + list(zips) + ctx.files.srcs,
|
||||||
|
outputs = [ctx.outputs.vulcanized],
|
||||||
|
command = cmd)
|
||||||
|
|
||||||
|
hermetic_npm_command = "export PATH && " + " ".join([
|
||||||
|
'python',
|
||||||
|
ctx.file._run_npm.path,
|
||||||
|
ctx.file._crisper_archive.path,
|
||||||
|
"--always-write-script",
|
||||||
|
"--source", ctx.outputs.vulcanized.path,
|
||||||
|
"--html", ctx.outputs.html.path,
|
||||||
|
"--js", ctx.outputs.js.path])
|
||||||
|
|
||||||
|
ctx.action(
|
||||||
|
mnemonic = "Crisper",
|
||||||
|
inputs = [ctx.file._run_npm, ctx.file.app,
|
||||||
|
ctx.file._crisper_archive, ctx.outputs.vulcanized],
|
||||||
|
outputs = [ctx.outputs.js, ctx.outputs.html],
|
||||||
|
command = hermetic_npm_command)
|
||||||
|
|
||||||
|
|
||||||
|
_vulcanize_rule = rule(
|
||||||
|
_vulcanize_impl,
|
||||||
|
attrs = {
|
||||||
|
"deps": attr.label_list(providers=["transitive_zipfiles"]),
|
||||||
|
"app": attr.label(mandatory=True, allow_single_file=True),
|
||||||
|
"srcs": attr.label_list(allow_files=[".js", ".html", ".txt", ".css", ".ico"]),
|
||||||
|
|
||||||
|
"pkg": attr.string(mandatory=True),
|
||||||
|
"_run_npm": attr.label(
|
||||||
|
default=Label("//tools/js:run_npm_binary.py"),
|
||||||
|
allow_single_file=True
|
||||||
|
),
|
||||||
|
"_vulcanize_archive": attr.label(
|
||||||
|
default=Label("@vulcanize//:%s" % _npm_tarball("vulcanize")),
|
||||||
|
allow_single_file=True
|
||||||
|
),
|
||||||
|
"_crisper_archive": attr.label(
|
||||||
|
default=Label("@crisper//:%s" % _npm_tarball("crisper")),
|
||||||
|
allow_single_file=True
|
||||||
|
),
|
||||||
|
},
|
||||||
|
outputs = {
|
||||||
|
"vulcanized": "%{name}.vulcanized.html",
|
||||||
|
"html": "%{name}.crisped.html",
|
||||||
|
"js": "%{name}.crisped.js",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
def vulcanize(*args, **kwargs):
|
||||||
|
"""Vulcanize runs vulcanize and crisper on a set of sources."""
|
||||||
|
_vulcanize_rule(*args, pkg=PACKAGE_NAME, **kwargs)
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
exports_files(["run_npm_binary.py"])
|
Loading…
Reference in New Issue
Block a user