You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
garble/testdata/script/gotoolchain.txtar

46 lines
1.3 KiB
Plaintext

# We want the upgraded toolchain to match the garble binary
# which we will exec below, as otherwise garble will complain.
# Tell GOTOOLCHAIN to upgrade to the same version thanks to `go mod init`
# setting up a `go` directive with its Go version.
cd mod
go mod init test
exec cat go.mod
cd ..
go env GOVERSION
setenvfile GOVERSION_UPGRADE stdout
# To test that garble works with transparent upgrades via GOTOOLCHAIN,
# use a relatively old version, but still new enough to support GOTOOLCHAIN.
env GOVERSION_BASE=go1.23.0
setup-go ${GOVERSION_BASE}
# We want to use the real GOPROXY so that we can download the newer
# toolchain, and we use the host's GOMODCACHE so we can reuse it.
env GOPROXY=proxy.golang.org
env GOMODCACHE=${HOST_GOMODCACHE}
# Verify that we are using an older version of Go.
exec go version
stdout 'go version '${GOVERSION_BASE@R}
# The builds inside the module use the upgraded toolchain.
cd mod
exec go run .
stderr 'hello from '${GOVERSION_UPGRADE@R}
# Note that garble hides runtime.Version by design, but we know that it requires
# the Go toolchain version to match the exact same version that built garble,
# and that version is most likely newer than GOVERSION_BASE.
exec garble run .
stderr 'hello from unknown'
-- mod/main.go --
package main
import "runtime"
func main() {
println("hello from", runtime.Version())
}