diff --git a/README.md b/README.md index 996fe97741..a9b2fba479 100644 --- a/README.md +++ b/README.md @@ -320,19 +320,8 @@ For example, the `protractor` package has two bin entries in its `package.json`: These will result in two generated `nodejs_binary` targets in the `@npm//protractor/bin` package (if your npm deps workspace is `@npm`): -```python -nodejs_binary( - name = "protractor", - entry_point = "protractor/bin/protractor", - data = ["//protractor"], -) - -nodejs_binary( - name = "webdriver-manager", - entry_point = "protractor/bin/webdriver-manager", - data = ["//protractor"], -) -``` +* `@npm//protractor/bin:protractor` +* `@npm//protractor/bin:webdriver-manager` These targets can be used as executables for actions in custom rules or can be run by Bazel directly. For example, you can run protractor with the @@ -452,7 +441,7 @@ load("@build_bazel_rules_nodejs//:defs.bzl", "nodejs_binary") nodejs_binary( name = "rollup", - entry_point = "rollup/bin/rollup", + entry_point = "//:node_modules/rollup/bin/rollup", ) ``` @@ -480,7 +469,7 @@ nodejs_binary( "@//:node_modules", "main.js", ], - entry_point = "workspace_name/main.js", + entry_point = ":main.js", args = ["--node_options=--expose-gc"], ) ``` diff --git a/e2e/ts_library/googmodule/BUILD.bazel b/e2e/ts_library/googmodule/BUILD.bazel index cc9dd44f2d..3e7d409194 100644 --- a/e2e/ts_library/googmodule/BUILD.bazel +++ b/e2e/ts_library/googmodule/BUILD.bazel @@ -13,7 +13,7 @@ nodejs_binary( "@npm//@bazel/typescript", "@npm//tsickle", ], - entry_point = "@bazel/typescript/internal/tsc_wrapped/tsc_wrapped.js", + entry_point = "@npm//node_modules/@bazel/typescript:internal/tsc_wrapped/tsc_wrapped.js", install_source_map_support = False, ) diff --git a/e2e/ts_library/some_module/BUILD.bazel b/e2e/ts_library/some_module/BUILD.bazel index d3266aaab5..ba8e7c3120 100644 --- a/e2e/ts_library/some_module/BUILD.bazel +++ b/e2e/ts_library/some_module/BUILD.bazel @@ -25,7 +25,7 @@ nodejs_binary( ":main", ":some_module", ], - entry_point = "e2e_ts_library/some_module/main.js", + entry_point = ":main.ts", ) sh_test( diff --git a/e2e/typescript_3.1/BUILD.bazel b/e2e/typescript_3.1/BUILD.bazel index 0e1d3a76d0..68dc4174be 100644 --- a/e2e/typescript_3.1/BUILD.bazel +++ b/e2e/typescript_3.1/BUILD.bazel @@ -12,7 +12,7 @@ # See the License for the specific language governing permissions and # limitations under the License. -load("@build_bazel_rules_nodejs//:defs.bzl", "nodejs_binary", "rollup_bundle") +load("@build_bazel_rules_nodejs//:defs.bzl", "rollup_bundle") load("@npm_bazel_jasmine//:index.bzl", "jasmine_node_test") load("@npm_bazel_typescript//:index.bzl", "ts_library") @@ -57,26 +57,9 @@ jasmine_node_test( ], ) -nodejs_binary( - name = "main_js", - data = [ - ":main", - ], - entry_point = "e2e_typescript_3_1/main.js", -) - -nodejs_binary( - name = "main_js_sm", - data = [ - ":main", - "@npm//source-map-support", - ], - entry_point = "e2e_typescript_3_1/main.js", -) - rollup_bundle( name = "bundle", - entry_point = "main", + entry_point = ":main.ts", deps = [ ":main", ], @@ -84,7 +67,7 @@ rollup_bundle( rollup_bundle( name = "bundle_sm", - entry_point = "main", + entry_point = ":main.ts", deps = [ ":main", "@npm//source-map-support", diff --git a/examples/app/BUILD.bazel b/examples/app/BUILD.bazel index 9c7880d4f7..95501893d0 100644 --- a/examples/app/BUILD.bazel +++ b/examples/app/BUILD.bazel @@ -19,7 +19,7 @@ ts_devserver( rollup_bundle( name = "bundle", - entry_point = "examples_app/app", + entry_point = ":app.ts", deps = [":app"], ) diff --git a/examples/parcel/BUILD.bazel b/examples/parcel/BUILD.bazel index 18112820f1..b60327f406 100644 --- a/examples/parcel/BUILD.bazel +++ b/examples/parcel/BUILD.bazel @@ -5,9 +5,8 @@ parcel( name = "bundle", srcs = [ "bar.js", - "foo.js", ], - entry_point = "foo.js", + entry_point = ":foo.js", ) jasmine_node_test( diff --git a/examples/parcel/parcel.bzl b/examples/parcel/parcel.bzl index 899da32e96..d1eb224cd6 100644 --- a/examples/parcel/parcel.bzl +++ b/examples/parcel/parcel.bzl @@ -27,12 +27,12 @@ def _parcel_impl(ctx): """ # Options documented at https://parceljs.org/cli.html - args = ["build", ctx.attr.entry_point] + args = ["build", ctx.file.entry_point.short_path] args += ["--out-dir", ctx.outputs.bundle.dirname] args += ["--out-file", ctx.outputs.bundle.basename] ctx.actions.run( - inputs = ctx.files.srcs, + inputs = ctx.files.srcs + [ctx.file.entry_point], executable = ctx.executable.parcel, outputs = [ctx.outputs.bundle, ctx.outputs.sourcemap], arguments = args, @@ -44,7 +44,10 @@ parcel = rule( implementation = _parcel_impl, attrs = { "srcs": attr.label_list(allow_files = True), - "entry_point": attr.string(mandatory = True), + "entry_point": attr.label( + allow_single_file = True, + mandatory = True, + ), "parcel": attr.label( # This default assumes that users name their install "npm" default = Label("@npm//parcel-bundler/bin:parcel"), diff --git a/examples/program/BUILD.bazel b/examples/program/BUILD.bazel index e1ad440dbf..33e786d1e5 100644 --- a/examples/program/BUILD.bazel +++ b/examples/program/BUILD.bazel @@ -38,7 +38,7 @@ nodejs_binary( "index.js", ":node_modules", ], - entry_point = "examples_program/index.js", + entry_point = ":index.js", ) jasmine_node_test( diff --git a/examples/protocol_buffers/BUILD.bazel b/examples/protocol_buffers/BUILD.bazel index 1d06f97204..34c370b050 100644 --- a/examples/protocol_buffers/BUILD.bazel +++ b/examples/protocol_buffers/BUILD.bazel @@ -70,7 +70,7 @@ ts_devserver( # Test for production mode rollup_bundle( name = "bundle", - entry_point = "examples_protocol_buffers/app", + entry_point = ":app.ts", # TODO(alexeagle): we should be able to get this from //:protobufjs_bootstrap_scripts # and automatically plumb it through to Rollup. globals = { diff --git a/examples/webapp/BUILD.bazel b/examples/webapp/BUILD.bazel index 85df3e5171..24d6919d0b 100644 --- a/examples/webapp/BUILD.bazel +++ b/examples/webapp/BUILD.bazel @@ -6,7 +6,7 @@ load("@build_bazel_rules_nodejs//internal/web_package:web_package.bzl", "web_pac rollup_bundle( name = "bundle", srcs = glob(["*.js"]), - entry_point = "index.js", + entry_point = ":index.js", ) web_package( diff --git a/internal/common/collect_es6_sources.bzl b/internal/common/collect_es6_sources.bzl index ec9cf6acb5..83f6d25d0f 100644 --- a/internal/common/collect_es6_sources.bzl +++ b/internal/common/collect_es6_sources.bzl @@ -31,6 +31,11 @@ def collect_es6_sources(ctx): non_rerooted_files = [d for d in ctx.files.deps if d.is_source] if hasattr(ctx.attr, "srcs"): non_rerooted_files += ctx.files.srcs + + # Some rules such as rollup_bundle specify an entry_point which should + # be collected if the file is a js file. + if hasattr(ctx.attr, "entry_point"): + non_rerooted_files += [s for s in ctx.files.entry_point if s.extension == "js"] for dep in ctx.attr.deps: if hasattr(dep, "typescript"): non_rerooted_files += dep.typescript.transitive_es6_sources.to_list() diff --git a/internal/e2e/fine_grained_no_bin/BUILD.bazel b/internal/e2e/fine_grained_no_bin/BUILD.bazel index 38e5ac028c..03a064fc46 100644 --- a/internal/e2e/fine_grained_no_bin/BUILD.bazel +++ b/internal/e2e/fine_grained_no_bin/BUILD.bazel @@ -12,5 +12,5 @@ nodejs_binary( "test/test.js", "@fine_grained_no_bin//fs.realpath", ], - entry_point = "build_bazel_rules_nodejs/internal/e2e/fine_grained_no_bin/index.js", + entry_point = ":index.js", ) diff --git a/internal/e2e/rollup/BUILD.bazel b/internal/e2e/rollup/BUILD.bazel index 99041bf140..fde910683e 100644 --- a/internal/e2e/rollup/BUILD.bazel +++ b/internal/e2e/rollup/BUILD.bazel @@ -3,11 +3,8 @@ load("//:defs.bzl", "rollup_bundle") rollup_bundle( name = "bundle", - srcs = [ - "bar.js", - "foo.js", - ], - entry_point = "internal/e2e/rollup/foo.js", + srcs = ["bar.js"], + entry_point = ":foo.js", globals = {"some_global_var": "runtime_name_of_global_var"}, license_banner = ":license.txt", deps = [ diff --git a/internal/e2e/rollup_code_splitting/BUILD.bazel b/internal/e2e/rollup_code_splitting/BUILD.bazel index 84b9d9be62..46a0a68fe3 100644 --- a/internal/e2e/rollup_code_splitting/BUILD.bazel +++ b/internal/e2e/rollup_code_splitting/BUILD.bazel @@ -6,8 +6,8 @@ rollup_bundle( ["*.js"], exclude = ["*.spec.js"], ), - additional_entry_points = ["internal/e2e/rollup_code_splitting/additional_entry.js"], - entry_point = "internal/e2e/rollup_code_splitting/main1.js", + additional_entry_points = ["build_bazel_rules_nodejs/internal/e2e/rollup_code_splitting/additional_entry.js"], + entry_point = ":main1.js", license_banner = ":license.txt", ) @@ -18,10 +18,11 @@ jasmine_node_test( "main1.spec.js", ], data = glob([ - "*_golden.js_", + "goldens/*", ]) + [ ":bundle", ":bundle.min.js", + ":bundle.min.es2015.js", ], deps = [ "//internal/e2e:check_lib", diff --git a/internal/e2e/rollup_code_splitting/additional_entry.spec.js b/internal/e2e/rollup_code_splitting/additional_entry.spec.js index 602b653445..c1598de5be 100644 --- a/internal/e2e/rollup_code_splitting/additional_entry.spec.js +++ b/internal/e2e/rollup_code_splitting/additional_entry.spec.js @@ -5,7 +5,8 @@ const path = __dirname; describe('bundling additional entry point', () => { it('should work', () => { - check(path, 'bundle.min.js', 'bundle-min_golden.js_'); + check(path, 'bundle.min.js', 'goldens/bundle.min.js_'); + check(path, 'bundle.min.es2015.js', 'goldens/bundle.min.es2015.js_'); }); // Disabled because native ESModules can't be loaded in current nodejs diff --git a/internal/e2e/rollup_code_splitting/goldens/bundle.min.es2015.js_ b/internal/e2e/rollup_code_splitting/goldens/bundle.min.es2015.js_ new file mode 100755 index 0000000000..8fafe68af6 --- /dev/null +++ b/internal/e2e/rollup_code_splitting/goldens/bundle.min.es2015.js_ @@ -0,0 +1 @@ +import('./bundle_chunks_min_es2015/main1.js'); \ No newline at end of file diff --git a/internal/e2e/rollup_code_splitting/bundle-min_golden.js_ b/internal/e2e/rollup_code_splitting/goldens/bundle.min.js_ similarity index 61% rename from internal/e2e/rollup_code_splitting/bundle-min_golden.js_ rename to internal/e2e/rollup_code_splitting/goldens/bundle.min.js_ index f29b46c8c0..925ad39265 100755 --- a/internal/e2e/rollup_code_splitting/bundle-min_golden.js_ +++ b/internal/e2e/rollup_code_splitting/goldens/bundle.min.js_ @@ -3,7 +3,7 @@ (function(global) { System.config({ packages: { - '': {map: {"./main1.js": "bundle_chunks_min/main1.js", "./additional_entry.js": "bundle_chunks_min/additional_entry.js"}, defaultExtension: 'js'}, + '': {map: {"./main1": "bundle_chunks_min/main1", "./additional_entry.js": "bundle_chunks_min/additional_entry.js"}, defaultExtension: 'js'}, } }); System.import('main1.js').catch(function(err) { diff --git a/internal/e2e/rollup_fine_grained_deps/BUILD.bazel b/internal/e2e/rollup_fine_grained_deps/BUILD.bazel index 4e4feccb2f..c98a9ef0f7 100644 --- a/internal/e2e/rollup_fine_grained_deps/BUILD.bazel +++ b/internal/e2e/rollup_fine_grained_deps/BUILD.bazel @@ -4,16 +4,14 @@ load("//:defs.bzl", "jasmine_node_test", "nodejs_binary", "rollup_bundle") # and no fine grained deps rollup_bundle( name = "bundle_no_deps", - srcs = ["no-deps.js"], - entry_point = "internal/e2e/rollup_fine_grained_deps/no-deps.js", + entry_point = ":no-deps.js", ) # You can have a rollup_bundle with no node_modules attribute # and fine grained deps rollup_bundle( name = "bundle", - srcs = ["has-deps.js"], - entry_point = "internal/e2e/rollup_fine_grained_deps/has-deps.js", + entry_point = ":has-deps.js", deps = [ "@fine_grained_deps_yarn//@gregmagolan/test-a", "@fine_grained_deps_yarn//@gregmagolan/test-b", @@ -24,8 +22,7 @@ rollup_bundle( # and no fine grained deps rollup_bundle( name = "bundle_legacy", - srcs = ["has-deps.js"], - entry_point = "internal/e2e/rollup_fine_grained_deps/has-deps.js", + entry_point = ":has-deps.js", node_modules = "@fine_grained_deps_yarn//:node_modules", ) @@ -33,8 +30,7 @@ rollup_bundle( # and fine grained deps so long as they come from the same root rollup_bundle( name = "bundle_hybrid", - srcs = ["has-deps.js"], - entry_point = "internal/e2e/rollup_fine_grained_deps/has-deps.js", + entry_point = ":has-deps.js", node_modules = "@fine_grained_deps_yarn//:node_modules", deps = [ "@fine_grained_deps_yarn//@gregmagolan/test-a", @@ -93,6 +89,6 @@ nodejs_binary( "@npm//jasmine", "@npm//unidiff", ], - entry_point = "build_bazel_rules_nodejs/internal/e2e/rollup_fine_grained_deps/update_golden.js", + entry_point = ":update_golden.js", install_source_map_support = False, ) diff --git a/internal/history-server/history_server.bzl b/internal/history-server/history_server.bzl index 944cf1eb03..9bf74723c3 100644 --- a/internal/history-server/history_server.bzl +++ b/internal/history-server/history_server.bzl @@ -26,7 +26,7 @@ def history_server(templated_args = [], **kwargs): nodejs_binary_macro( node_modules = "@history-server_runtime_deps//:node_modules", - entry_point = "history-server/modules/cli.js", + entry_point = "@history-server_runtime_deps//node_modules/history-server:modules/cli.js", install_source_map_support = False, templated_args = templated_args, **kwargs diff --git a/internal/http-server/http_server.bzl b/internal/http-server/http_server.bzl index 79aa1f93c9..42eb4f76f9 100644 --- a/internal/http-server/http_server.bzl +++ b/internal/http-server/http_server.bzl @@ -29,7 +29,7 @@ def http_server(templated_args = [], **kwargs): nodejs_binary_macro( node_modules = "@http-server_runtime_deps//:node_modules", - entry_point = "http-server/bin/http-server", + entry_point = "@http-server_runtime_deps//node_modules/http-server:bin/http-server", install_source_map_support = False, templated_args = templated_args, **kwargs diff --git a/internal/jasmine_node_test/jasmine_node_test.bzl b/internal/jasmine_node_test/jasmine_node_test.bzl index 32fe86faa2..437ee11396 100644 --- a/internal/jasmine_node_test/jasmine_node_test.bzl +++ b/internal/jasmine_node_test/jasmine_node_test.bzl @@ -57,9 +57,8 @@ def jasmine_node_test( ) all_data = data + srcs + deps - all_data += [Label("//internal/jasmine_node_test:jasmine_runner.js")] all_data += [":%s_devmode_srcs.MF" % name] - entry_point = "build_bazel_rules_nodejs/internal/jasmine_node_test/jasmine_runner.js" + entry_point = Label("//internal/jasmine_node_test:jasmine_runner.js") # If the target specified templated_args, pass it through. templated_args = kwargs.pop("templated_args", []) + ["$(location :%s_devmode_srcs.MF)" % name] diff --git a/internal/jasmine_node_test/test/BUILD.bazel b/internal/jasmine_node_test/test/BUILD.bazel index 15374b51d5..78c184ebfa 100644 --- a/internal/jasmine_node_test/test/BUILD.bazel +++ b/internal/jasmine_node_test/test/BUILD.bazel @@ -30,5 +30,5 @@ nodejs_test( "no_jasmine_test.js", "//internal/jasmine_node_test:jasmine_runner.js", ], - entry_point = "build_bazel_rules_nodejs/internal/jasmine_node_test/test/no_jasmine_test.js", + entry_point = ":no_jasmine_test.js", ) diff --git a/internal/node/node.bzl b/internal/node/node.bzl index 548e5e16be..cc597ece45 100644 --- a/internal/node/node.bzl +++ b/internal/node/node.bzl @@ -21,7 +21,7 @@ a `module_name` attribute can be `require`d by that name. """ load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources", "collect_node_modules_aspect") -load("//internal/common:expand_into_runfiles.bzl", "expand_location_into_runfiles") +load("//internal/common:expand_into_runfiles.bzl", "expand_location_into_runfiles", "expand_path_into_runfiles") load("//internal/common:module_mappings.bzl", "module_mappings_runtime_aspect") load("//internal/common:sources_aspect.bzl", "sources_aspect") @@ -86,6 +86,16 @@ def _write_loader_script(ctx): node_modules_root = _compute_node_modules_root(ctx) + if len(ctx.attr.entry_point.files) != 1: + fail("labels in entry_point must contain exactly one file") + + entry_point_path = expand_path_into_runfiles(ctx, ctx.file.entry_point.short_path) + + # If the entry point specified is a typescript file then set the entry + # point to the corresponding .js file + if entry_point_path.endswith(".ts"): + entry_point_path = entry_point_path[:-3] + ".js" + ctx.actions.expand_template( template = ctx.file._loader_template, output = ctx.outputs.loader, @@ -94,7 +104,7 @@ def _write_loader_script(ctx): "TEMPLATED_bootstrap": "\n " + ",\n ".join( ["\"" + d + "\"" for d in ctx.attr.bootstrap], ), - "TEMPLATED_entry_point": ctx.attr.entry_point, + "TEMPLATED_entry_point": entry_point_path, "TEMPLATED_gen_dir": ctx.genfiles_dir.path, "TEMPLATED_install_source_map_support": str(ctx.attr.install_source_map_support).lower(), "TEMPLATED_module_roots": "\n " + ",\n ".join(module_mappings), @@ -171,6 +181,10 @@ def _nodejs_binary_impl(ctx): runfiles = depset([node, ctx.outputs.loader, ctx.file._repository_args], transitive = [sources, node_modules]) + # entry point is only needed in runfiles if it is a .js file + if ctx.file.entry_point.extension == "js": + runfiles = depset([ctx.file.entry_point], transitive = [runfiles]) + return [DefaultInfo( executable = ctx.outputs.script, runfiles = ctx.runfiles( @@ -209,12 +223,65 @@ _NODEJS_EXECUTABLE_ATTRS = { allow_files = True, aspects = [sources_aspect, module_mappings_runtime_aspect, collect_node_modules_aspect], ), - "entry_point": attr.string( + "entry_point": attr.label( doc = """The script which should be executed first, usually containing a main function. - This attribute expects a string starting with the workspace name, so that it's not ambiguous - in cases where a script with the same name appears in another directory or external workspace. + + If the entry JavaScript file belongs to the same package (as the BUILD file), + you can simply reference it by its relative name to the package directory: + + ``` + nodejs_binary( + name = "my_binary", + ... + entry_point = ":file.js", + ) + ``` + + You can specify the entry point as a typescript file so long as you also include + the ts_library target in data: + + ``` + ts_library( + name = "main", + srcs = ["main.ts"], + ) + + nodejs_binary( + name = "bin", + data = [":main"] + entry_point = ":main.ts", + ) + ``` + + The rule will use the corresponding `.js` output of the ts_library rule as the entry point. + + If the entry point target is a rule, it should produce a single JavaScript entry file that will be passed to the nodejs_binary rule. + For example: + + ``` + filegroup( + name = "entry_file", + srcs = ["main.js"], + ) + + nodejs_binary( + name = "my_binary", + entry_point = ":entry_file", + ) + ``` + + The entry_point can also be a label in another workspace: + + ``` + nodejs_binary( + name = "history-server", + entry_point = "@npm//node_modules/history-server:modules/cli.js", + data = ["@npm//history-server"], + ) + ``` """, mandatory = True, + allow_single_file = True, ), "install_source_map_support": attr.bool( doc = """Install the source-map-support package. diff --git a/internal/node/node_loader.js b/internal/node/node_loader.js index 65a47cebc1..023350aeb3 100644 --- a/internal/node/node_loader.js +++ b/internal/node/node_loader.js @@ -49,16 +49,26 @@ var BOOTSTRAP = [TEMPLATED_bootstrap]; const USER_WORKSPACE_NAME = 'TEMPLATED_user_workspace_name'; const NODE_MODULES_ROOT = 'TEMPLATED_node_modules_root'; const BIN_DIR = 'TEMPLATED_bin_dir'; +const ENTRY_POINT = 'TEMPLATED_entry_point'; const GEN_DIR = 'TEMPLATED_gen_dir'; +const INSTALL_SOURCE_MAP_SUPPORT = TEMPLATED_install_source_map_support; +const TARGET = 'TEMPLATED_target'; if (DEBUG) console.error(` -node_loader: running TEMPLATED_target with - MODULE_ROOTS: ${JSON.stringify(MODULE_ROOTS, undefined, 2)} - BOOTSTRAP: ${JSON.stringify(BOOTSTRAP, undefined, 2)} - NODE_MODULES_ROOT: ${NODE_MODULES_ROOT} +node_loader: running ${TARGET} with + cwd: ${process.cwd()} + runfiles: ${process.env.RUNFILES} + BIN_DIR: ${BIN_DIR} + BOOTSTRAP: ${JSON.stringify(BOOTSTRAP, undefined, 2)} + ENTRY_POINT: ${ENTRY_POINT} GEN_DIR: ${GEN_DIR} + INSTALL_SOURCE_MAP_SUPPORT: ${INSTALL_SOURCE_MAP_SUPPORT} + MODULE_ROOTS: ${JSON.stringify(MODULE_ROOTS, undefined, 2)} + NODE_MODULES_ROOT: ${NODE_MODULES_ROOT} + TARGET: ${TARGET} + USER_WORKSPACE_NAME: ${USER_WORKSPACE_NAME} `); function resolveToModuleRoot(path) { @@ -448,7 +458,7 @@ module.constructor._resolveFilename = function(request, parent, isMain, options) } const error = new Error( - `TEMPLATED_target cannot find module '${request}' required by '${parentFilename}'\n looked in:\n` + + `${TARGET} cannot find module '${request}' required by '${parentFilename}'\n looked in:\n` + failedResolutions.map(r => ` ${r}`).join('\n') + '\n'); error.code = 'MODULE_NOT_FOUND'; throw error; @@ -456,7 +466,7 @@ module.constructor._resolveFilename = function(request, parent, isMain, options) // Before loading anything that might print a stack, install the // source-map-support. -if (TEMPLATED_install_source_map_support) { +if (INSTALL_SOURCE_MAP_SUPPORT) { try { const sourcemap_support_package = path.resolve(process.cwd(), '../build_bazel_rules_nodejs/third_party/github.com/source-map-support'); @@ -465,7 +475,7 @@ if (TEMPLATED_install_source_map_support) { if (DEBUG) { console.error(`WARNING: source-map-support module not installed. Stack traces from languages like TypeScript will point to generated .js files. - Set install_source_map_support = False in TEMPLATED_target to turn off this warning. + Set install_source_map_support = False in ${TARGET} to turn off this warning. `); } } @@ -484,7 +494,7 @@ if (require.main === module) { // Set the actual entry point in the arguments list. // argv[0] == node, argv[1] == entry point. // NB: entry_point below is replaced during the build process. - var mainScript = process.argv[1] = 'TEMPLATED_entry_point'; + var mainScript = process.argv[1] = ENTRY_POINT; try { module.constructor._load(mainScript, this, /*isMain=*/true); } catch (e) { @@ -496,7 +506,7 @@ if (require.main === module) { // (which is an empty filegroup). // See https://github.com/bazelbuild/rules_nodejs/wiki#migrating-to-rules_nodejs-013 console.error( - `\nWARNING: Due to a breaking change in rules_nodejs 0.13.0, target TEMPLATED_target\n` + + `\nWARNING: Due to a breaking change in rules_nodejs 0.13.0, target ${TARGET}\n` + `must now declare either an explicit node_modules attribute, or\n` + `list explicit deps[] or data[] fine grained dependencies on npm labels\n` + `if it has any node_modules dependencies.\n` + diff --git a/internal/node/test/BUILD.bazel b/internal/node/test/BUILD.bazel index d926216f6f..4b524b8260 100644 --- a/internal/node/test/BUILD.bazel +++ b/internal/node/test/BUILD.bazel @@ -5,7 +5,7 @@ load("//:defs.bzl", "nodejs_binary") nodejs_binary( name = "no_deps", data = ["no-deps.js"], - entry_point = "build_bazel_rules_nodejs/internal/node/test/no-deps", + entry_point = ":no-deps.js", ) # You can have a nodejs_binary with a node_modules attribute @@ -13,7 +13,7 @@ nodejs_binary( nodejs_binary( name = "has_deps_legacy", data = ["has-deps.js"], - entry_point = "build_bazel_rules_nodejs/internal/node/test/has-deps", + entry_point = ":has-deps.js", node_modules = "@fine_grained_deps_yarn//:node_modules", ) @@ -25,7 +25,7 @@ nodejs_binary( "has-deps.js", "@fine_grained_deps_yarn//typescript", ], - entry_point = "build_bazel_rules_nodejs/internal/node/test/has-deps", + entry_point = ":has-deps.js", ) # You can have a nodejs_binary with both a node_modules attribute @@ -36,6 +36,16 @@ nodejs_binary( "has-deps.js", "@fine_grained_deps_yarn//typescript", ], - entry_point = "build_bazel_rules_nodejs/internal/node/test/has-deps", + entry_point = ":has-deps.js", node_modules = "@fine_grained_deps_yarn//:node_modules", ) + +filegroup( + name = "entry_file", + srcs = ["no-deps.js"], +) + +nodejs_binary( + name = "has_entry_file", + entry_point = ":entry_file", +) diff --git a/internal/npm_install/BUILD.bazel b/internal/npm_install/BUILD.bazel index 2cccbf6c8a..7f45172fad 100644 --- a/internal/npm_install/BUILD.bazel +++ b/internal/npm_install/BUILD.bazel @@ -33,7 +33,7 @@ nodejs_binary( ":browserify-wrapped.js", "//third_party/github.com/browserify/browserify:sources", ], - entry_point = "build_bazel_rules_nodejs/internal/npm_install/browserify-wrapped.js", + entry_point = ":browserify-wrapped.js", install_source_map_support = False, visibility = ["//visibility:public"], ) diff --git a/internal/npm_install/generate_build_file.js b/internal/npm_install/generate_build_file.js index cdf0a624ac..92b3ea6933 100644 --- a/internal/npm_install/generate_build_file.js +++ b/internal/npm_install/generate_build_file.js @@ -887,7 +887,7 @@ npm_umd_bundle( result += `# Wire up the \`bin\` entry \`${name}\` nodejs_binary( name = "${name}__bin", - entry_point = "${pkg._dir}/${path}", + entry_point = ":${path}", install_source_map_support = False, data = [":${pkg._name}__pkg"],${additionalAttributes} ) diff --git a/internal/npm_install/test/BUILD.bazel b/internal/npm_install/test/BUILD.bazel index ec4524bd56..e63a5bf8d6 100644 --- a/internal/npm_install/test/BUILD.bazel +++ b/internal/npm_install/test/BUILD.bazel @@ -34,6 +34,6 @@ nodejs_binary( "@npm//jasmine", "@npm//unidiff", ], - entry_point = "build_bazel_rules_nodejs/internal/npm_install/test/update_golden.js", + entry_point = ":update_golden.js", install_source_map_support = False, ) diff --git a/internal/npm_install/test/golden/node_modules/@gregmagolan/test-a/BUILD.bazel.golden b/internal/npm_install/test/golden/node_modules/@gregmagolan/test-a/BUILD.bazel.golden index 936aaf4ea2..1182e5d6fd 100644 --- a/internal/npm_install/test/golden/node_modules/@gregmagolan/test-a/BUILD.bazel.golden +++ b/internal/npm_install/test/golden/node_modules/@gregmagolan/test-a/BUILD.bazel.golden @@ -33,7 +33,7 @@ npm_umd_bundle( ) nodejs_binary( name = "test__bin", - entry_point = "@gregmagolan/test-a/@bin/test.js", + entry_point = ":@bin/test.js", install_source_map_support = False, data = [":test-a__pkg"], ) diff --git a/internal/npm_install/test/golden/node_modules/jasmine/BUILD.bazel.golden b/internal/npm_install/test/golden/node_modules/jasmine/BUILD.bazel.golden index d41a7602b0..b7349bf8d8 100644 --- a/internal/npm_install/test/golden/node_modules/jasmine/BUILD.bazel.golden +++ b/internal/npm_install/test/golden/node_modules/jasmine/BUILD.bazel.golden @@ -56,7 +56,7 @@ npm_umd_bundle( ) nodejs_binary( name = "jasmine__bin", - entry_point = "jasmine/bin/jasmine.js", + entry_point = ":bin/jasmine.js", install_source_map_support = False, data = [":jasmine__pkg"], ) diff --git a/internal/npm_package/BUILD.bazel b/internal/npm_package/BUILD.bazel index 7318073caa..875c18c560 100644 --- a/internal/npm_package/BUILD.bazel +++ b/internal/npm_package/BUILD.bazel @@ -1,6 +1,8 @@ load("@bazel_skylib//:bzl_library.bzl", "bzl_library") load("@build_bazel_rules_nodejs//:defs.bzl", "nodejs_binary") +package(default_visibility = ["//visibility:public"]) + bzl_library( name = "bzl", srcs = glob(["*.bzl"]), @@ -17,7 +19,7 @@ nodejs_binary( "//third_party/github.com/gjtorikian/isBinaryFile", "@nodejs//:run_npm.sh.template", ], - entry_point = "build_bazel_rules_nodejs/internal/npm_package/packager.js", + entry_point = ":packager.js", install_source_map_support = False, visibility = ["//visibility:public"], ) diff --git a/internal/rollup/BUILD.bazel b/internal/rollup/BUILD.bazel index 7e65f5e6f3..a53da3589e 100644 --- a/internal/rollup/BUILD.bazel +++ b/internal/rollup/BUILD.bazel @@ -38,7 +38,7 @@ nodejs_binary( # Allow --define=ROLLUP_BUNDLE_FIXED_CHUNK_NAMES=1 to be passed as # process.env so we can give predictable chunk names in CI configuration_env_vars = ["ROLLUP_BUNDLE_FIXED_CHUNK_NAMES"], - entry_point = "build_bazel_rules_nodejs_rollup_deps/node_modules/rollup/bin/rollup", + entry_point = "@build_bazel_rules_nodejs_rollup_deps//node_modules/rollup:bin/rollup", install_source_map_support = False, node_modules = "@build_bazel_rules_nodejs_rollup_deps//:node_modules", visibility = ["//visibility:public"], @@ -46,7 +46,7 @@ nodejs_binary( nodejs_binary( name = "tsc", - entry_point = "build_bazel_rules_nodejs_rollup_deps/node_modules/typescript/bin/tsc", + entry_point = "@build_bazel_rules_nodejs_rollup_deps//node_modules/typescript:bin/tsc", install_source_map_support = False, node_modules = "@build_bazel_rules_nodejs_rollup_deps//:node_modules", visibility = ["//visibility:public"], @@ -54,7 +54,7 @@ nodejs_binary( nodejs_binary( name = "terser", - entry_point = "build_bazel_rules_nodejs_rollup_deps/node_modules/terser/bin/uglifyjs", + entry_point = "@build_bazel_rules_nodejs_rollup_deps//node_modules/terser:bin/uglifyjs", install_source_map_support = False, node_modules = "@build_bazel_rules_nodejs_rollup_deps//:node_modules", visibility = ["//visibility:public"], @@ -63,7 +63,7 @@ nodejs_binary( nodejs_binary( name = "terser-wrapped", data = [":terser-wrapped.js"], - entry_point = "build_bazel_rules_nodejs/internal/rollup/terser-wrapped.js", + entry_point = ":terser-wrapped.js", install_source_map_support = False, node_modules = "@build_bazel_rules_nodejs_rollup_deps//:node_modules", visibility = ["//visibility:public"], @@ -72,7 +72,7 @@ nodejs_binary( nodejs_binary( name = "tsc-directory", data = [":tsc-directory.js"], - entry_point = "build_bazel_rules_nodejs/internal/rollup/tsc-directory.js", + entry_point = ":tsc-directory.js", install_source_map_support = False, node_modules = "@build_bazel_rules_nodejs_rollup_deps//:node_modules", visibility = ["//visibility:public"], @@ -80,7 +80,7 @@ nodejs_binary( nodejs_binary( name = "source-map-explorer", - entry_point = "build_bazel_rules_nodejs_rollup_deps/node_modules/source-map-explorer", + entry_point = "@build_bazel_rules_nodejs_rollup_deps//node_modules/source-map-explorer:index.js", install_source_map_support = False, node_modules = "@build_bazel_rules_nodejs_rollup_deps//:node_modules", visibility = ["//visibility:public"], diff --git a/internal/rollup/rollup_bundle.bzl b/internal/rollup/rollup_bundle.bzl index 4cf3e73ac6..a4fa173ee8 100644 --- a/internal/rollup/rollup_bundle.bzl +++ b/internal/rollup/rollup_bundle.bzl @@ -20,6 +20,7 @@ You do not need to install them into your project. load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources", "collect_node_modules_aspect") load("//internal/common:collect_es6_sources.bzl", _collect_es2015_sources = "collect_es6_sources") +load("//internal/common:expand_into_runfiles.bzl", "expand_path_into_runfiles") load("//internal/common:module_mappings.bzl", "get_module_mappings") _ROLLUP_MODULE_MAPPINGS_ATTR = "rollup_module_mappings" @@ -80,6 +81,13 @@ def _compute_node_modules_root(ctx): ] if f]) return node_modules_root +# Expand entry_point into runfiles and strip the file extension +def _entry_point_path(ctx): + return "/".join([ + expand_path_into_runfiles(ctx, ctx.file.entry_point.dirname), + ctx.file.entry_point.basename, + ])[:-(len(ctx.file.entry_point.extension) + 1)] + def write_rollup_config(ctx, plugins = [], root_dir = None, filename = "_%s.rollup.conf.js", output_format = "iife", additional_entry_points = []): """Generate a rollup config file. @@ -102,7 +110,7 @@ def write_rollup_config(ctx, plugins = [], root_dir = None, filename = "_%s.roll # build_file_path includes the BUILD.bazel file, transform here to only include the dirname build_file_dirname = "/".join(ctx.build_file_path.split("/")[:-1]) - entry_points = [ctx.attr.entry_point] + additional_entry_points + entry_points = [_entry_point_path(ctx)] + additional_entry_points mappings = dict() all_deps = ctx.attr.deps + ctx.attr.srcs @@ -363,9 +371,7 @@ def run_sourcemapexplorer(ctx, js, map, output): def _generate_toplevel_entry(ctx, bundles_folder, output): """Generates a native ESmodule that imports the entry point """ - main_entry_point_basename = ctx.attr.entry_point.split("/")[-1] - if not main_entry_point_basename.endswith(".js"): - main_entry_point_basename += ".js" + main_entry_point_basename = _entry_point_path(ctx).split("/")[-1] + ".js" ctx.actions.write(output, """import('./%s/%s');""" % (bundles_folder, main_entry_point_basename)) def _generate_code_split_entry(ctx, bundles_folder, output): @@ -419,10 +425,11 @@ def _generate_code_split_entry(ctx, bundles_folder, output): bundles_folder: the folder name with the bundled chunks to map to output: the file to generate """ - main_entry_point_basename = ctx.attr.entry_point.split("/")[-1] - main_entry_point_dirname = "/".join(ctx.attr.entry_point.split("/")[:-1]) + "/" + entry_point_path = _entry_point_path(ctx) + main_entry_point_basename = entry_point_path.split("/")[-1] + ".js" + main_entry_point_dirname = "/".join(entry_point_path.split("/")[:-1]) + "/" entry_points = {} - for e in [ctx.attr.entry_point] + ctx.attr.additional_entry_points: + for e in [entry_point_path] + ctx.attr.additional_entry_points: entry_point = e[len(main_entry_point_dirname):] entry_points["./" + entry_point] = bundles_folder + "/" + entry_point.split("/")[-1] @@ -436,6 +443,9 @@ def _generate_code_split_entry(ctx, bundles_folder, output): ) def _rollup_bundle(ctx): + if len(ctx.attr.entry_point.files) != 1: + fail("labels in entry_point must contain exactly one file") + if ctx.attr.additional_entry_points: # Generate code split bundles if additional entry points have been specified. # See doc for additional_entry_points for more information. @@ -601,11 +611,54 @@ ROLLUP_ATTRS = { It is sufficient to load one of these SystemJS boilerplate/entry point files as a script in your HTML to load your application""", ), - "entry_point": attr.string( + "entry_point": attr.label( doc = """The starting point of the application, passed as the `--input` flag to rollup. - This should be a path relative to the workspace root. + + If the entry JavaScript file belongs to the same package (as the BUILD file), + you can simply reference it by its relative name to the package directory: + + ``` + rollup_bundle( + name = "bundle", + entry_point = ":main.js", + ) + ``` + + You can specify the entry point as a typescript file so long as you also include + the ts_library target in deps: + + ``` + ts_library( + name = "main", + srcs = ["main.ts"], + ) + + rollup_bundle( + name = "bundle", + deps = [":main"] + entry_point = ":main.ts", + ) + ``` + + The rule will use the corresponding `.js` output of the ts_library rule as the entry point. + + If the entry point target is a rule, it should produce a single JavaScript entry file that will be passed to the nodejs_binary rule. + For example: + + ``` + filegroup( + name = "entry_file", + srcs = ["main.js"], + ) + + rollup_bundle( + name = "bundle", + entry_point = ":entry_file", + ) + ``` """, mandatory = True, + allow_single_file = True, ), "global_name": attr.string( doc = """A name given to this package when referenced as a global variable. diff --git a/internal/web_package/BUILD.bazel b/internal/web_package/BUILD.bazel index 02b62af38d..d4b5f93c8c 100644 --- a/internal/web_package/BUILD.bazel +++ b/internal/web_package/BUILD.bazel @@ -21,7 +21,7 @@ filegroup( nodejs_binary( name = "assembler", data = ["assembler.js"], - entry_point = "build_bazel_rules_nodejs/internal/web_package/assembler.js", + entry_point = ":assembler.js", install_source_map_support = False, node_modules = ":node_modules_none", ) @@ -32,7 +32,7 @@ nodejs_binary( "injector.js", "//third_party/github.com/inikulin/parse5", ], - entry_point = "build_bazel_rules_nodejs/internal/web_package/injector.js", + entry_point = ":injector.js", install_source_map_support = False, ) diff --git a/internal/web_package/test/BUILD.bazel b/internal/web_package/test/BUILD.bazel index 655475270f..c23b04ba89 100644 --- a/internal/web_package/test/BUILD.bazel +++ b/internal/web_package/test/BUILD.bazel @@ -5,8 +5,7 @@ package(default_visibility = ["//visibility:public"]) rollup_bundle( name = "bundle", - srcs = glob(["*.js"]), - entry_point = "internal/web_package/test/script.js", + entry_point = ":script.js", ) web_package( diff --git a/internal/web_package/test2/BUILD.bazel b/internal/web_package/test2/BUILD.bazel index 0fb78b8a13..7d1a0cca66 100644 --- a/internal/web_package/test2/BUILD.bazel +++ b/internal/web_package/test2/BUILD.bazel @@ -3,8 +3,7 @@ load("@build_bazel_rules_nodejs//internal/web_package:web_package.bzl", "web_pac rollup_bundle( name = "local_bundle", - srcs = glob(["*.js"]), - entry_point = "internal/web_package/test2/script.js", + entry_point = ":script.js", ) # Same exts as //internal/web_package/test-exports, //internal/web_package/test2/rel-exports diff --git a/package.bzl b/package.bzl index 6a58311ff5..a9d915febe 100644 --- a/package.bzl +++ b/package.bzl @@ -35,11 +35,12 @@ def rules_nodejs_dev_dependencies(): """ # Dependencies for generating documentation + # TODO(gregmagolan): switch to https://github.com/bazelbuild/rules_sass/ when + # https://github.com/bazelbuild/rules_sass/pull/87 lands http_archive( name = "io_bazel_rules_sass", - url = "https://github.com/bazelbuild/rules_sass/archive/8ccf4f1c351928b55d5dddf3672e3667f6978d60.zip", # 2018-11-23 - strip_prefix = "rules_sass-8ccf4f1c351928b55d5dddf3672e3667f6978d60", - sha256 = "894d7928df8da85e263d743c8434d4c10ab0a3f0708fed0d53394e688e3faf70", + url = "https://github.com/manekinekko/rules_sass/archive/9862dfc96a4a1f66fe171ef5e043b29853e8445b.zip", + strip_prefix = "rules_sass-9862dfc96a4a1f66fe171ef5e043b29853e8445b", ) # Needed for stardoc diff --git a/packages/create/BUILD.bazel b/packages/create/BUILD.bazel index f932fb274d..bfd4dcf86e 100644 --- a/packages/create/BUILD.bazel +++ b/packages/create/BUILD.bazel @@ -27,7 +27,7 @@ nodejs_test( ":npm_package", "@npm//minimist", ], - entry_point = "build_bazel_rules_nodejs/packages/create/test.js", + entry_point = ":test.js", ) # TODO(alexeagle): add e2e testing by running bazel in a newly created project diff --git a/packages/jasmine/BUILD.bazel b/packages/jasmine/BUILD.bazel index f7ac5321c9..02f922473f 100644 --- a/packages/jasmine/BUILD.bazel +++ b/packages/jasmine/BUILD.bazel @@ -60,7 +60,7 @@ npm_package( ) js_library( - name = "jasmine_runner", + name = "jasmine__pkg", srcs = [ "index.js", "src/jasmine_runner.js", diff --git a/packages/jasmine/src/jasmine_node_test.bzl b/packages/jasmine/src/jasmine_node_test.bzl index e50d67cbe3..db3331691d 100644 --- a/packages/jasmine/src/jasmine_node_test.bzl +++ b/packages/jasmine/src/jasmine_node_test.bzl @@ -28,23 +28,26 @@ def jasmine_node_test( deps = [], expected_exit_code = 0, tags = [], - jasmine = Label("@npm//@bazel/jasmine"), coverage = False, + jasmine = "@npm//node_modules/@bazel/jasmine:index.js", **kwargs): """Runs tests in NodeJS using the Jasmine test runner. To debug the test, see debugging notes in `nodejs_test`. Args: - name: name of the resulting label + name: Name of the resulting label srcs: JavaScript source files containing Jasmine specs data: Runtime dependencies which will be loaded while the test executes deps: Other targets which produce JavaScript, such as ts_library expected_exit_code: The expected exit code for the test. Defaults to 0. - tags: bazel tags applied to test - jasmine: a label providing the jasmine dependency - coverage: Enables code coverage collection and reporting - **kwargs: remaining arguments are passed to the test rule + tags: Bazel tags applied to test + coverage: Enables code coverage collection and reporting. Defaults to False. + jasmine: A label providing the @bazel/jasmine npm dependency. Defaults + to "@npm//node_modules/@bazel/jasmine:index.js" so that the correct + jasmine & jasmine-core dependencies are resolved unless they are + overwritten in a bootstrap file. + **kwargs: Remaining arguments are passed to the test rule """ devmode_js_sources( name = "%s_devmode_srcs" % name, @@ -53,11 +56,11 @@ def jasmine_node_test( tags = tags, ) - all_data = data + srcs + deps + [jasmine] + all_data = data + srcs + deps + [Label(jasmine).relative(":jasmine__pkg")] all_data += [":%s_devmode_srcs.MF" % name] all_data += [Label("@bazel_tools//tools/bash/runfiles")] - entry_point = "@bazel/jasmine/src/jasmine_runner.js" + entry_point = Label(jasmine).relative(":src/jasmine_runner.js") # If the target specified templated_args, pass it through. templated_args = kwargs.pop("templated_args", []) + ["$(location :%s_devmode_srcs.MF)" % name] diff --git a/packages/jasmine/test/BUILD.bazel b/packages/jasmine/test/BUILD.bazel index 1b7e57458b..ef86e1d292 100644 --- a/packages/jasmine/test/BUILD.bazel +++ b/packages/jasmine/test/BUILD.bazel @@ -1,48 +1,36 @@ -load("@npm_bazel_jasmine//:index.bzl", "jasmine_node_test") +load(":jasmine_node_test.bzl", "jasmine_node_test") jasmine_node_test( name = "underscore_spec_test", srcs = ["foo_spec.js"], - jasmine = "@npm//jasmine", - deps = ["//:jasmine_runner"], ) jasmine_node_test( name = "underscore_test_test", srcs = ["foo_test.js"], - jasmine = "@npm//jasmine", - deps = ["//:jasmine_runner"], ) jasmine_node_test( name = "dot_spec_test", srcs = ["foo.spec.js"], - jasmine = "@npm//jasmine", - deps = ["//:jasmine_runner"], ) jasmine_node_test( name = "dot_test_test", srcs = ["foo.test.js"], - jasmine = "@npm//jasmine", - deps = ["//:jasmine_runner"], ) jasmine_node_test( name = "sharding_test", srcs = ["sharded_test.js"], - jasmine = "@npm//jasmine", shard_count = 3, - deps = ["//:jasmine_runner"], ) jasmine_node_test( name = "failing_sharding_test", srcs = ["failing_sharded_test.js"], expected_exit_code = 3, - jasmine = "@npm//jasmine", shard_count = 2, - deps = ["//:jasmine_runner"], ) jasmine_node_test( @@ -54,8 +42,6 @@ jasmine_node_test( # maybe sniff the stdout for Ran 1 of 3 specs # or change the exit code for Jasmine 'incomplete' status expected_exit_code = 3, - jasmine = "@npm//jasmine", - deps = ["//:jasmine_runner"], ) jasmine_node_test( @@ -65,9 +51,7 @@ jasmine_node_test( "coverage_source.js", ], coverage = True, - jasmine = "@npm//jasmine", deps = [ - "//:jasmine_runner", "@npm//v8-coverage", ], ) @@ -75,9 +59,7 @@ jasmine_node_test( jasmine_node_test( name = "templated_args_test", srcs = ["templated_args_test.js"], - jasmine = "@npm//jasmine", templated_args = [ "--node_options=--experimental-modules", ], - deps = ["//:jasmine_runner"], ) diff --git a/packages/jasmine/test/jasmine_node_test.bzl b/packages/jasmine/test/jasmine_node_test.bzl new file mode 100644 index 0000000000..d04295d18d --- /dev/null +++ b/packages/jasmine/test/jasmine_node_test.bzl @@ -0,0 +1,33 @@ +# Copyright 2019 The Bazel Authors. All rights reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +""" Test API surface is +""" + +load("//:src/jasmine_node_test.bzl", _jasmine_node_test = "jasmine_node_test") + +def jasmine_node_test(deps = [], **kwargs): + deps = deps + [ + "//:jasmine__pkg", + "@npm//jasmine", + ] + _jasmine_node_test( + # The jasmine label here is specific to local testing since + # there is no @npm//@bazel/jasmine package here. Users + # will always have this label point to their @foobar//node_modules/@bazel/jasmine:index.js + # target if there is no @npm//@bazel/jasmine package + jasmine = "@npm_bazel_jasmine//:index.js", + deps = deps, + **kwargs + ) diff --git a/packages/karma/BUILD.bazel b/packages/karma/BUILD.bazel index 3b5c6cc2d3..ed8c12308d 100644 --- a/packages/karma/BUILD.bazel +++ b/packages/karma/BUILD.bazel @@ -53,7 +53,7 @@ nodejs_binary( "@npm//requirejs", "@npm//tmp", ], - entry_point = "karma/bin/karma", + entry_point = "@npm//node_modules/karma:bin/karma", install_source_map_support = False, ) diff --git a/packages/karma/docs/install.md b/packages/karma/docs/install.md index 2d50e94dc4..4f390c83a7 100644 --- a/packages/karma/docs/install.md +++ b/packages/karma/docs/install.md @@ -45,7 +45,7 @@ If you didn't use the `yarn_install` or `npm_install` rule to create an `npm` wo # attribute when using self-managed dependencies nodejs_binary( name = "karma/karma", - entry_point = "karma/bin/karma", + entry_point = "//:node_modules/karma/bin/karma", # Point bazel to your node_modules to find the entry point node_modules = ["//:node_modules"], ) diff --git a/packages/labs/package.json b/packages/labs/package.json index 118f87988f..32adf78605 100644 --- a/packages/labs/package.json +++ b/packages/labs/package.json @@ -11,6 +11,9 @@ "bugs": { "url": "https://github.com/bazelbuild/rules_nodejs/issues" }, + "bin": { + "webpack": "./webpack/src/cli.js" + }, "devDependencies": { "@bazel/typescript": "file:../../dist/npm_bazel_typescript", "@types/jasmine": "^3.3.9", diff --git a/packages/labs/webpack/BUILD.bazel b/packages/labs/webpack/BUILD.bazel index e058ecf5da..6c23a1eea9 100644 --- a/packages/labs/webpack/BUILD.bazel +++ b/packages/labs/webpack/BUILD.bazel @@ -1,5 +1,5 @@ # BEGIN-INTERNAL -load("@build_bazel_rules_nodejs//:defs.bzl", "npm_package") +load("@build_bazel_rules_nodejs//:defs.bzl", "nodejs_binary", "npm_package") npm_package( name = "webpack", @@ -10,9 +10,18 @@ npm_package( replacements = {"#@external\\s": ""}, visibility = ["//:__pkg__"], deps = [ - "//webpack/src:cli", + "//webpack/src:cli_lib", "//webpack/src:package_contents", ], ) +nodejs_binary( + name = "cli", + data = [ + "//webpack/src:cli_lib", + "@npm//webpack", + ], + entry_point = "//webpack/src:cli.ts", + visibility = ["//visibility:public"], +) # END-INTERNAL diff --git a/packages/labs/webpack/src/BUILD.bazel b/packages/labs/webpack/src/BUILD.bazel index ce4e3be085..c9aeebed86 100644 --- a/packages/labs/webpack/src/BUILD.bazel +++ b/packages/labs/webpack/src/BUILD.bazel @@ -1,11 +1,12 @@ -load("@build_bazel_rules_nodejs//:defs.bzl", "nodejs_binary") - # BEGIN-INTERNAL load("@npm_bazel_typescript//:defs.bzl", "ts_library") +exports_files(["cli.ts"]) + ts_library( name = "cli_lib", srcs = glob(["*.ts"]), + visibility = ["//:__subpackages__"], deps = [ "@npm//@types", ], @@ -20,24 +21,3 @@ filegroup( visibility = ["//webpack:__subpackages__"], ) # END-INTERNAL - -nodejs_binary( - name = "cli", - data = [ - # BEGIN-INTERNAL - # For local development, we depend on the TypeScript output - ":cli_lib", - # END-INTERNAL - - # For external usage, we depend on the published .JS files - #@external "@npm//@bazel/labs", - "@npm//webpack", - ], - # BEGIN-INTERNAL - # For local development, our module has this AMD name - entry_point = "npm_bazel_labs/webpack/src/cli.js", - # END-INTERNAL - # For external usage, we resolve the module from node_modules - #@external entry_point = "@bazel/labs/webpack/src/cli.js", - visibility = ["//visibility:public"], -) diff --git a/packages/labs/webpack/src/webpack_bundle.bzl b/packages/labs/webpack/src/webpack_bundle.bzl index a6410435e5..6b2184da8a 100644 --- a/packages/labs/webpack/src/webpack_bundle.bzl +++ b/packages/labs/webpack/src/webpack_bundle.bzl @@ -20,7 +20,7 @@ This rule is experimental, as part of Angular Labs! There may be breaking change WEBPACK_BUNDLE_ATTRS = { "srcs": attr.label_list(allow_files = True), "entry_point": attr.label(allow_single_file = True, mandatory = True), - "webpack": attr.label(default = "@npm_bazel_labs//webpack/src:cli", executable = True, cfg = "host"), + "webpack": attr.label(default = "@npm//@bazel/labs/bin:webpack", executable = True, cfg = "host"), } WEBPACK_BUNDLE_OUTS = { "bundle": "%{name}.js", diff --git a/packages/labs/webpack/test/BUILD.bazel b/packages/labs/webpack/test/BUILD.bazel index bfb37ace57..f70c338039 100644 --- a/packages/labs/webpack/test/BUILD.bazel +++ b/packages/labs/webpack/test/BUILD.bazel @@ -6,6 +6,11 @@ webpack_bundle( name = "bundle", srcs = glob(["*.js"]), entry_point = "index.js", + # The webpack label here is specific to local testing since + # there is no @bazel/labs npm package here. Users + # will always have this label point to their @foobar//@bazel/labs/bin:webpack + # target if they are not using the default @npm//@bazel/labs/bin:webpack + webpack = "@npm_bazel_labs//webpack:cli", ) ts_library( diff --git a/packages/typescript/WORKSPACE b/packages/typescript/WORKSPACE index 087ac75756..0f290f2152 100644 --- a/packages/typescript/WORKSPACE +++ b/packages/typescript/WORKSPACE @@ -38,10 +38,13 @@ rules_nodejs_dev_dependencies() # We use git_repository since Renovate knows how to update it. # With http_archive it only sees releases/download/*.tar.gz urls + +# TODO(gregmagolan): switch to https://github.com/bazelbuild/rules_typescript/ HEAD when +# https://github.com/bazelbuild/rules_typescript/pull/453 lands git_repository( name = "build_bazel_rules_typescript", - commit = "4ae7cda81c7ea3215a024f10b00ee38a0755549d", - remote = "http://github.com/bazelbuild/rules_typescript.git", + commit = "6521ce4e0d4959eaf46a4738d45f3f480d4af25f", + remote = "http://github.com/gregmagolan/rules_typescript.git", ) # We have a source dependency on build_bazel_rules_typescript diff --git a/packages/typescript/docs/BUILD.bazel b/packages/typescript/docs/BUILD.bazel index 6358bde82c..8f5640af6b 100644 --- a/packages/typescript/docs/BUILD.bazel +++ b/packages/typescript/docs/BUILD.bazel @@ -17,5 +17,5 @@ nodejs_test( "docs_test.js", ":index.md", ], - entry_point = "npm_bazel_typescript/docs/docs_test.js", + entry_point = ":docs_test.js", ) diff --git a/packages/typescript/internal/protobufjs/BUILD.bazel b/packages/typescript/internal/protobufjs/BUILD.bazel index c3dd63f692..4dc77a2fc1 100644 --- a/packages/typescript/internal/protobufjs/BUILD.bazel +++ b/packages/typescript/internal/protobufjs/BUILD.bazel @@ -42,7 +42,7 @@ nodejs_binary( "@build_bazel_rules_typescript_protobufs_compiletime_deps//escodegen", "@build_bazel_rules_typescript_protobufs_compiletime_deps//estraverse", ], - entry_point = "protobufjs/bin/pbjs", + entry_point = "@build_bazel_rules_typescript_protobufs_compiletime_deps//node_modules/protobufjs:bin/pbjs", install_source_map_support = False, ) @@ -65,7 +65,7 @@ nodejs_binary( "@build_bazel_rules_typescript_protobufs_compiletime_deps//escodegen", "@build_bazel_rules_typescript_protobufs_compiletime_deps//estraverse", ], - entry_point = "protobufjs/bin/pbts", + entry_point = "@build_bazel_rules_typescript_protobufs_compiletime_deps//node_modules/protobufjs:bin/pbts", install_source_map_support = False, ) diff --git a/scripts/setup_examples_angular.sh b/scripts/setup_examples_angular.sh index d6e310f3cd..208280d7f2 100755 --- a/scripts/setup_examples_angular.sh +++ b/scripts/setup_examples_angular.sh @@ -28,7 +28,8 @@ printf "\n\nSetting up /examples/angular\n" # Clean example echo_and_run cd ${EXAMPLES_DIR} rm -rf angular - echo_and_run git clone https://github.com/angular/angular-bazel-example.git angular + # TODO(gmagolan): switch back upstream when https://github.com/angular/angular-bazel-example/pull/450 lands + echo_and_run git clone --single-branch --branch entry-point https://github.com/gregmagolan/angular-bazel-example.git angular ( echo_and_run cd angular diff --git a/tools/npm_packages/bazel_workspaces/a/BUILD.bazel b/tools/npm_packages/bazel_workspaces/a/BUILD.bazel index 0c0bc63434..f4363550d1 100644 --- a/tools/npm_packages/bazel_workspaces/a/BUILD.bazel +++ b/tools/npm_packages/bazel_workspaces/a/BUILD.bazel @@ -5,5 +5,5 @@ nodejs_binary( data = [ ":index.js", ], - entry_point = "bazel_workspace_a/index.js", + entry_point = ":index.js", ) diff --git a/tools/npm_packages/bazel_workspaces/a/subdir/BUILD.bazel b/tools/npm_packages/bazel_workspaces/a/subdir/BUILD.bazel index 79650d95ef..f4363550d1 100644 --- a/tools/npm_packages/bazel_workspaces/a/subdir/BUILD.bazel +++ b/tools/npm_packages/bazel_workspaces/a/subdir/BUILD.bazel @@ -5,5 +5,5 @@ nodejs_binary( data = [ ":index.js", ], - entry_point = "bazel_workspace_a/subdir/index.js", + entry_point = ":index.js", ) diff --git a/tools/npm_packages/bazel_workspaces/b/BUILD.bazel b/tools/npm_packages/bazel_workspaces/b/BUILD.bazel index 3ab8090ffd..f4363550d1 100644 --- a/tools/npm_packages/bazel_workspaces/b/BUILD.bazel +++ b/tools/npm_packages/bazel_workspaces/b/BUILD.bazel @@ -5,5 +5,5 @@ nodejs_binary( data = [ ":index.js", ], - entry_point = "bazel_workspace_b/index.js", + entry_point = ":index.js", ) diff --git a/tools/npm_packages/bazel_workspaces/b/subdir/BUILD.bazel b/tools/npm_packages/bazel_workspaces/b/subdir/BUILD.bazel index f901d4a405..f4363550d1 100644 --- a/tools/npm_packages/bazel_workspaces/b/subdir/BUILD.bazel +++ b/tools/npm_packages/bazel_workspaces/b/subdir/BUILD.bazel @@ -5,5 +5,5 @@ nodejs_binary( data = [ ":index.js", ], - entry_point = "bazel_workspace_b/subdir/index.js", + entry_point = ":index.js", ) diff --git a/tools/npm_packages/bazel_workspaces/package.json b/tools/npm_packages/bazel_workspaces/package.json index a4538150f1..e78a47f468 100644 --- a/tools/npm_packages/bazel_workspaces/package.json +++ b/tools/npm_packages/bazel_workspaces/package.json @@ -1,6 +1,6 @@ { "name": "bazel_workspace", - "version": "0.0.1", + "version": "0.0.2", "bazelWorkspaces": { "bazel_workspace_a": { "rootPath": "a" diff --git a/yarn.lock b/yarn.lock index eeadf12ff2..4a85713c6d 100644 --- a/yarn.lock +++ b/yarn.lock @@ -442,7 +442,7 @@ base@^0.11.1: pascalcase "^0.1.1" "bazel_workspaces@file:./tools/npm_packages/bazel_workspaces": - version "0.0.1" + version "0.0.2" bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.1.1, bn.js@^4.4.0: version "4.11.8"