Docker: add ALPINE.txt to manage alpine versions
The goal here is to 1. make it so that the number doesn't diverge between the various places we had it defined 2. not define the number in corp, only in oss Signed-off-by: Maisem Ali <maisem@tailscale.com>pull/4977/head
parent
cfa484e1a2
commit
88133c361e
|
@ -0,0 +1 @@
|
||||||
|
3.16
|
|
@ -19,10 +19,15 @@ import (
|
||||||
var (
|
var (
|
||||||
goToolchain = flag.Bool("go", false, "print the supported Go toolchain git hash (a github.com/tailscale/go commit)")
|
goToolchain = flag.Bool("go", false, "print the supported Go toolchain git hash (a github.com/tailscale/go commit)")
|
||||||
goToolchainURL = flag.Bool("go-url", false, "print the URL to the tarball of the Tailscale Go toolchain")
|
goToolchainURL = flag.Bool("go-url", false, "print the URL to the tarball of the Tailscale Go toolchain")
|
||||||
|
alpine = flag.Bool("alpine", false, "print the tag of alpine docker image")
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
if *alpine {
|
||||||
|
fmt.Println(strings.TrimSpace(ts.AlpineDockerTag))
|
||||||
|
return
|
||||||
|
}
|
||||||
if *goToolchain {
|
if *goToolchain {
|
||||||
fmt.Println(strings.TrimSpace(ts.GoToolchainRev))
|
fmt.Println(strings.TrimSpace(ts.GoToolchainRev))
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,9 @@ import _ "embed"
|
||||||
//go:embed VERSION.txt
|
//go:embed VERSION.txt
|
||||||
var Version string
|
var Version string
|
||||||
|
|
||||||
|
//go:embed ALPINE.txt
|
||||||
|
var AlpineDockerTag string
|
||||||
|
|
||||||
// GoToolchainRev is the git hash from github.com/tailscale/go that this release
|
// GoToolchainRev is the git hash from github.com/tailscale/go that this release
|
||||||
// should be built using. It may end in a newline.
|
// should be built using. It may end in a newline.
|
||||||
//
|
//
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
// 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 version
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
ts "tailscale.com"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestAlpineTag(t *testing.T) {
|
||||||
|
if tag := readAlpineTag(t, "../Dockerfile.base"); tag == "" {
|
||||||
|
t.Fatal(`"FROM alpine:" not found in Dockerfile.base`)
|
||||||
|
} else if tag != ts.AlpineDockerTag {
|
||||||
|
t.Errorf("alpine version mismatch: Dockerfile.base has %q; ALPINE.txt has %q", tag, ts.AlpineDockerTag)
|
||||||
|
}
|
||||||
|
if tag := readAlpineTag(t, "../Dockerfile"); tag == "" {
|
||||||
|
t.Fatal(`"FROM alpine:" not found in Dockerfile`)
|
||||||
|
} else if tag != ts.AlpineDockerTag {
|
||||||
|
t.Errorf("alpine version mismatch: Dockerfile has %q; ALPINE.txt has %q", tag, ts.AlpineDockerTag)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func readAlpineTag(t *testing.T, file string) string {
|
||||||
|
f, err := os.ReadFile(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
for _, line := range bytes.Split(f, []byte{'\n'}) {
|
||||||
|
line = bytes.TrimSpace(line)
|
||||||
|
_, suf, ok := bytes.Cut(line, []byte("FROM alpine:"))
|
||||||
|
if !ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
return string(suf)
|
||||||
|
}
|
||||||
|
return ""
|
||||||
|
}
|
Loading…
Reference in New Issue