From 2bc4b5ebbaafd5854b9fe09f117f0ede48cacee5 Mon Sep 17 00:00:00 2001 From: thumphries-stripe <90940789+thumphries-stripe@users.noreply.github.com> Date: Wed, 17 Apr 2024 09:43:54 -0700 Subject: [PATCH] buildozer: correctly substitute custom string attrs (#1246) --- edit/buildozer.go | 2 +- edit/buildozer_test.go | 55 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 56 insertions(+), 1 deletion(-) diff --git a/edit/buildozer.go b/edit/buildozer.go index 486d71f63..6bc0a829c 100644 --- a/edit/buildozer.go +++ b/edit/buildozer.go @@ -546,7 +546,7 @@ func cmdSubstitute(opts *Options, env CmdEnvironment) (*build.File, error) { continue } if newValue, ok := stringSubstitute(e.Value, oldRegexp, newTemplate); ok { - env.Rule.SetAttr(key, getAttrValueExpr(key, []string{newValue}, env)) + env.Rule.SetAttr(key, getStringExpr(newValue, env.Pkg)) } } return env.File, nil diff --git a/edit/buildozer_test.go b/edit/buildozer_test.go index 26ce729a2..5e9d37995 100644 --- a/edit/buildozer_test.go +++ b/edit/buildozer_test.go @@ -414,6 +414,61 @@ func TestCmdSubstituteLoad(t *testing.T) { } } +func TestCmdSubstitute(t *testing.T) { + for i, tc := range []struct { + name string + args []string + buildFile string + expected string + }{ + { + name: "empty_rule", + args: []string{"*", "^$", "x"}, + buildFile: `cc_library()`, + expected: `cc_library()`, + }, + { + name: "known_attr", + args: []string{"*", "^//(.*)$", "//foo/${1}"}, + buildFile: `cc_library(deps = ["//bar/baz:quux"])`, + expected: `cc_library(deps = ["//foo/bar/baz:quux"])`, + }, + { + name: "custom_attr", + args: []string{"*", "^//(.*)$", "//foo/${1}"}, + buildFile: `cc_library(my_custom_attr = "//bar/baz:quux")`, + expected: `cc_library(my_custom_attr = "//foo/bar/baz:quux")`, + }, + { + name: "specific_rule", + args: []string{"deps", "^//(.*)$", "//foo/${1}"}, + buildFile: `cc_library(deps = ["//bar"], fancy_deps = ["//bar/baz:quux"])`, + expected: `cc_library( + fancy_deps = ["//bar/baz:quux"], + deps = ["//foo/bar"], +)`, + }, + } { + t.Run(tc.name, func(t *testing.T) { + bld, err := build.Parse("BUILD", []byte(tc.buildFile)) + if err != nil { + t.Error(err) + return + } + env := CmdEnvironment{ + File: bld, + Args: tc.args, + Rule: bld.RuleAt(1), + } + bld, _ = cmdSubstitute(NewOpts(), env) + got := strings.TrimSpace(string(build.Format(bld))) + if got != tc.expected { + t.Errorf("cmdSubstitute(%d):\ngot:\n%s\nexpected:\n%s", i, got, tc.expected) + } + }) + } +} + func TestCmdDictAddSet_missingColon(t *testing.T) { for _, tc := range []struct { name string