From 4bda41e7019d6fd4c0bbd235dc1698f6afdf6651 Mon Sep 17 00:00:00 2001 From: Brad Fitzpatrick Date: Fri, 16 Sep 2022 11:39:32 -0700 Subject: [PATCH] Dockerfile: add test that build-env Alpine version matches go.mod So things like #5660 don't happen in the future. Change-Id: I01234f241e297d5b7bdd18da1bb3cc5420ad2225 Signed-off-by: Brad Fitzpatrick --- version_test.go | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 version_test.go diff --git a/version_test.go b/version_test.go new file mode 100644 index 000000000..9b99609f3 --- /dev/null +++ b/version_test.go @@ -0,0 +1,34 @@ +// Copyright (c) 2022 Tailscale Inc & 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 tailscaleroot + +import ( + "fmt" + "os" + "regexp" + "strings" + "testing" +) + +func TestDockerfileVersion(t *testing.T) { + goMod, err := os.ReadFile("go.mod") + if err != nil { + t.Fatal(err) + } + m := regexp.MustCompile(`(?m)^go (\d\.\d+)\r?$`).FindStringSubmatch(string(goMod)) + if m == nil { + t.Fatalf("didn't find go version in go.mod") + } + goVersion := m[1] + + dockerFile, err := os.ReadFile("Dockerfile") + if err != nil { + t.Fatal(err) + } + wantSub := fmt.Sprintf("FROM golang:%s-alpine AS build-env", goVersion) + if !strings.Contains(string(dockerFile), wantSub) { + t.Errorf("didn't find %q in Dockerfile", wantSub) + } +}