Skip to content

Commit

Permalink
tailscaleroot: panic if tailscale_go build tag but Go toolchain mismatch
Browse files Browse the repository at this point in the history
Fixes #13527

Change-Id: I05921969a84a303b60d1b3b9227aff9865662831
  • Loading branch information
bradfitz committed Oct 6, 2024
1 parent c48cc08 commit 23f41ae
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 10 deletions.
27 changes: 27 additions & 0 deletions assert_ts_toolchain_match.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
// Copyright (c) Tailscale Inc & AUTHORS
// SPDX-License-Identifier: BSD-3-Clause

//go:build tailscale_go

package tailscaleroot

import (
"fmt"
"os"
"strings"
)

func init() {
tsRev, ok := tailscaleToolchainRev()
if !ok {
panic("binary built with tailscale_go build tag but failed to read build info or find tailscale.toolchain.rev in build info")
}
want := strings.TrimSpace(GoToolchainRev)
if tsRev != want {
if os.Getenv("TS_PERMIT_TOOLCHAIN_MISMATCH") == "1" {
fmt.Fprintf(os.Stderr, "tailscale.toolchain.rev = %q, want %q; but ignoring due to TS_PERMIT_TOOLCHAIN_MISMATCH=1\n", tsRev, want)
return
}
panic(fmt.Sprintf("binary built with tailscale_go build tag but Go toolchain %q doesn't match github.com/tailscale/tailscale expected value %q; override this failure with TS_PERMIT_TOOLCHAIN_MISMATCH=1", tsRev, want))
}
}
18 changes: 17 additions & 1 deletion version-embed.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,10 @@
// Package tailscaleroot embeds VERSION.txt into the binary.
package tailscaleroot

import _ "embed"
import (
_ "embed"
"runtime/debug"
)

// VersionDotTxt is the contents of VERSION.txt. Despite the tempting filename,
// this does not necessarily contain the accurate version number of the build, which
Expand All @@ -22,3 +25,16 @@ var AlpineDockerTag string
//
//go:embed go.toolchain.rev
var GoToolchainRev string

func tailscaleToolchainRev() (gitHash string, ok bool) {
bi, ok := debug.ReadBuildInfo()
if !ok {
return "", false
}
for _, s := range bi.Settings {
if s.Key == "tailscale.toolchain.rev" {
return s.Value, true
}
}
return "", false
}
10 changes: 1 addition & 9 deletions version_tailscale_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,23 +7,15 @@ package tailscaleroot

import (
"os"
"runtime/debug"
"strings"
"testing"
)

func TestToolchainMatches(t *testing.T) {
bi, ok := debug.ReadBuildInfo()
tsRev, ok := tailscaleToolchainRev()
if !ok {
t.Fatal("failed to read build info")
}
var tsRev string
for _, s := range bi.Settings {
if s.Key == "tailscale.toolchain.rev" {
tsRev = s.Value
break
}
}
want := strings.TrimSpace(GoToolchainRev)
if tsRev != want {
if os.Getenv("TS_PERMIT_TOOLCHAIN_MISMATCH") == "1" {
Expand Down

0 comments on commit 23f41ae

Please sign in to comment.