From aab61a644561a86115a23a801362043b445f7140 Mon Sep 17 00:00:00 2001 From: zack olson Date: Tue, 26 Nov 2024 09:20:38 -0500 Subject: [PATCH] add VersionNumFromSemver for builds --- version/version.go | 17 +++++++++++++---- version/version_test.go | 8 ++++++++ 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/version/version.go b/version/version.go index dd4a5a8..7b5d0a1 100644 --- a/version/version.go +++ b/version/version.go @@ -103,15 +103,17 @@ const ( patchVersionMultiplier int = 1 ) -// VersionNum parses the semver version string to look for only the major.minor.patch portion, +// VersionNumFromSemver parses the semver version string to look for only the major.minor.patch portion, // splits that into 3 parts (disregarding any extra portions), and applies a multiplier to each // part to generate a total int value representing the semver. // note that this will generate a sortable, and reversible integer as long as all parts remain less than 1000 // This is currently intended for use in generating comparable versions to set within windows registry entries, // allowing for an easy "upgrade-only" detection configuration within intune. -// Zero is returned for any case where the version cannot be reliably translated -func VersionNum() int { - semverMatch := semverRegexp.FindStringSubmatch(version) +// Zero is returned for any case where the version cannot be reliably translated. +// VersionNumFromSemver should be used where the build time version value cannot be controlled- to restrict +// translations to the internally set version, use VersionNum +func VersionNumFromSemver(semver string) int { + semverMatch := semverRegexp.FindStringSubmatch(semver) // expect the leftmost match as semverMatch[0] and the semver substring as semverMatch[1] if semverMatch == nil || len(semverMatch) != 2 { return 0 @@ -142,6 +144,13 @@ func VersionNum() int { return versionNum } +// VersionNum returns an integer representing the version value set at build time. +// see VersionNumFromSemver for additional details regarding the general translation process +// and limitations. this will return 0 if version is unset/unknown +func VersionNum() int { + return VersionNumFromSemver(version) +} + // SemverFromVersionNum provides the inverse functionality of VersionNum, allowing us // to collect and report the integer version in a readable semver format func SemverFromVersionNum(versionNum int) string { diff --git a/version/version_test.go b/version/version_test.go index 13e4cc9..3584045 100644 --- a/version/version_test.go +++ b/version/version_test.go @@ -41,10 +41,18 @@ func Test_VersionNum(t *testing.T) { semver: "", expectedVersionNum: 0, }, + "unset version": { + semver: "unknown", + expectedVersionNum: 0, + }, "basic version": { semver: "1.2.3", expectedVersionNum: 1002003, }, + "4_part_version": { + semver: "1.2.3.4", + expectedVersionNum: 1002003, + }, "max version": { semver: "999.999.999", expectedVersionNum: 999999999,