Adding upstream version 0.8.13.
Signed-off-by: Daniel Baumann <daniel@debian.org>
This commit is contained in:
parent
c0c4addb85
commit
6819b9812e
28 changed files with 556 additions and 76 deletions
282
internal/meta/meta_test.go
Normal file
282
internal/meta/meta_test.go
Normal file
|
@ -0,0 +1,282 @@
|
|||
package meta
|
||||
|
||||
import (
|
||||
"regexp"
|
||||
"runtime/debug"
|
||||
"strings"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
||||
func TestGetVersionInfo(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
setVars func()
|
||||
expect Info
|
||||
partialMatch bool
|
||||
}{
|
||||
{
|
||||
name: "GoReleaser build",
|
||||
setVars: func() {
|
||||
Version = "0.0.1"
|
||||
Commit = "abc123456789"
|
||||
Date = "2025-05-07T00:00:00Z"
|
||||
},
|
||||
expect: Info{
|
||||
Version: "v0.0.1",
|
||||
Commit: "abc1234",
|
||||
Date: "2025-05-07",
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "Source build with default values",
|
||||
setVars: func() {
|
||||
Version = devVersion
|
||||
Commit = unknownValue
|
||||
Date = unknownValue
|
||||
},
|
||||
expect: Info{
|
||||
Version: unknownValue,
|
||||
Commit: unknownValue,
|
||||
Date: time.Now().UTC().Format("2006-01-02"),
|
||||
},
|
||||
partialMatch: true,
|
||||
},
|
||||
{
|
||||
name: "Source build with empty values",
|
||||
setVars: func() {
|
||||
Version = ""
|
||||
Commit = ""
|
||||
Date = ""
|
||||
},
|
||||
expect: Info{
|
||||
Version: unknownValue,
|
||||
Commit: unknownValue,
|
||||
Date: time.Now().UTC().Format("2006-01-02"),
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "Invalid GoReleaser version",
|
||||
setVars: func() {
|
||||
Version = "v"
|
||||
Commit = ""
|
||||
Date = ""
|
||||
},
|
||||
expect: Info{
|
||||
Version: unknownValue,
|
||||
Commit: unknownValue,
|
||||
Date: time.Now().UTC().Format("2006-01-02"),
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
tt.setVars()
|
||||
|
||||
info := GetMetaInfo()
|
||||
|
||||
if !tt.partialMatch {
|
||||
if info.Version != tt.expect.Version {
|
||||
t.Errorf("Version = %q, want %q", info.Version, tt.expect.Version)
|
||||
}
|
||||
|
||||
if info.Commit != tt.expect.Commit {
|
||||
t.Errorf("Commit = %q, want %q", info.Commit, tt.expect.Commit)
|
||||
}
|
||||
|
||||
// Validate Date format (YYYY-MM-DD) instead of exact match
|
||||
if !regexp.MustCompile(`^\d{4}-\d{2}-\d{2}$`).MatchString(info.Date) {
|
||||
t.Errorf("Date = %q, want valid YYYY-MM-DD format", info.Date)
|
||||
}
|
||||
} else if info.Version != tt.expect.Version && !strings.Contains(info.Version, "+dirty") {
|
||||
t.Errorf("Version = %q, want %q or dirty variant", info.Version, tt.expect.Version)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestGetVersionInfo_VCSData(t *testing.T) {
|
||||
Version = devVersion
|
||||
Commit = unknownValue
|
||||
Date = unknownValue
|
||||
|
||||
info := GetMetaInfo()
|
||||
|
||||
if buildInfo, ok := debug.ReadBuildInfo(); ok {
|
||||
var vcsRevision, vcsTime, vcsModified string
|
||||
|
||||
for _, setting := range buildInfo.Settings {
|
||||
switch setting.Key {
|
||||
case "vcs.revision":
|
||||
vcsRevision = setting.Value
|
||||
case "vcs.time":
|
||||
vcsTime = setting.Value
|
||||
case "vcs.modified":
|
||||
vcsModified = setting.Value
|
||||
}
|
||||
}
|
||||
|
||||
if vcsRevision != "" {
|
||||
expectedCommit := vcsRevision
|
||||
if len(vcsRevision) >= 7 {
|
||||
expectedCommit = vcsRevision[:7]
|
||||
}
|
||||
|
||||
if info.Commit == unknownValue {
|
||||
t.Errorf(
|
||||
"Expected commit %q, got %q; ensure repository has commit history",
|
||||
expectedCommit,
|
||||
info.Commit,
|
||||
)
|
||||
} else if info.Commit != expectedCommit {
|
||||
t.Errorf("Commit = %q, want %q", info.Commit, expectedCommit)
|
||||
}
|
||||
} else {
|
||||
t.Logf("No vcs.revision found; ensure repository has Git metadata to cover commit assignment")
|
||||
}
|
||||
|
||||
if vcsTime != "" {
|
||||
if parsedTime, err := time.Parse(time.RFC3339, vcsTime); err == nil {
|
||||
expectedDate := parsedTime.Format("2006-01-02")
|
||||
if info.Date == unknownValue {
|
||||
t.Errorf(
|
||||
"Expected date %q, got %q; ensure vcs.time is a valid RFC3339 timestamp",
|
||||
expectedDate,
|
||||
info.Date,
|
||||
)
|
||||
} else if info.Date != expectedDate {
|
||||
t.Errorf("Date = %q, want %q", info.Date, expectedDate)
|
||||
}
|
||||
} else {
|
||||
t.Logf("vcs.time %q is invalid; date should be in YYYY-MM-DD format", vcsTime)
|
||||
|
||||
if !regexp.MustCompile(`^\d{4}-\d{2}-\d{2}$`).MatchString(info.Date) {
|
||||
t.Errorf("Date = %q, want valid YYYY-MM-DD format", info.Date)
|
||||
}
|
||||
}
|
||||
} else {
|
||||
t.Logf("No vcs.time found; date should be in YYYY-MM-DD format")
|
||||
|
||||
if !regexp.MustCompile(`^\d{4}-\d{2}-\d{2}$`).MatchString(info.Date) {
|
||||
t.Errorf("Date = %q, want valid YYYY-MM-DD format", info.Date)
|
||||
}
|
||||
}
|
||||
|
||||
if vcsModified == trueValue && info.Version != unknownValue {
|
||||
if !strings.Contains(info.Version, "+dirty") {
|
||||
t.Errorf(
|
||||
"Expected version to contain '+dirty', got %q; ensure repository has uncommitted changes",
|
||||
info.Version,
|
||||
)
|
||||
}
|
||||
} else if vcsModified != trueValue {
|
||||
t.Logf("Repository is clean (vcs.modified=%q); make uncommitted changes to cover '+dirty' case", vcsModified)
|
||||
}
|
||||
} else {
|
||||
t.Logf("debug.ReadBuildInfo() failed; ensure tests run in a Git repository to cover VCS parsing")
|
||||
}
|
||||
}
|
||||
|
||||
func TestGetVersionInfo_InvalidVCSTime(t *testing.T) {
|
||||
Version = devVersion
|
||||
Commit = unknownValue
|
||||
Date = unknownValue
|
||||
|
||||
info := GetMetaInfo()
|
||||
|
||||
if !regexp.MustCompile(`^\d{4}-\d{2}-\d{2}$`).MatchString(info.Date) {
|
||||
t.Errorf("Date = %q, want valid YYYY-MM-DD format", info.Date)
|
||||
}
|
||||
}
|
||||
|
||||
func TestGetMetaStr(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
setVars func()
|
||||
expect string
|
||||
}{
|
||||
{
|
||||
name: "With commit (GoReleaser build)",
|
||||
setVars: func() {
|
||||
Version = "0.8.10"
|
||||
Commit = "a6fcf77abcdef"
|
||||
Date = "2025-05-27T00:00:00Z"
|
||||
},
|
||||
expect: "v0.8.10 (Built on 2025-05-27 from Git SHA a6fcf77)",
|
||||
},
|
||||
{
|
||||
name: "Without commit (go install build)",
|
||||
setVars: func() {
|
||||
Version = "0.8.10"
|
||||
Commit = unknownValue
|
||||
Date = unknownValue
|
||||
},
|
||||
expect: "v0.8.10 (Built on " + time.Now().UTC().Format("2006-01-02") + ")",
|
||||
},
|
||||
{
|
||||
name: "Invalid version",
|
||||
setVars: func() {
|
||||
Version = "v"
|
||||
Commit = unknownValue
|
||||
Date = unknownValue
|
||||
},
|
||||
expect: "unknown (Built on " + time.Now().UTC().Format("2006-01-02") + ")",
|
||||
},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
tt.setVars()
|
||||
|
||||
result := GetMetaStr()
|
||||
if !strings.HasPrefix(result, strings.Split(tt.expect, " (")[0]) ||
|
||||
!regexp.MustCompile(`\d{4}-\d{2}-\d{2}`).MatchString(result) {
|
||||
t.Errorf("GetMetaStr() = %q, want format like %q", result, tt.expect)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestContains(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
s string
|
||||
substr string
|
||||
expected bool
|
||||
}{
|
||||
{
|
||||
name: "Substring found",
|
||||
s: "v1.0.0+dirty",
|
||||
substr: "+dirty",
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
name: "Substring not found",
|
||||
s: "v1.0.0",
|
||||
substr: "+dirty",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "Empty string",
|
||||
s: "",
|
||||
substr: "+dirty",
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
name: "Empty substring",
|
||||
s: "v1.0.0",
|
||||
substr: "",
|
||||
expected: true,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
result := contains(tt.s, tt.substr)
|
||||
if result != tt.expected {
|
||||
t.Errorf("contains(%q, %q) = %v, want %v", tt.s, tt.substr, result, tt.expected)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue