Merge "export allowlist of environment variables to Bazel" am: db23e22835
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/2421469 Change-Id: I737c772c39100936506eafe59c86652e2169658b Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
		| @@ -29,6 +29,7 @@ import ( | |||||||
| 	"android/soong/android/allowlists" | 	"android/soong/android/allowlists" | ||||||
| 	"android/soong/bazel/cquery" | 	"android/soong/bazel/cquery" | ||||||
| 	"android/soong/shared" | 	"android/soong/shared" | ||||||
|  | 	"android/soong/starlark_fmt" | ||||||
|  |  | ||||||
| 	"github.com/google/blueprint" | 	"github.com/google/blueprint" | ||||||
|  |  | ||||||
| @@ -43,6 +44,27 @@ var ( | |||||||
| 		Description: "", | 		Description: "", | ||||||
| 		CommandDeps: []string{"${bazelBuildRunfilesTool}"}, | 		CommandDeps: []string{"${bazelBuildRunfilesTool}"}, | ||||||
| 	}, "outDir") | 	}, "outDir") | ||||||
|  | 	allowedBazelEnvironmentVars = []string{ | ||||||
|  | 		"ALLOW_LOCAL_TIDY_TRUE", | ||||||
|  | 		"DEFAULT_TIDY_HEADER_DIRS", | ||||||
|  | 		"TIDY_TIMEOUT", | ||||||
|  | 		"WITH_TIDY", | ||||||
|  | 		"WITH_TIDY_FLAGS", | ||||||
|  | 		"SKIP_ABI_CHECKS", | ||||||
|  | 		"UNSAFE_DISABLE_APEX_ALLOWED_DEPS_CHECK", | ||||||
|  | 		"AUTO_ZERO_INITIALIZE", | ||||||
|  | 		"AUTO_PATTERN_INITIALIZE", | ||||||
|  | 		"AUTO_UNINITIALIZE", | ||||||
|  | 		"USE_CCACHE", | ||||||
|  | 		"LLVM_NEXT", | ||||||
|  | 		"ALLOW_UNKNOWN_WARNING_OPTION", | ||||||
|  |  | ||||||
|  | 		// Overrides the version in the apex_manifest.json. The version is unique for | ||||||
|  | 		// each branch (internal, aosp, mainline releases, dessert releases).  This | ||||||
|  | 		// enables modules built on an older branch to be installed against a newer | ||||||
|  | 		// device for development purposes. | ||||||
|  | 		"OVERRIDE_APEX_MANIFEST_DEFAULT_VERSION", | ||||||
|  | 	} | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func init() { | func init() { | ||||||
| @@ -165,7 +187,7 @@ type BazelContext interface { | |||||||
| } | } | ||||||
|  |  | ||||||
| type bazelRunner interface { | type bazelRunner interface { | ||||||
| 	createBazelCommand(paths *bazelPaths, runName bazel.RunName, command bazelCommand, extraFlags ...string) *exec.Cmd | 	createBazelCommand(config Config, paths *bazelPaths, runName bazel.RunName, command bazelCommand, extraFlags ...string) *exec.Cmd | ||||||
| 	issueBazelCommand(bazelCmd *exec.Cmd) (output string, errorMessage string, error error) | 	issueBazelCommand(bazelCmd *exec.Cmd) (output string, errorMessage string, error error) | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -558,7 +580,7 @@ type mockBazelRunner struct { | |||||||
| 	extraFlags []string | 	extraFlags []string | ||||||
| } | } | ||||||
|  |  | ||||||
| func (r *mockBazelRunner) createBazelCommand(_ *bazelPaths, _ bazel.RunName, | func (r *mockBazelRunner) createBazelCommand(_ Config, _ *bazelPaths, _ bazel.RunName, | ||||||
| 	command bazelCommand, extraFlags ...string) *exec.Cmd { | 	command bazelCommand, extraFlags ...string) *exec.Cmd { | ||||||
| 	r.commands = append(r.commands, command) | 	r.commands = append(r.commands, command) | ||||||
| 	r.extraFlags = append(r.extraFlags, strings.Join(extraFlags, " ")) | 	r.extraFlags = append(r.extraFlags, strings.Join(extraFlags, " ")) | ||||||
| @@ -595,7 +617,7 @@ func (r *builtinBazelRunner) issueBazelCommand(bazelCmd *exec.Cmd) (string, stri | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (r *builtinBazelRunner) createBazelCommand(paths *bazelPaths, runName bazel.RunName, command bazelCommand, | func (r *builtinBazelRunner) createBazelCommand(config Config, paths *bazelPaths, runName bazel.RunName, command bazelCommand, | ||||||
| 	extraFlags ...string) *exec.Cmd { | 	extraFlags ...string) *exec.Cmd { | ||||||
| 	cmdFlags := []string{ | 	cmdFlags := []string{ | ||||||
| 		"--output_base=" + absolutePath(paths.outputBase), | 		"--output_base=" + absolutePath(paths.outputBase), | ||||||
| @@ -639,6 +661,13 @@ func (r *builtinBazelRunner) createBazelCommand(paths *bazelPaths, runName bazel | |||||||
| 		// explicitly in BUILD files. | 		// explicitly in BUILD files. | ||||||
| 		"BAZEL_DO_NOT_DETECT_CPP_TOOLCHAIN=1", | 		"BAZEL_DO_NOT_DETECT_CPP_TOOLCHAIN=1", | ||||||
| 	} | 	} | ||||||
|  | 	for _, envvar := range allowedBazelEnvironmentVars { | ||||||
|  | 		val := config.Getenv(envvar) | ||||||
|  | 		if val == "" { | ||||||
|  | 			continue | ||||||
|  | 		} | ||||||
|  | 		extraEnv = append(extraEnv, fmt.Sprintf("%s=%s", envvar, val)) | ||||||
|  | 	} | ||||||
| 	bazelCmd.Env = append(os.Environ(), extraEnv...) | 	bazelCmd.Env = append(os.Environ(), extraEnv...) | ||||||
|  |  | ||||||
| 	return bazelCmd | 	return bazelCmd | ||||||
| @@ -965,13 +994,13 @@ func (context *mixedBuildBazelContext) InvokeBazel(config Config, ctx *Context) | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	context.results = make(map[cqueryKey]string) | 	context.results = make(map[cqueryKey]string) | ||||||
| 	if err := context.runCquery(ctx); err != nil { | 	if err := context.runCquery(config, ctx); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	if err := context.runAquery(config, ctx); err != nil { | 	if err := context.runAquery(config, ctx); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	if err := context.generateBazelSymlinks(ctx); err != nil { | 	if err := context.generateBazelSymlinks(config, ctx); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -980,7 +1009,7 @@ func (context *mixedBuildBazelContext) InvokeBazel(config Config, ctx *Context) | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
| func (context *mixedBuildBazelContext) runCquery(ctx *Context) error { | func (context *mixedBuildBazelContext) runCquery(config Config, ctx *Context) error { | ||||||
| 	if ctx != nil { | 	if ctx != nil { | ||||||
| 		ctx.EventHandler.Begin("cquery") | 		ctx.EventHandler.Begin("cquery") | ||||||
| 		defer ctx.EventHandler.End("cquery") | 		defer ctx.EventHandler.End("cquery") | ||||||
| @@ -1007,7 +1036,7 @@ func (context *mixedBuildBazelContext) runCquery(ctx *Context) error { | |||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	cqueryCommandWithFlag := context.createBazelCommand(context.paths, bazel.CqueryBuildRootRunName, cqueryCmd, | 	cqueryCommandWithFlag := context.createBazelCommand(config, context.paths, bazel.CqueryBuildRootRunName, cqueryCmd, | ||||||
| 		"--output=starlark", "--starlark:file="+absolutePath(cqueryFileRelpath)) | 		"--output=starlark", "--starlark:file="+absolutePath(cqueryFileRelpath)) | ||||||
| 	cqueryOutput, cqueryErrorMessage, cqueryErr := context.issueBazelCommand(cqueryCommandWithFlag) | 	cqueryOutput, cqueryErrorMessage, cqueryErr := context.issueBazelCommand(cqueryCommandWithFlag) | ||||||
| 	if cqueryErr != nil { | 	if cqueryErr != nil { | ||||||
| @@ -1072,7 +1101,7 @@ func (context *mixedBuildBazelContext) runAquery(config Config, ctx *Context) er | |||||||
| 			extraFlags = append(extraFlags, "--instrumentation_filter="+strings.Join(paths, ",")) | 			extraFlags = append(extraFlags, "--instrumentation_filter="+strings.Join(paths, ",")) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	aqueryOutput, _, err := context.issueBazelCommand(context.createBazelCommand(context.paths, bazel.AqueryBuildRootRunName, aqueryCmd, | 	aqueryOutput, _, err := context.issueBazelCommand(context.createBazelCommand(config, context.paths, bazel.AqueryBuildRootRunName, aqueryCmd, | ||||||
| 		extraFlags...)) | 		extraFlags...)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -1081,7 +1110,7 @@ func (context *mixedBuildBazelContext) runAquery(config Config, ctx *Context) er | |||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
| func (context *mixedBuildBazelContext) generateBazelSymlinks(ctx *Context) error { | func (context *mixedBuildBazelContext) generateBazelSymlinks(config Config, ctx *Context) error { | ||||||
| 	if ctx != nil { | 	if ctx != nil { | ||||||
| 		ctx.EventHandler.Begin("symlinks") | 		ctx.EventHandler.Begin("symlinks") | ||||||
| 		defer ctx.EventHandler.End("symlinks") | 		defer ctx.EventHandler.End("symlinks") | ||||||
| @@ -1089,7 +1118,7 @@ func (context *mixedBuildBazelContext) generateBazelSymlinks(ctx *Context) error | |||||||
| 	// Issue a build command of the phony root to generate symlink forests for dependencies of the | 	// Issue a build command of the phony root to generate symlink forests for dependencies of the | ||||||
| 	// Bazel build. This is necessary because aquery invocations do not generate this symlink forest, | 	// Bazel build. This is necessary because aquery invocations do not generate this symlink forest, | ||||||
| 	// but some of symlinks may be required to resolve source dependencies of the build. | 	// but some of symlinks may be required to resolve source dependencies of the build. | ||||||
| 	_, _, err := context.issueBazelCommand(context.createBazelCommand(context.paths, bazel.BazelBuildPhonyRootRunName, buildCmd)) | 	_, _, err := context.issueBazelCommand(context.createBazelCommand(config, context.paths, bazel.BazelBuildPhonyRootRunName, buildCmd)) | ||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1299,3 +1328,13 @@ func GetConfigKey(ctx BaseModuleContext) configKey { | |||||||
| func bazelDepsetName(contentHash string) string { | func bazelDepsetName(contentHash string) string { | ||||||
| 	return fmt.Sprintf("bazel_depset_%s", contentHash) | 	return fmt.Sprintf("bazel_depset_%s", contentHash) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func EnvironmentVarsFile(config Config) string { | ||||||
|  | 	return fmt.Sprintf(bazel.GeneratedBazelFileWarning+` | ||||||
|  | _env = %s | ||||||
|  |  | ||||||
|  | env = _env | ||||||
|  | `, | ||||||
|  | 		starlark_fmt.PrintStringList(allowedBazelEnvironmentVars, 0), | ||||||
|  | 	) | ||||||
|  | } | ||||||
|   | |||||||
| @@ -58,6 +58,8 @@ func soongInjectionFiles(cfg android.Config, metrics CodegenMetrics) []BazelFile | |||||||
| 	files = append(files, newFile("api_levels", "api_levels.json", string(apiLevelsContent))) | 	files = append(files, newFile("api_levels", "api_levels.json", string(apiLevelsContent))) | ||||||
| 	files = append(files, newFile("api_levels", "api_levels.bzl", android.StarlarkApiLevelConfigs(cfg))) | 	files = append(files, newFile("api_levels", "api_levels.bzl", android.StarlarkApiLevelConfigs(cfg))) | ||||||
|  |  | ||||||
|  | 	files = append(files, newFile("allowlists", GeneratedBuildFileName, "")) | ||||||
|  | 	files = append(files, newFile("allowlists", "env.bzl", android.EnvironmentVarsFile(cfg))) | ||||||
| 	// TODO(b/262781701): Create an alternate soong_build entrypoint for writing out these files only when requested | 	// TODO(b/262781701): Create an alternate soong_build entrypoint for writing out these files only when requested | ||||||
| 	files = append(files, newFile("allowlists", "mixed_build_prod_allowlist.txt", strings.Join(android.GetBazelEnabledModules(android.BazelProdMode), "\n")+"\n")) | 	files = append(files, newFile("allowlists", "mixed_build_prod_allowlist.txt", strings.Join(android.GetBazelEnabledModules(android.BazelProdMode), "\n")+"\n")) | ||||||
| 	files = append(files, newFile("allowlists", "mixed_build_staging_allowlist.txt", strings.Join(android.GetBazelEnabledModules(android.BazelStagingMode), "\n")+"\n")) | 	files = append(files, newFile("allowlists", "mixed_build_staging_allowlist.txt", strings.Join(android.GetBazelEnabledModules(android.BazelStagingMode), "\n")+"\n")) | ||||||
|   | |||||||
| @@ -151,6 +151,14 @@ func TestCreateBazelFiles_Bp2Build_CreatesDefaultFiles(t *testing.T) { | |||||||
| 			dir:      "api_levels", | 			dir:      "api_levels", | ||||||
| 			basename: "api_levels.bzl", | 			basename: "api_levels.bzl", | ||||||
| 		}, | 		}, | ||||||
|  | 		{ | ||||||
|  | 			dir:      "allowlists", | ||||||
|  | 			basename: GeneratedBuildFileName, | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			dir:      "allowlists", | ||||||
|  | 			basename: "env.bzl", | ||||||
|  | 		}, | ||||||
| 		{ | 		{ | ||||||
| 			dir:      "allowlists", | 			dir:      "allowlists", | ||||||
| 			basename: "mixed_build_prod_allowlist.txt", | 			basename: "mixed_build_prod_allowlist.txt", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user