diff options
author | 2023-08-15 22:06:41 +0000 | |
---|---|---|
committer | 2023-08-16 01:15:48 +0000 | |
commit | 03010664c89cdc98a3f191111e546bc85c77c25b (patch) | |
tree | a2cf11c7c97527428eee689d74baa45bc60aa3a6 /android/bazel_paths_test.go | |
parent | f768e6e27ea7d9833ae324d58621b874a7144170 (diff) |
Add a function to find src labels in a specific directory
The existing api restricts search to the directory of the currently
visited soong module. Create a new function that allows search in any
directory. Internally it calls TransformSubpackagePath so the returned
labels will be resolved to respect package boundaries.
The use case for this is to support proto.include_dirs of cc_*, java_*,
python_*
Test: Added a unit test that uses a mock for GlobWihDeps
Change-Id: I75fe3ca7de88b163f456190049a22c62f91c9a2e
Diffstat (limited to 'android/bazel_paths_test.go')
-rw-r--r-- | android/bazel_paths_test.go | 54 |
1 files changed, 51 insertions, 3 deletions
diff --git a/android/bazel_paths_test.go b/android/bazel_paths_test.go index 75b77a36c..bed719cbb 100644 --- a/android/bazel_paths_test.go +++ b/android/bazel_paths_test.go @@ -15,6 +15,7 @@ package android import ( + "fmt" "path/filepath" "testing" @@ -114,8 +115,9 @@ func TestPathForBazelOutRelativeWithParentDirectoryRoot(t *testing.T) { type TestBazelConversionPathContext struct { TestBazelConversionContext - moduleDir string - cfg Config + moduleDir string + cfg Config + mockGlobResults *[]string } func (ctx *TestBazelConversionPathContext) AddNinjaFileDeps(...string) { @@ -123,7 +125,10 @@ func (ctx *TestBazelConversionPathContext) AddNinjaFileDeps(...string) { } func (ctx *TestBazelConversionPathContext) GlobWithDeps(string, []string) ([]string, error) { - panic("Unimplemented") + if ctx.mockGlobResults == nil { + return []string{}, fmt.Errorf("Set mock glob results first") + } + return *ctx.mockGlobResults, nil } func (ctx *TestBazelConversionPathContext) PropertyErrorf(string, string, ...interface{}) { @@ -190,3 +195,46 @@ func TestTransformSubpackagePath(t *testing.T) { } } } + +// Check that the files in a specific directory are returned with labels that respect package boundaries +// Since the test uses a mock for GlobWithDeps, the params passed to BazelLabelForSrcPatternExcludes are no-ops +func TestBazelLabelForSrcPatternExcludes(t *testing.T) { + cfg := NullConfig("out", "out/soong") + cfg.fs = pathtools.MockFs(map[string][]byte{ + "x/Android.bp": nil, + "x/y/Android.bp": nil, + // .proto files + "foo.proto": nil, + "x/bar.proto": nil, + "x/baz.proto": nil, + "x/y/qux.proto": nil, + }) + + var ctx BazelConversionPathContext = &TestBazelConversionPathContext{ + cfg: cfg, + } + + // Root dir + ctx.(*TestBazelConversionPathContext).mockGlobResults = &[]string{"foo.proto", "x/bar.proto", "x/baz.proto", "x/y/qux.proto"} + actualLabelsFromRoot := BazelLabelForSrcPatternExcludes(ctx, ".", "**/*.proto", []string{}) + expectedLabelsAsString := []string{"foo.proto", "//x:bar.proto", "//x:baz.proto", "//x/y:qux.proto"} + for i, actual := range actualLabelsFromRoot.Includes { + AssertStringEquals(t, "Error in finding src labels relative to root directory", expectedLabelsAsString[i], actual.Label) + } + + // x dir + ctx.(*TestBazelConversionPathContext).mockGlobResults = &[]string{"x/bar.proto", "x/baz.proto", "x/y/qux.proto"} + actualLabelsFromRoot = BazelLabelForSrcPatternExcludes(ctx, "x", "**/*.proto", []string{}) + expectedLabelsAsString = []string{"bar.proto", "baz.proto", "//x/y:qux.proto"} + for i, actual := range actualLabelsFromRoot.Includes { + AssertStringEquals(t, "Error in finding src labels relative to x directory", expectedLabelsAsString[i], actual.Label) + } + + // y dir + ctx.(*TestBazelConversionPathContext).mockGlobResults = &[]string{"x/y/qux.proto"} + actualLabelsFromRoot = BazelLabelForSrcPatternExcludes(ctx, "x/y", "**/*.proto", []string{}) + expectedLabelsAsString = []string{"qux.proto"} + for i, actual := range actualLabelsFromRoot.Includes { + AssertStringEquals(t, "Error in finding src labels relative to x/y directory", expectedLabelsAsString[i], actual.Label) + } +} |