blob: 789344601e46323946feb990e6ecaeace27f96c1 [file] [log] [blame]
// Copyright 2024 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package testfiles_test
import (
"fmt"
"os"
"path/filepath"
"testing"
"golang.org/x/tools/go/analysis"
"golang.org/x/tools/go/analysis/analysistest"
"golang.org/x/tools/internal/testenv"
"golang.org/x/tools/internal/testfiles"
"golang.org/x/tools/internal/versions"
"golang.org/x/tools/txtar"
)
func TestTestDir(t *testing.T) {
testenv.NeedsGo1Point(t, 23)
// Files are initially {go.mod.test,sub.test/sub.go.test}.
fs := os.DirFS(filepath.Join(analysistest.TestData(), "versions"))
tmpdir := testfiles.CopyToTmp(t, fs,
"go.mod.test,go.mod", // After: {go.mod,sub.test/sub.go.test}
"sub.test/sub.go.test,sub.test/abc", // After: {go.mod,sub.test/abc}
"sub.test,sub", // After: {go.mod,sub/abc}
"sub/abc,sub/sub.go", // After: {go.mod,sub/sub.go}
)
filever := &analysis.Analyzer{
Name: "filever",
Doc: "reports file go versions",
Run: func(pass *analysis.Pass) (any, error) {
for _, file := range pass.Files {
ver := versions.FileVersion(pass.TypesInfo, file)
name := filepath.Base(pass.Fset.Position(file.Package).Filename)
pass.Reportf(file.Package, "%s@%s", name, ver)
}
return nil, nil
},
}
res := analysistest.Run(t, tmpdir, filever, "golang.org/fake/versions", "golang.org/fake/versions/sub")
got := 0
for _, r := range res {
got += len(r.Diagnostics)
}
if want := 4; got != want {
t.Errorf("Got %d diagnostics. wanted %d", got, want)
}
}
func TestTestDirErrors(t *testing.T) {
const input = `
-- one.txt --
one
`
// Files are initially {go.mod.test,sub.test/sub.go.test}.
fs, err := txtar.FS(txtar.Parse([]byte(input)))
if err != nil {
t.Fatal(err)
}
directive := "no comma to split on"
intercept := &fatalIntercept{t, nil}
func() {
defer func() { // swallow panics from fatalIntercept.Fatal
if r := recover(); r != intercept {
panic(r)
}
}()
testfiles.CopyToTmp(intercept, fs, directive)
}()
got := fmt.Sprint(intercept.fatalfs)
want := `[rename directive "no comma to split on" does not contain delimiter ","]`
if got != want {
t.Errorf("CopyToTmp(%q) had the Fatal messages %q. wanted %q", directive, got, want)
}
}
// helper for TestTestDirErrors
type fatalIntercept struct {
testing.TB
fatalfs []string
}
func (i *fatalIntercept) Fatalf(format string, args ...any) {
i.fatalfs = append(i.fatalfs, fmt.Sprintf(format, args...))
// Do not mark the test as failing, but fail early.
panic(i)
}