mirror of
https://github.com/golang/go
synced 2024-11-26 19:51:17 -07:00
cmd/go: resolve std-vendored dependencies as std packages except in 'go get' and 'go mod'
In CL 251159, I removed a hard-coded special case changing the rewriting behavior for std dependencies in GOROOT/src/vendor and GOROOT/src/cmd/vendor. Unfortunately, that caused packages in 'std' to be reported as stale when run within GOROOT/src. This change restores the special-case behavior, but plumbs it through the PackageOpts explicitly instead of comparing strings stored in global variables. Fixes #44725 Change-Id: If084fe74972ce1704715ca79b0b7e092dd90c88b Reviewed-on: https://go-review.googlesource.com/c/go/+/297869 Trust: Bryan C. Mills <bcmills@google.com> Run-TryBot: Bryan C. Mills <bcmills@google.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Jay Conrod <jayconrod@google.com>
This commit is contained in:
parent
09f4ef4fa7
commit
e9eed78dc3
@ -62,10 +62,11 @@ func runTidy(ctx context.Context, cmd *base.Command, args []string) {
|
|||||||
modload.RootMode = modload.NeedRoot
|
modload.RootMode = modload.NeedRoot
|
||||||
|
|
||||||
modload.LoadPackages(ctx, modload.PackageOpts{
|
modload.LoadPackages(ctx, modload.PackageOpts{
|
||||||
Tags: imports.AnyTags(),
|
Tags: imports.AnyTags(),
|
||||||
ResolveMissingImports: true,
|
VendorModulesInGOROOTSrc: true,
|
||||||
LoadTests: true,
|
ResolveMissingImports: true,
|
||||||
AllowErrors: tidyE,
|
LoadTests: true,
|
||||||
|
AllowErrors: tidyE,
|
||||||
}, "all")
|
}, "all")
|
||||||
|
|
||||||
modload.TidyBuildList()
|
modload.TidyBuildList()
|
||||||
|
@ -64,10 +64,11 @@ func runVendor(ctx context.Context, cmd *base.Command, args []string) {
|
|||||||
modload.RootMode = modload.NeedRoot
|
modload.RootMode = modload.NeedRoot
|
||||||
|
|
||||||
loadOpts := modload.PackageOpts{
|
loadOpts := modload.PackageOpts{
|
||||||
Tags: imports.AnyTags(),
|
Tags: imports.AnyTags(),
|
||||||
ResolveMissingImports: true,
|
VendorModulesInGOROOTSrc: true,
|
||||||
UseVendorAll: true,
|
ResolveMissingImports: true,
|
||||||
AllowErrors: vendorE,
|
UseVendorAll: true,
|
||||||
|
AllowErrors: vendorE,
|
||||||
}
|
}
|
||||||
_, pkgs := modload.LoadPackages(ctx, loadOpts, "all")
|
_, pkgs := modload.LoadPackages(ctx, loadOpts, "all")
|
||||||
|
|
||||||
|
@ -68,10 +68,11 @@ func runWhy(ctx context.Context, cmd *base.Command, args []string) {
|
|||||||
modload.RootMode = modload.NeedRoot
|
modload.RootMode = modload.NeedRoot
|
||||||
|
|
||||||
loadOpts := modload.PackageOpts{
|
loadOpts := modload.PackageOpts{
|
||||||
Tags: imports.AnyTags(),
|
Tags: imports.AnyTags(),
|
||||||
LoadTests: !*whyVendor,
|
VendorModulesInGOROOTSrc: true,
|
||||||
SilenceErrors: true,
|
LoadTests: !*whyVendor,
|
||||||
UseVendorAll: *whyVendor,
|
SilenceErrors: true,
|
||||||
|
UseVendorAll: *whyVendor,
|
||||||
}
|
}
|
||||||
|
|
||||||
if *whyM {
|
if *whyM {
|
||||||
|
@ -1120,9 +1120,10 @@ func (r *resolver) findAndUpgradeImports(ctx context.Context, queries []*query)
|
|||||||
// build list.
|
// build list.
|
||||||
func (r *resolver) loadPackages(ctx context.Context, patterns []string, findPackage func(ctx context.Context, path string, m module.Version) (versionOk bool)) {
|
func (r *resolver) loadPackages(ctx context.Context, patterns []string, findPackage func(ctx context.Context, path string, m module.Version) (versionOk bool)) {
|
||||||
opts := modload.PackageOpts{
|
opts := modload.PackageOpts{
|
||||||
Tags: imports.AnyTags(),
|
Tags: imports.AnyTags(),
|
||||||
LoadTests: *getT,
|
VendorModulesInGOROOTSrc: true,
|
||||||
SilenceErrors: true, // May be fixed by subsequent upgrades or downgrades.
|
LoadTests: *getT,
|
||||||
|
SilenceErrors: true, // May be fixed by subsequent upgrades or downgrades.
|
||||||
}
|
}
|
||||||
|
|
||||||
opts.AllowPackage = func(ctx context.Context, path string, m module.Version) error {
|
opts.AllowPackage = func(ctx context.Context, path string, m module.Version) error {
|
||||||
@ -1459,9 +1460,10 @@ func (r *resolver) checkPackagesAndRetractions(ctx context.Context, pkgPatterns
|
|||||||
// LoadPackages will print errors (since it has more context) but will not
|
// LoadPackages will print errors (since it has more context) but will not
|
||||||
// exit, since we need to load retractions later.
|
// exit, since we need to load retractions later.
|
||||||
pkgOpts := modload.PackageOpts{
|
pkgOpts := modload.PackageOpts{
|
||||||
LoadTests: *getT,
|
VendorModulesInGOROOTSrc: true,
|
||||||
ResolveMissingImports: false,
|
LoadTests: *getT,
|
||||||
AllowErrors: true,
|
ResolveMissingImports: false,
|
||||||
|
AllowErrors: true,
|
||||||
}
|
}
|
||||||
matches, pkgs := modload.LoadPackages(ctx, pkgOpts, pkgPatterns...)
|
matches, pkgs := modload.LoadPackages(ctx, pkgOpts, pkgPatterns...)
|
||||||
for _, m := range matches {
|
for _, m := range matches {
|
||||||
|
@ -134,6 +134,11 @@ type PackageOpts struct {
|
|||||||
// If nil, treated as equivalent to imports.Tags().
|
// If nil, treated as equivalent to imports.Tags().
|
||||||
Tags map[string]bool
|
Tags map[string]bool
|
||||||
|
|
||||||
|
// VendorModulesInGOROOTSrc indicates that if we are within a module in
|
||||||
|
// GOROOT/src, packages in the module's vendor directory should be resolved as
|
||||||
|
// actual module dependencies (instead of standard-library packages).
|
||||||
|
VendorModulesInGOROOTSrc bool
|
||||||
|
|
||||||
// ResolveMissingImports indicates that we should attempt to add module
|
// ResolveMissingImports indicates that we should attempt to add module
|
||||||
// dependencies as needed to resolve imports of packages that are not found.
|
// dependencies as needed to resolve imports of packages that are not found.
|
||||||
//
|
//
|
||||||
@ -1170,13 +1175,13 @@ func (ld *loader) stdVendor(parentPath, path string) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if str.HasPathPrefix(parentPath, "cmd") {
|
if str.HasPathPrefix(parentPath, "cmd") {
|
||||||
if Target.Path != "cmd" {
|
if !ld.VendorModulesInGOROOTSrc || Target.Path != "cmd" {
|
||||||
vendorPath := pathpkg.Join("cmd", "vendor", path)
|
vendorPath := pathpkg.Join("cmd", "vendor", path)
|
||||||
if _, err := os.Stat(filepath.Join(cfg.GOROOTsrc, filepath.FromSlash(vendorPath))); err == nil {
|
if _, err := os.Stat(filepath.Join(cfg.GOROOTsrc, filepath.FromSlash(vendorPath))); err == nil {
|
||||||
return vendorPath
|
return vendorPath
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if Target.Path != "std" || str.HasPathPrefix(parentPath, "vendor") {
|
} else if !ld.VendorModulesInGOROOTSrc || Target.Path != "std" || str.HasPathPrefix(parentPath, "vendor") {
|
||||||
// If we are outside of the 'std' module, resolve imports from within 'std'
|
// If we are outside of the 'std' module, resolve imports from within 'std'
|
||||||
// to the vendor directory.
|
// to the vendor directory.
|
||||||
//
|
//
|
||||||
|
31
src/cmd/go/testdata/script/list_std_stale.txt
vendored
Normal file
31
src/cmd/go/testdata/script/list_std_stale.txt
vendored
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
# https://golang.org/issue/44725: packages in std should not be reported as stale,
|
||||||
|
# regardless of whether they are listed from within or outside GOROOT/src.
|
||||||
|
|
||||||
|
# Control case: net should not be stale at the start of the test,
|
||||||
|
# and should depend on vendor/golang.org/… instead of golang.org/….
|
||||||
|
|
||||||
|
! stale net
|
||||||
|
|
||||||
|
go list -deps net
|
||||||
|
stdout '^vendor/golang.org/x/net'
|
||||||
|
! stdout '^golang.org/x/net'
|
||||||
|
|
||||||
|
# Net should also not be stale when viewed from within GOROOT/src,
|
||||||
|
# and should still report the same package dependencies.
|
||||||
|
|
||||||
|
cd $GOROOT/src
|
||||||
|
! stale net
|
||||||
|
|
||||||
|
go list -deps net
|
||||||
|
stdout '^vendor/golang.org/x/net'
|
||||||
|
! stdout '^golang.org/x/net'
|
||||||
|
|
||||||
|
|
||||||
|
# However, 'go mod' and 'go get' subcommands should report the original module
|
||||||
|
# dependencies, not the vendored packages.
|
||||||
|
|
||||||
|
[!net] stop
|
||||||
|
|
||||||
|
env GOPROXY=
|
||||||
|
go mod why -m golang.org/x/net
|
||||||
|
stdout '^# golang.org/x/net\nnet\ngolang.org/x/net'
|
14
src/cmd/go/testdata/script/mod_list_std.txt
vendored
14
src/cmd/go/testdata/script/mod_list_std.txt
vendored
@ -48,18 +48,20 @@ stdout ^vendor/golang.org/x/crypto/internal/subtle
|
|||||||
! stdout ^golang\.org/x
|
! stdout ^golang\.org/x
|
||||||
|
|
||||||
# Within the std module, the dependencies of the non-vendored packages within
|
# Within the std module, the dependencies of the non-vendored packages within
|
||||||
# std should appear to come from modules, but they should be loaded from the
|
# std should appear to be packages beginning with 'vendor/', not 'golang.org/…'
|
||||||
# vendor directory (just like ordinary vendored module dependencies).
|
# module dependencies.
|
||||||
|
|
||||||
go list all
|
go list all
|
||||||
stdout ^golang.org/x/
|
! stdout ^golang.org/x/
|
||||||
! stdout ^std/
|
! stdout ^std/
|
||||||
! stdout ^cmd/
|
! stdout ^cmd/
|
||||||
! stdout ^vendor/
|
stdout ^vendor/
|
||||||
|
|
||||||
go list -deps -f '{{if not .Standard}}{{.ImportPath}}{{end}}' std
|
go list -deps -f '{{if not .Standard}}{{.ImportPath}}{{end}}' std
|
||||||
! stdout ^vendor/golang.org/x/net/http2/hpack
|
! stdout .
|
||||||
stdout ^golang.org/x/net/http2/hpack
|
|
||||||
|
# However, the 'golang.org/…' module dependencies should resolve to those same
|
||||||
|
# directories.
|
||||||
|
|
||||||
go list -f '{{.Dir}}' golang.org/x/net/http2/hpack
|
go list -f '{{.Dir}}' golang.org/x/net/http2/hpack
|
||||||
stdout $GOROOT[/\\]src[/\\]vendor
|
stdout $GOROOT[/\\]src[/\\]vendor
|
||||||
|
@ -36,11 +36,11 @@ stderr 'use of vendored package'
|
|||||||
|
|
||||||
|
|
||||||
# When run within the 'std' module, 'go list -test' should report vendored
|
# When run within the 'std' module, 'go list -test' should report vendored
|
||||||
# transitive dependencies at their original module paths.
|
# transitive dependencies at their vendored paths.
|
||||||
cd $GOROOT/src
|
cd $GOROOT/src
|
||||||
go list -test -f '{{range .Deps}}{{.}}{{"\n"}}{{end}}' net/http
|
go list -test -f '{{range .Deps}}{{.}}{{"\n"}}{{end}}' net/http
|
||||||
stdout ^golang.org/x/net/http2/hpack
|
! stdout ^golang.org/x/net/http2/hpack
|
||||||
! stdout ^vendor/golang.org/x/net/http2/hpack
|
stdout ^vendor/golang.org/x/net/http2/hpack
|
||||||
|
|
||||||
-- go.mod --
|
-- go.mod --
|
||||||
module m
|
module m
|
||||||
|
Loading…
Reference in New Issue
Block a user