...
Text file
src/cmd/go/testdata/script/goroot_executable_trimpath.txt
1# Regression test for https://go.dev/issue/62119:
2# A 'go' command cross-compiled with a different GOHOSTOS
3# should be able to locate its GOROOT using os.Executable.
4#
5# (This also tests a 'go' command built with -trimpath
6# that is not cross-compiled, since we need to build that
7# configuration for the test anyway.)
8
9[short] skip 'builds and links another cmd/go'
10
11mkdir $WORK/new/bin
12mkdir $WORK/new/bin/${GOOS}_${GOARCH}
13
14# In this test, we are specifically checking the logic for deriving
15# the value of GOROOT from os.Executable when runtime.GOROOT is
16# trimmed away.
17# GOROOT_FINAL changes the default behavior of runtime.GOROOT,
18# so we explicitly clear it to remove it as a confounding variable.
19env GOROOT_FINAL=
20
21# $GOROOT/bin/go is whatever the user has already installed
22# (using make.bash or similar). We can't make assumptions about what
23# options it may have been built with, such as -trimpath or GOROOT_FINAL.
24# Instead, we build a fresh copy of the binary with known settings.
25go build -trimpath -o $WORK/new/bin/go$GOEXE cmd/go &
26go build -trimpath -o $WORK/bin/check$GOEXE check.go &
27wait
28
29env TESTGOROOT=$GOROOT
30env GOROOT=
31
32# Unset GOPATH and any variables that its default may be derived from,
33# so that we can check for a spurious warning.
34env GOPATH=
35env HOME=''
36env USERPROFILE=''
37env home=''
38
39# Relocated Executable
40# Since we built with -trimpath and the binary isn't installed in a
41# normal-looking GOROOT, this command should fail.
42
43! exec $WORK/new/bin/go$GOEXE env GOROOT
44stderr '^go: cannot find GOROOT directory: ''go'' binary is trimmed and GOROOT is not set$'
45! stderr 'GOPATH set to GOROOT'
46
47# Cross-compiled binaries in cmd are installed to a ${GOOS}_${GOARCH} subdirectory,
48# so we also want to try a copy there.
49# (Note that the script engine's 'exec' engine already works around
50# https://go.dev/issue/22315, so we don't have to do that explicitly in the
51# 'check' program we use later.)
52cp $WORK/new/bin/go$GOEXE $WORK/new/bin/${GOOS}_${GOARCH}/go$GOEXE
53! exec $WORK/new/bin/${GOOS}_${GOARCH}/go$GOEXE env GOROOT
54stderr '^go: cannot find GOROOT directory: ''go'' binary is trimmed and GOROOT is not set$'
55! stderr 'GOPATH set to GOROOT'
56
57# Relocated Tree:
58# If the binary is sitting in a bin dir next to ../pkg/tool, that counts as a GOROOT,
59# so it should find the new tree.
60mkdir $WORK/new/pkg/tool
61exec $WORK/bin/check$GOEXE $WORK/new/bin/go$GOEXE $WORK/new
62exec $WORK/bin/check$GOEXE $WORK/new/bin/${GOOS}_${GOARCH}/go$GOEXE $WORK/new
63! stderr 'GOPATH set to GOROOT'
64
65-- check.go --
66package main
67
68import (
69 "fmt"
70 "os"
71 "os/exec"
72 "path/filepath"
73 "strings"
74)
75
76func main() {
77 exe := os.Args[1]
78 want := os.Args[2]
79 cmd := exec.Command(exe, "env", "GOROOT")
80 out, err := cmd.CombinedOutput()
81 if err != nil {
82 fmt.Fprintf(os.Stderr, "%s env GOROOT: %v, %s\n", exe, err, out)
83 os.Exit(1)
84 }
85 goroot, err := filepath.EvalSymlinks(strings.TrimSpace(string(out)))
86 if err != nil {
87 fmt.Fprintln(os.Stderr, err)
88 os.Exit(1)
89 }
90 want, err = filepath.EvalSymlinks(want)
91 if err != nil {
92 fmt.Fprintln(os.Stderr, err)
93 os.Exit(1)
94 }
95 if !strings.EqualFold(goroot, want) {
96 fmt.Fprintf(os.Stderr, "go env GOROOT:\nhave %s\nwant %s\n", goroot, want)
97 os.Exit(1)
98 }
99 fmt.Fprintf(os.Stderr, "go env GOROOT: %s\n", goroot)
100
101}
View as plain text