From cd8520d870abe490d7a154f7e1d9ccac32ea04d8 Mon Sep 17 00:00:00 2001 From: Alex Eagle Date: Sun, 29 Mar 2020 09:12:20 -0700 Subject: [PATCH] fix(typescript): include extended tsconfigs in _TsConfigInfo Allows ts_project to work with extra tsconfig indirections Fixes #1754 --- packages/typescript/src/internal/ts_project.bzl | 2 +- packages/typescript/test/ts_project/a/BUILD.bazel | 5 ++++- packages/typescript/test/ts_project/a/tsconfig-extended.json | 4 ++++ packages/typescript/test/ts_project/a/tsconfig.json | 2 +- 4 files changed, 10 insertions(+), 3 deletions(-) create mode 100644 packages/typescript/test/ts_project/a/tsconfig-extended.json diff --git a/packages/typescript/src/internal/ts_project.bzl b/packages/typescript/src/internal/ts_project.bzl index caa791fb5f..18f86d6665 100644 --- a/packages/typescript/src/internal/ts_project.bzl +++ b/packages/typescript/src/internal/ts_project.bzl @@ -123,7 +123,7 @@ def _ts_project_impl(ctx): collect_default = True, ), ), - _TsConfigInfo(tsconfigs = depset([ctx.file.tsconfig], transitive = [ + _TsConfigInfo(tsconfigs = depset([ctx.file.tsconfig] + ctx.files.extends, transitive = [ dep[_TsConfigInfo].tsconfigs for dep in ctx.attr.deps if _TsConfigInfo in dep diff --git a/packages/typescript/test/ts_project/a/BUILD.bazel b/packages/typescript/test/ts_project/a/BUILD.bazel index 37725b049a..738495a362 100644 --- a/packages/typescript/test/ts_project/a/BUILD.bazel +++ b/packages/typescript/test/ts_project/a/BUILD.bazel @@ -2,7 +2,10 @@ load("@npm_bazel_typescript//:index.bzl", "ts_project") ts_project( composite = True, - extends = ["//packages/typescript/test/ts_project:tsconfig-base.json"], + extends = [ + ":tsconfig-extended.json", + "//packages/typescript/test/ts_project:tsconfig-base.json", + ], # Intentionally not syncing this option from tsconfig, to test validator suppression # source_map = True, validate = False, diff --git a/packages/typescript/test/ts_project/a/tsconfig-extended.json b/packages/typescript/test/ts_project/a/tsconfig-extended.json new file mode 100644 index 0000000000..e703888abb --- /dev/null +++ b/packages/typescript/test/ts_project/a/tsconfig-extended.json @@ -0,0 +1,4 @@ +// This file is an extra hop of indirection, regression test for #1754 +{ + "extends": "../tsconfig-base" +} \ No newline at end of file diff --git a/packages/typescript/test/ts_project/a/tsconfig.json b/packages/typescript/test/ts_project/a/tsconfig.json index 8fa4bcb5e0..3e6e16dcfc 100644 --- a/packages/typescript/test/ts_project/a/tsconfig.json +++ b/packages/typescript/test/ts_project/a/tsconfig.json @@ -1,5 +1,5 @@ { - "extends": "../tsconfig-base.json", + "extends": "./tsconfig-extended.json", "compilerOptions": { "sourceMap": true, // WORKAROUND https://github.com/microsoft/TypeScript/issues/37378