Skip to content

Commit

Permalink
chore: flip supports_workers to default False
Browse files Browse the repository at this point in the history
Fixes #400
  • Loading branch information
alexeagle committed Aug 9, 2023
1 parent 5daf9a0 commit d355c4d
Show file tree
Hide file tree
Showing 7 changed files with 36 additions and 129 deletions.
12 changes: 5 additions & 7 deletions docs/rules.md

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 3 additions & 3 deletions docs/troubleshooting.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,9 @@ redirect the stdout to a file that you can analyze with power tools.

## Non-deterministic behavior

By default, we run `tsc` in a "watch mode" using the [Bazel Persistent Worker](https://bazel.build/remote/persistent) feature.
When Worker Support is enabled, we run `tsc` in a "watch mode" using the [Bazel Persistent Worker](https://bazel.build/remote/persistent) feature.
See the [`supports_workers`](https://docs.aspect.build/rules/aspect_rules_ts/docs/rules#supports_workers-1) attribute for docs on enabling this feature.

However, this risks leaking state from one compilation to another, and you may still encounter such bugs, for example:
- removing a required types package from `deps` but the compilation still succeeds
- outputs created by a previous compilation are still produced even though the source file is deleted
Expand All @@ -76,8 +78,6 @@ You can confirm that it's a worker bug by running `bazel shutdown` and trying ag

Please check for issues or file one if you find a bug with persistent workers.

To disable persistent workers for a single target, use the `supports_workers` attribute of `ts_project`. To disable globally, add the line `build --strategy=TsProject=sandboxed` to your `.bazelrc`.

## Which files should be emitted

TypeScript emits for each file in the "Program". `--listFiles` is a `tsc` flag to show what is in the program, and `--listEmittedFiles` shows what was written.
Expand Down
3 changes: 1 addition & 2 deletions ts/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ bool_flag(

bool_flag(
name = "supports_workers",
build_setting_default = True,
build_setting_default = False,
visibility = ["//visibility:public"],
)

Expand Down Expand Up @@ -122,7 +122,6 @@ options(
),
supports_workers = select({
":supports_workers_flag": True,
# TODO(2.0): default should be False if we set swc as default
"//conditions:default": False,
}),
verbose = select({
Expand Down
26 changes: 14 additions & 12 deletions ts/defs.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -225,19 +225,22 @@ def ts_project(
ts_build_info_file: The user-specified value of `tsBuildInfoFile` from the tsconfig.
Helps Bazel to predict the path where the .tsbuildinfo output is written.
supports_workers: Whether the worker protocol is enabled.
To disable worker mode for a particular target set `supports_workers` to `False`.
supports_workers: Whether the "Persistent Worker" protocol is enabled.
This uses a custom `tsc` compiler to make rebuilds faster.
Note that this causes some known correctness bugs, see
https://docs.aspect.build/rules/aspect_rules_ts/docs/troubleshooting.
We do not intend to fix these bugs.
Note that value of this attribute always preferred over `--@aspect_rules_ts//ts:supports_workers` flag
unless the `supports_workers` attribute is not set explicitly.
Worker mode can be enabled for all `ts_project`s in a build with the global
`--@aspect_rules_ts//ts:supports_workers` flag.
To enable worker mode for all builds in the workspace, add
`build --@aspect_rules_ts//ts:supports_workers` to the .bazelrc.
Worker mode can be disabled workspace wide by using the `--@aspect_rules_ts//ts:supports_workers` flag.
To disable worker mode globally, insert `build --@aspect_rules_ts//ts:supports_workers=false` into the .bazelrc.
This is a "tri-state" attribute. The valid values are:
Alternatively, worker mode can be controlled via `--strategy`.
To disable worker mode globally via `--strategy` insert `build --strategy=TsProject=sandboxed` into the .bazelrc.
See https://docs.bazel.build/versions/main/user-manual.html#flag--strategy for more details.
- `0`: use the value of the global --@aspect_rules_ts//ts:supports_workers flag.
- `1`: Override the global flag, enabling workers for this target.
- `-1`: Override the global flag, disabling workers for this target.
**kwargs: passed through to underlying [`ts_project_rule`](#ts_project_rule), eg. `visibility`, `tags`
"""
Expand Down Expand Up @@ -391,7 +394,7 @@ def ts_project(

# Disable workers if a custom tsc was provided but not a custom tsc_worker.
if tsc != _tsc and tsc_worker == _tsc_worker:
supports_workers = False
supports_workers = -1

ts_project_rule(
name = tsc_target_name,
Expand Down Expand Up @@ -427,6 +430,5 @@ def ts_project(
"@npm_typescript//:is_typescript_5_or_greater": True,
"//conditions:default": False,
}),
internal_do_not_depend_supports_workers_is_none = supports_workers == None,
**kwargs
)
16 changes: 8 additions & 8 deletions ts/private/ts_lib.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -41,19 +41,19 @@ See more details on the `assets` parameter of the `ts_project` macro.
allow_files = True,
mandatory = True,
),
"supports_workers": attr.bool(
doc = "Whether the tsc compiler understands Bazel's persistent worker protocol",
default = False,
"supports_workers": attr.int(
doc = """\
Whether to use a custom `tsc` compiler which understands Bazel's persistent worker protocol.
See the docs for `supports_workers` on the [`ts_project`](#ts_project) macro.
""",
default = 0,
values = [-1, 0, 1],
),
"is_typescript_5_or_greater": attr.bool(
doc = "Whether TypeScript version is >= 5.0.0",
default = False,
),
# TODO(2.0): remove this and make supports_workers a tri-state int.
"internal_do_not_depend_supports_workers_is_none": attr.bool(
doc = "Internal. DO NOT DEPEND!",
default = False,
),
"transpile": attr.bool(
doc = "whether tsc should be used to produce .js outputs",
default = True,
Expand Down
12 changes: 5 additions & 7 deletions ts/private/ts_project.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -67,13 +67,11 @@ def _ts_project_impl(ctx):
execution_requirements = {}
executable = ctx.executable.tsc

supports_workers = ctx.attr.supports_workers

# workers can be enabled/disabled globally. if no supports_workers attribute is set explicitly for this target,
# which is indicated by internal_do_not_depend_supports_workers_is_none attribute, then set it to global supports_workers config
# TODO(2.0): remove this
if ctx.attr.internal_do_not_depend_supports_workers_is_none:
supports_workers = options.supports_workers
supports_workers = options.supports_workers
if ctx.attr.supports_workers == 1:
supports_workers = True
elif ctx.attr.supports_workers == -1:
supports_workers = False

host_is_windows = platform_utils.host_platform_is_windows()
if host_is_windows and supports_workers:
Expand Down
Loading

0 comments on commit d355c4d

Please sign in to comment.