// 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++ } }