|  | // Copyright 2020 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 bp2build | 
|  |  | 
|  | import ( | 
|  | "sort" | 
|  | "testing" | 
|  |  | 
|  | "android/soong/android" | 
|  | ) | 
|  |  | 
|  | type bazelFilepath struct { | 
|  | dir      string | 
|  | basename string | 
|  | } | 
|  |  | 
|  | func TestCreateBazelFiles_QueryView_AddsTopLevelFiles(t *testing.T) { | 
|  | files := CreateBazelFiles(map[string]RuleShim{}, map[string]BazelTargets{}, QueryView) | 
|  | expectedFilePaths := []bazelFilepath{ | 
|  | { | 
|  | dir:      "", | 
|  | basename: "BUILD.bazel", | 
|  | }, | 
|  | { | 
|  | dir:      "", | 
|  | basename: "WORKSPACE", | 
|  | }, | 
|  | { | 
|  | dir:      bazelRulesSubDir, | 
|  | basename: "BUILD.bazel", | 
|  | }, | 
|  | { | 
|  | dir:      bazelRulesSubDir, | 
|  | basename: "providers.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      bazelRulesSubDir, | 
|  | basename: "soong_module.bzl", | 
|  | }, | 
|  | } | 
|  |  | 
|  | // Compare number of files | 
|  | if a, e := len(files), len(expectedFilePaths); a != e { | 
|  | t.Errorf("Expected %d files, got %d", e, a) | 
|  | } | 
|  |  | 
|  | // Sort the files to be deterministic | 
|  | sort.Slice(files, func(i, j int) bool { | 
|  | if dir1, dir2 := files[i].Dir, files[j].Dir; dir1 == dir2 { | 
|  | return files[i].Basename < files[j].Basename | 
|  | } else { | 
|  | return dir1 < dir2 | 
|  | } | 
|  | }) | 
|  |  | 
|  | // Compare the file contents | 
|  | for i := range files { | 
|  | actualFile, expectedFile := files[i], expectedFilePaths[i] | 
|  |  | 
|  | if actualFile.Dir != expectedFile.dir || actualFile.Basename != expectedFile.basename { | 
|  | t.Errorf("Did not find expected file %s/%s", actualFile.Dir, actualFile.Basename) | 
|  | } else if actualFile.Basename == "BUILD.bazel" || actualFile.Basename == "WORKSPACE" { | 
|  | if actualFile.Contents != "" { | 
|  | t.Errorf("Expected %s to have no content.", actualFile) | 
|  | } | 
|  | } else if actualFile.Contents == "" { | 
|  | t.Errorf("Contents of %s unexpected empty.", actualFile) | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | func TestCreateBazelFiles_Bp2Build_CreatesDefaultFiles(t *testing.T) { | 
|  | testConfig := android.TestConfig("", make(map[string]string), "", make(map[string][]byte)) | 
|  | codegenCtx := NewCodegenContext(testConfig, android.NewTestContext(testConfig).Context, Bp2Build, "") | 
|  | files, err := createSoongInjectionDirFiles(codegenCtx, CreateCodegenMetrics()) | 
|  | if err != nil { | 
|  | t.Error(err) | 
|  | } | 
|  | expectedFilePaths := []bazelFilepath{ | 
|  | { | 
|  | dir:      "android", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "android", | 
|  | basename: "constants.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "cc_toolchain", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "cc_toolchain", | 
|  | basename: "config_constants.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "cc_toolchain", | 
|  | basename: "sanitizer_constants.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "java_toolchain", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "java_toolchain", | 
|  | basename: "constants.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "rust_toolchain", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "rust_toolchain", | 
|  | basename: "constants.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "apex_toolchain", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "apex_toolchain", | 
|  | basename: "constants.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "metrics", | 
|  | basename: "converted_modules.json", | 
|  | }, | 
|  | { | 
|  | dir:      "metrics", | 
|  | basename: "BUILD.bazel", | 
|  | }, | 
|  | { | 
|  | dir:      "metrics", | 
|  | basename: "converted_modules_path_map.json", | 
|  | }, | 
|  | { | 
|  | dir:      "metrics", | 
|  | basename: "converted_modules_path_map.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "product_config", | 
|  | basename: "soong_config_variables.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "product_config", | 
|  | basename: "arch_configuration.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "api_levels", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "api_levels", | 
|  | basename: "api_levels.json", | 
|  | }, | 
|  | { | 
|  | dir:      "api_levels", | 
|  | basename: "platform_versions.bzl", | 
|  | }, | 
|  | { | 
|  | dir:      "allowlists", | 
|  | basename: GeneratedBuildFileName, | 
|  | }, | 
|  | { | 
|  | dir:      "allowlists", | 
|  | basename: "mixed_build_prod_allowlist.txt", | 
|  | }, | 
|  | { | 
|  | dir:      "allowlists", | 
|  | basename: "mixed_build_staging_allowlist.txt", | 
|  | }, | 
|  | } | 
|  |  | 
|  | less := func(a bazelFilepath, b bazelFilepath) bool { | 
|  | return a.dir+"/"+a.basename < b.dir+"/"+b.basename | 
|  | } | 
|  |  | 
|  | fileToFilepath := func(a BazelFile) bazelFilepath { | 
|  | return bazelFilepath{basename: a.Basename, dir: a.Dir} | 
|  | } | 
|  |  | 
|  | sort.Slice(expectedFilePaths, func(i, j int) bool { | 
|  | return less(expectedFilePaths[i], expectedFilePaths[j]) | 
|  | }) | 
|  | sort.Slice(files, func(i, j int) bool { | 
|  | return less(fileToFilepath(files[i]), fileToFilepath(files[j])) | 
|  | }) | 
|  |  | 
|  | i := 0 | 
|  | j := 0 | 
|  | for i < len(expectedFilePaths) && j < len(files) { | 
|  | expectedFile, actualFile := expectedFilePaths[i], files[j] | 
|  |  | 
|  | if actualFile.Dir == expectedFile.dir && actualFile.Basename == expectedFile.basename { | 
|  | i++ | 
|  | j++ | 
|  | } else if less(expectedFile, fileToFilepath(actualFile)) { | 
|  | t.Errorf("Did not find expected file %s/%s", expectedFile.dir, expectedFile.basename) | 
|  | i++ | 
|  | } else { | 
|  | t.Errorf("Found unexpected file %s/%s", actualFile.Dir, actualFile.Basename) | 
|  | j++ | 
|  | } | 
|  | } | 
|  | for i < len(expectedFilePaths) { | 
|  | expectedFile := expectedFilePaths[i] | 
|  | t.Errorf("Did not find expected file %s/%s", expectedFile.dir, expectedFile.basename) | 
|  | i++ | 
|  | } | 
|  | for j < len(files) { | 
|  | actualFile := files[j] | 
|  | t.Errorf("Found unexpected file %s/%s", actualFile.Dir, actualFile.Basename) | 
|  | j++ | 
|  | } | 
|  | } |