]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/dist: log OS version when testing
authorMichael Pratt <mpratt@google.com>
Mon, 13 Dec 2021 22:34:16 +0000 (17:34 -0500)
committerMichael Pratt <mpratt@google.com>
Fri, 14 Jan 2022 18:36:49 +0000 (18:36 +0000)
As a follow-up to https://golang.org/cl/371474, add the OS version to
the metadata printed for each test.

Fixes #50146.

Change-Id: I3b7e47983d0e85feebce8e424881b931882d53bf
Reviewed-on: https://go-review.googlesource.com/c/go/+/371475
Reviewed-by: Bryan Mills <bcmills@google.com>
Trust: Michael Pratt <mpratt@google.com>
Run-TryBot: Michael Pratt <mpratt@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Austin Clements <austin@google.com>
src/cmd/dist/metadata.go
src/cmd/internal/osinfo/doc.go [new file with mode: 0644]
src/cmd/internal/osinfo/os_js.go [new file with mode: 0644]
src/cmd/internal/osinfo/os_plan9.go [new file with mode: 0644]
src/cmd/internal/osinfo/os_unix.go [new file with mode: 0644]
src/cmd/internal/osinfo/os_windows.go [new file with mode: 0644]

index f0a125fb8a25dae07b6964ecc4c8a4fcd95d4854..76f108ea062f25ce80c632ce11ad264960e722ae 100644 (file)
@@ -12,6 +12,7 @@
 package main
 
 import (
+       "cmd/internal/osinfo"
        "fmt"
        "internal/sysinfo"
        "runtime"
@@ -20,5 +21,13 @@ import (
 func logMetadata() error {
        fmt.Printf("# GOARCH: %s\n", runtime.GOARCH)
        fmt.Printf("# CPU: %s\n", sysinfo.CPU.Name())
+
+       fmt.Printf("# GOOS: %s\n", runtime.GOOS)
+       ver, err := osinfo.Version()
+       if err != nil {
+               return fmt.Errorf("error determining OS version: %v", err)
+       }
+       fmt.Printf("# OS Version: %s\n", ver)
+
        return nil
 }
diff --git a/src/cmd/internal/osinfo/doc.go b/src/cmd/internal/osinfo/doc.go
new file mode 100644 (file)
index 0000000..c2f74be
--- /dev/null
@@ -0,0 +1,6 @@
+// Copyright 2021 The Go 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 osinfo provides OS metadata information.
+package osinfo
diff --git a/src/cmd/internal/osinfo/os_js.go b/src/cmd/internal/osinfo/os_js.go
new file mode 100644 (file)
index 0000000..8e86464
--- /dev/null
@@ -0,0 +1,18 @@
+// Copyright 2021 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+//go:build js
+
+package osinfo
+
+import (
+       "fmt"
+)
+
+// Version returns the OS version name/number.
+func Version() (string, error) {
+       // TODO(prattmic): Does wasm have any version/runtime detection
+       // functionality?
+       return "", fmt.Errorf("unimplemented")
+}
diff --git a/src/cmd/internal/osinfo/os_plan9.go b/src/cmd/internal/osinfo/os_plan9.go
new file mode 100644 (file)
index 0000000..ad1d324
--- /dev/null
@@ -0,0 +1,21 @@
+// Copyright 2021 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+//go:build plan9
+
+package osinfo
+
+import (
+       "os"
+)
+
+// Version returns the OS version name/number.
+func Version() (string, error) {
+       b, err := os.ReadFile("/dev/osversion")
+       if err != nil {
+               return "", err
+       }
+
+       return string(b), nil
+}
diff --git a/src/cmd/internal/osinfo/os_unix.go b/src/cmd/internal/osinfo/os_unix.go
new file mode 100644 (file)
index 0000000..4587cb2
--- /dev/null
@@ -0,0 +1,36 @@
+// Copyright 2021 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+//go:build aix || darwin || dragonfly || freebsd || linux || netbsd || openbsd || solaris
+
+package osinfo
+
+import (
+       "bytes"
+
+       "golang.org/x/sys/unix"
+)
+
+func utsString(b []byte) string {
+       i := bytes.IndexByte(b, 0)
+       if i == -1 {
+               return string(b)
+       }
+       return string(b[:i])
+}
+
+// Version returns the OS version name/number.
+func Version() (string, error) {
+       var uts unix.Utsname
+       if err := unix.Uname(&uts); err != nil {
+               return "", err
+       }
+
+       sysname := utsString(uts.Sysname[:])
+       release := utsString(uts.Release[:])
+       version := utsString(uts.Version[:])
+       machine := utsString(uts.Machine[:])
+
+       return sysname + " " + release + " " + version + " " + machine, nil
+}
diff --git a/src/cmd/internal/osinfo/os_windows.go b/src/cmd/internal/osinfo/os_windows.go
new file mode 100644 (file)
index 0000000..05fab9b
--- /dev/null
@@ -0,0 +1,19 @@
+// Copyright 2021 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+//go:build windows
+
+package osinfo
+
+import (
+       "fmt"
+
+       "golang.org/x/sys/windows"
+)
+
+// Version returns the OS version name/number.
+func Version() (string, error) {
+       major, minor, patch := windows.RtlGetNtVersionNumbers()
+       return fmt.Sprintf("%d.%d.%d", major, minor, patch), nil
+}