blob: 57726e80dfabced98e75b2f2cb0ecc75a4837058 [file] [log] [blame]
/* Copyright 2023 The Bazel Authors. 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 generationtest
import (
"flag"
"io/fs"
"path/filepath"
"strings"
"testing"
"time"
"github.com/bazelbuild/bazel-gazelle/testtools"
"github.com/bazelbuild/rules_go/go/runfiles"
)
var (
gazelleBinaryPath = flag.String("gazelle_binary_path", "", "rlocationpath to the gazelle binary to test.")
buildInSuffix = flag.String("build_in_suffix", ".in", "The suffix on the test input BUILD.bazel files. Defaults to .in. "+
" By default, will use files named BUILD.in as the BUILD files before running gazelle.")
buildOutSuffix = flag.String("build_out_suffix", ".out", "The suffix on the expected BUILD.bazel files after running gazelle. Defaults to .out. "+
" By default, will use files named BUILD.out as the expected results of the gazelle run.")
timeout = flag.Duration("timeout", 2*time.Second, "Time to allow the gazelle process to run before killing.")
)
// TestFullGeneration runs the gazelle binary on a few example
// workspaces and confirms that the generated BUILD files match expectation.
func TestFullGeneration(t *testing.T) {
tests := []*testtools.TestGazelleGenerationArgs{}
relativeGazelleBinary, err := runfiles.Rlocation(*gazelleBinaryPath)
if err != nil {
t.Fatalf("Failed to find gazelle binary %s. Error: %v", *gazelleBinaryPath, err)
}
absoluteGazelleBinary, err := filepath.Abs(relativeGazelleBinary)
if err != nil {
t.Fatalf("Could not convert gazelle binary path %s to absolute path. Error: %v", relativeGazelleBinary, err)
}
testNames := map[string]struct{}{}
runfilesFS, err := runfiles.New()
if err != nil {
t.Fatalf("Failed to create runfiles filesystem. Error: %v", err)
}
err = fs.WalkDir(runfilesFS, ".", func(path string, d fs.DirEntry, err error) error {
if err != nil {
return err
}
if d.IsDir() {
return nil
}
if d.Name() == "WORKSPACE" || d.Name() == "MODULE.bazel" {
actualFilePath, err := runfiles.Rlocation(path)
if err != nil {
t.Fatalf("Failed to find runfile %s. Error: %v", path, err)
}
// absolutePathToTestDirectory is the absolute
// path to the test case directory. For example, /home/<user>/wksp/path/to/test_data/my_test_case
absolutePathToTestDirectory := filepath.Dir(actualFilePath)
// relativePathToTestDirectory is the workspace relative path
// to this test case directory. For example, path/to/test_data/my_test_case
relativePathToTestDirectory := filepath.Dir(path[strings.IndexRune(path, '/')+1:])
// name is the name of the test directory. For example, my_test_case.
// The name of the directory doubles as the name of the test.
name := filepath.Base(absolutePathToTestDirectory)
// Don't add a test if it was already added. That could be the case if a directory has
// both a WORKSPACE and a MODULE.bazel file in it, or due to multiple apparent names
// mapping to the same canonical name.
if _, exists := testNames[name]; !exists {
testNames[name] = struct{}{}
tests = append(tests, &testtools.TestGazelleGenerationArgs{
Name: name,
TestDataPathAbsolute: absolutePathToTestDirectory,
TestDataPathRelative: relativePathToTestDirectory,
GazelleBinaryPath: absoluteGazelleBinary,
BuildInSuffix: *buildInSuffix,
BuildOutSuffix: *buildOutSuffix,
Timeout: *timeout,
})
}
return fs.SkipDir
}
return nil
})
if err != nil {
t.Fatalf("Failed to walk runfiles. Error: %v", err)
}
if len(tests) == 0 {
t.Fatal("no tests found")
}
for _, args := range tests {
testtools.TestGazelleGenerationOnPath(t, args)
}
}