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