| // Copyright 2022 Google Inc. All rights reserved. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| package android |
| |
| import ( |
| "path/filepath" |
| "testing" |
| |
| "android/soong/bazel" |
| "github.com/google/blueprint" |
| "github.com/google/blueprint/pathtools" |
| ) |
| |
| type TestBazelPathContext struct{} |
| |
| func (*TestBazelPathContext) Config() Config { |
| cfg := NullConfig("out", "out/soong") |
| cfg.BazelContext = MockBazelContext{ |
| OutputBaseDir: "out/bazel", |
| } |
| return cfg |
| } |
| |
| func (*TestBazelPathContext) AddNinjaFileDeps(...string) { |
| panic("Unimplemented") |
| } |
| |
| func TestPathForBazelOut(t *testing.T) { |
| ctx := &TestBazelPathContext{} |
| out := PathForBazelOut(ctx, "foo/bar/baz/boq.txt") |
| expectedPath := filepath.Join(ctx.Config().BazelContext.OutputBase(), "execroot/__main__/foo/bar/baz/boq.txt") |
| if out.String() != expectedPath { |
| t.Errorf("incorrect OutputPath: expected %q, got %q", expectedPath, out.String()) |
| } |
| |
| expectedRelPath := "foo/bar/baz/boq.txt" |
| if out.Rel() != expectedRelPath { |
| t.Errorf("incorrect OutputPath.Rel(): expected %q, got %q", expectedRelPath, out.Rel()) |
| } |
| } |
| |
| func TestPathForBazelOutRelative(t *testing.T) { |
| ctx := &TestBazelPathContext{} |
| out := PathForBazelOutRelative(ctx, "foo/bar", "foo/bar/baz/boq.txt") |
| |
| expectedPath := filepath.Join(ctx.Config().BazelContext.OutputBase(), "execroot/__main__/foo/bar/baz/boq.txt") |
| if out.String() != expectedPath { |
| t.Errorf("incorrect OutputPath: expected %q, got %q", expectedPath, out.String()) |
| } |
| |
| expectedRelPath := "baz/boq.txt" |
| if out.Rel() != expectedRelPath { |
| t.Errorf("incorrect OutputPath.Rel(): expected %q, got %q", expectedRelPath, out.Rel()) |
| } |
| } |
| |
| func TestPathForBazelOutRelativeUnderBinFolder(t *testing.T) { |
| ctx := &TestBazelPathContext{} |
| out := PathForBazelOutRelative(ctx, "foo/bar", "bazel-out/linux_x86_64-fastbuild-ST-b4ef1c4402f9/bin/foo/bar/baz/boq.txt") |
| |
| expectedPath := filepath.Join(ctx.Config().BazelContext.OutputBase(), "execroot/__main__/bazel-out/linux_x86_64-fastbuild-ST-b4ef1c4402f9/bin/foo/bar/baz/boq.txt") |
| if out.String() != expectedPath { |
| t.Errorf("incorrect OutputPath: expected %q, got %q", expectedPath, out.String()) |
| } |
| |
| expectedRelPath := "baz/boq.txt" |
| if out.Rel() != expectedRelPath { |
| t.Errorf("incorrect OutputPath.Rel(): expected %q, got %q", expectedRelPath, out.Rel()) |
| } |
| } |
| |
| func TestPathForBazelOutOutsideOfExecroot(t *testing.T) { |
| ctx := &TestBazelPathContext{} |
| out := PathForBazelOut(ctx, "../bazel_tools/linux_x86_64-fastbuild/bin/tools/android/java_base_extras.jar") |
| |
| expectedPath := filepath.Join(ctx.Config().BazelContext.OutputBase(), "execroot/bazel_tools/linux_x86_64-fastbuild/bin/tools/android/java_base_extras.jar") |
| if out.String() != expectedPath { |
| t.Errorf("incorrect OutputPath: expected %q, got %q", expectedPath, out.String()) |
| } |
| |
| expectedRelPath := "execroot/bazel_tools/linux_x86_64-fastbuild/bin/tools/android/java_base_extras.jar" |
| if out.Rel() != expectedRelPath { |
| t.Errorf("incorrect OutputPath.Rel(): expected %q, got %q", expectedRelPath, out.Rel()) |
| } |
| } |
| |
| func TestPathForBazelOutRelativeWithParentDirectoryRoot(t *testing.T) { |
| ctx := &TestBazelPathContext{} |
| out := PathForBazelOutRelative(ctx, "../bazel_tools", "../bazel_tools/foo/bar/baz.sh") |
| |
| expectedPath := filepath.Join(ctx.Config().BazelContext.OutputBase(), "execroot/bazel_tools/foo/bar/baz.sh") |
| if out.String() != expectedPath { |
| t.Errorf("incorrect OutputPath: expected %q, got %q", expectedPath, out.String()) |
| } |
| |
| expectedRelPath := "foo/bar/baz.sh" |
| if out.Rel() != expectedRelPath { |
| t.Errorf("incorrect OutputPath.Rel(): expected %q, got %q", expectedRelPath, out.Rel()) |
| } |
| } |
| |
| type TestBazelConversionPathContext struct { |
| TestBazelConversionContext |
| moduleDir string |
| cfg Config |
| } |
| |
| func (ctx *TestBazelConversionPathContext) AddNinjaFileDeps(...string) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) GlobWithDeps(string, []string) ([]string, error) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) PropertyErrorf(string, string, ...interface{}) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) GetDirectDep(string) (blueprint.Module, blueprint.DependencyTag) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) ModuleFromName(string) (blueprint.Module, bool) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) AddUnconvertedBp2buildDep(string) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) AddMissingBp2buildDep(string) { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) Module() Module { |
| panic("Unimplemented") |
| } |
| |
| func (ctx *TestBazelConversionPathContext) Config() Config { |
| return ctx.cfg |
| } |
| |
| func (ctx *TestBazelConversionPathContext) ModuleDir() string { |
| return ctx.moduleDir |
| } |
| |
| func TestTransformSubpackagePath(t *testing.T) { |
| cfg := NullConfig("out", "out/soong") |
| cfg.fs = pathtools.MockFs(map[string][]byte{ |
| "x/Android.bp": nil, |
| "x/y/Android.bp": nil, |
| }) |
| |
| var ctx BazelConversionPathContext = &TestBazelConversionPathContext{ |
| moduleDir: "x", |
| cfg: cfg, |
| } |
| pairs := map[string]string{ |
| "y/a.c": "//x/y:a.c", |
| "./y/a.c": "//x/y:a.c", |
| "z/b.c": "z/b.c", |
| "./z/b.c": "z/b.c", |
| } |
| for in, out := range pairs { |
| actual := transformSubpackagePath(ctx, bazel.Label{Label: in}).Label |
| if actual != out { |
| t.Errorf("expected:\n%v\nactual:\n%v", out, actual) |
| } |
| } |
| } |