Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
fe80f029b5 | |||
15742e8f3f | |||
5251c15271 | |||
2d3d1f881e | |||
cde1201da5 | |||
6df08053c6 | |||
8690a026b1 |
14
Makefile
14
Makefile
@ -7,12 +7,12 @@ build:
|
|||||||
# Clean
|
# Clean
|
||||||
####################################################
|
####################################################
|
||||||
clean:
|
clean:
|
||||||
rm -f ~/.local/bin/versionedTerraform
|
rm -f $(shell go env GOPATH)/bin/versionedTerraform
|
||||||
####################################################
|
####################################################
|
||||||
# Install
|
# Install
|
||||||
####################################################
|
####################################################
|
||||||
install:
|
install:
|
||||||
mv versionedTerraform ~/.local/bin/
|
mv versionedTerraform $(shell go env GOPATH)/bin/
|
||||||
####################################################
|
####################################################
|
||||||
# help feature
|
# help feature
|
||||||
####################################################
|
####################################################
|
||||||
@ -20,8 +20,8 @@ help:
|
|||||||
@echo ''
|
@echo ''
|
||||||
@echo 'Usage: make [TARGET]'
|
@echo 'Usage: make [TARGET]'
|
||||||
@echo 'Targets:'
|
@echo 'Targets:'
|
||||||
@echo ' build go build -o versionedTerraform ./cmd'
|
@echo ' build go build -o versionedTerraform ./cmd'
|
||||||
@echo ' clean removes installed versionedTerraform file'
|
@echo ' clean removes installed versionedTerraform file'
|
||||||
@echo ' install installs versionedTerraform to local user bin folder'
|
@echo ' install installs versionedTerraform to bin folder in GOPATH'
|
||||||
@echo ' all Nothing to do.'
|
@echo ' all Nothing to do.'
|
||||||
@echo ''
|
@echo ''
|
||||||
|
@ -5,7 +5,7 @@ A wrapper for terraform to detect the expected version of terraform,
|
|||||||
download, and execute that version
|
download, and execute that version
|
||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
- go compiler (only tested on go1.17)
|
- go
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
`make build install` for installation to local user<br>
|
`make build install` for installation to local user<br>
|
||||||
|
@ -86,3 +86,50 @@ func (s *SemVersion) VersionInSlice(sSem []SemVersion) bool {
|
|||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *SemVersion) IsEqualTo(s2 SemVersion) bool {
|
||||||
|
if s.majorVersion == s2.majorVersion && s.minorVersion == s2.minorVersion && s.patchVersion == s2.patchVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SemVersion) IsLessThan(s2 SemVersion) bool {
|
||||||
|
if s2.majorVersion > s.majorVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if s2.minorVersion > s.minorVersion && s2.majorVersion == s.majorVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if s2.patchVersion > s.patchVersion && s2.majorVersion == s.majorVersion && s2.minorVersion == s.minorVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SemVersion) IsGreaterThan(s2 SemVersion) bool {
|
||||||
|
if s2.majorVersion < s.majorVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if s2.minorVersion < s.minorVersion && s2.majorVersion == s.majorVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if s2.patchVersion < s.patchVersion && s2.majorVersion == s.majorVersion && s2.minorVersion == s.minorVersion {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SemVersion) IsLessOrEqual(s2 SemVersion) bool {
|
||||||
|
if s.IsLessThan(s2) || s.IsEqualTo(s2) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SemVersion) IsGreaterOrEqual(s2 SemVersion) bool {
|
||||||
|
if s.IsGreaterThan(s2) || s.IsEqualTo(s2) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
@ -86,3 +86,688 @@ func TestSemVersion_VersionInSlice_fail(t *testing.T) {
|
|||||||
t.Errorf("Expected Sem Version to not be found in semArray")
|
t.Errorf("Expected Sem Version to not be found in semArray")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSemVersion_IsLessThan(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
name string
|
||||||
|
want bool
|
||||||
|
s1, s2 SemVersion
|
||||||
|
}{
|
||||||
|
{"IsEqualTo",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionLess",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionLess",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionLess",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, c := range cases {
|
||||||
|
t.Run("Test: "+c.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
got := c.s1.IsLessThan(c.s2)
|
||||||
|
if c.want != got {
|
||||||
|
t.Errorf("Expected %+v got %+v", c.want, got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSemVersion_IsGreaterThan(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
name string
|
||||||
|
want bool
|
||||||
|
s1, s2 SemVersion
|
||||||
|
}{
|
||||||
|
{"IsEqualTo",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionGreater",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionGreater",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionGreater",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, c := range cases {
|
||||||
|
t.Run("Test: "+c.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
got := c.s1.IsGreaterThan(c.s2)
|
||||||
|
if c.want != got {
|
||||||
|
t.Errorf("Expected %+v got %+v", c.want, got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSemVersion_IsEqualTo(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
name string
|
||||||
|
want bool
|
||||||
|
s1, s2 SemVersion
|
||||||
|
}{
|
||||||
|
{"IsEqualTo",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, c := range cases {
|
||||||
|
t.Run("Test: "+c.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
got := c.s1.IsEqualTo(c.s2)
|
||||||
|
if c.want != got {
|
||||||
|
t.Errorf("Expected %+v got %+v", c.want, got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSemVersion_IsLessOrEqual(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
name string
|
||||||
|
want bool
|
||||||
|
s1, s2 SemVersion
|
||||||
|
}{
|
||||||
|
{"IsEqualTo",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionLess",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionLess",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionLess",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionGreater",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, c := range cases {
|
||||||
|
t.Run("Test: "+c.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
got := c.s1.IsLessOrEqual(c.s2)
|
||||||
|
if c.want != got {
|
||||||
|
t.Errorf("Expected %+v got %+v", c.want, got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSemVersion_IsGreaterOrEqual(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
name string
|
||||||
|
want bool
|
||||||
|
s1, s2 SemVersion
|
||||||
|
}{
|
||||||
|
{"IsEqualTo",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionLess",
|
||||||
|
false,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MajorVersionGreater",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "2.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 2,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"MinorVersionGreater",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.3.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 3,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{"PatchVersionGreater",
|
||||||
|
true,
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.4",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 4,
|
||||||
|
},
|
||||||
|
SemVersion{
|
||||||
|
version: "1.2.3",
|
||||||
|
isStable: false,
|
||||||
|
majorVersion: 1,
|
||||||
|
minorVersion: 2,
|
||||||
|
patchVersion: 3,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, c := range cases {
|
||||||
|
t.Run("Test: "+c.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
got := c.s1.IsGreaterOrEqual(c.s2)
|
||||||
|
if c.want != got {
|
||||||
|
t.Errorf("Expected %+v got %+v", c.want, got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_darwin_amd64.zip"
|
fileSuffix = "_darwin_amd64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_darwin_arm64.zip"
|
fileSuffix = "_darwin_arm64.zip"
|
||||||
|
minVersion = "1.0.2"
|
||||||
|
alternateSuffix = "_darwin_amd64.zip"
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_freebsd_386.zip"
|
fileSuffix = "_freebsd_386.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_freebsd_amd64.zip"
|
fileSuffix = "_freebsd_amd64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_freebsd_arm.zip"
|
fileSuffix = "_freebsd_arm.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_linux_386.zip"
|
fileSuffix = "_linux_386.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_linux_amd64.zip"
|
fileSuffix = "_linux_amd64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_linux_arm.zip"
|
fileSuffix = "_linux_arm.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_linux_arm64.zip"
|
fileSuffix = "_linux_arm64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_openbsd_386.zip"
|
fileSuffix = "_openbsd_386.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_openbsd_amd64.zip"
|
fileSuffix = "_openbsd_amd64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_solaris_amd64.zip"
|
fileSuffix = "_solaris_amd64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"bufio"
|
"bufio"
|
||||||
"bytes"
|
"bytes"
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -25,7 +26,7 @@ const (
|
|||||||
versionedTerraformFolder = "/.versionedTerraform"
|
versionedTerraformFolder = "/.versionedTerraform"
|
||||||
)
|
)
|
||||||
|
|
||||||
//getLatestMajorRelease() returns the latest major release from Version
|
// getLatestMajorRelease() returns the latest major release from Version
|
||||||
func (v *Version) getLatestMajorRelease() {
|
func (v *Version) getLatestMajorRelease() {
|
||||||
for _, release := range v.availableVersions {
|
for _, release := range v.availableVersions {
|
||||||
if release.majorVersion == v.Version.majorVersion &&
|
if release.majorVersion == v.Version.majorVersion &&
|
||||||
@ -37,7 +38,7 @@ func (v *Version) getLatestMajorRelease() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//getGreatestRelease() returns less than release
|
// getGreatestRelease() returns less than release
|
||||||
func (v *Version) getOneLessRelease() {
|
func (v *Version) getOneLessRelease() {
|
||||||
var vSlice []Version
|
var vSlice []Version
|
||||||
|
|
||||||
@ -60,9 +61,8 @@ func (v *Version) getOneLessRelease() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//getLatestRelease returns the latest release from Version
|
// getLatestRelease returns the latest release from Version
|
||||||
func (v *Version) getLatestRelease() {
|
func (v *Version) getLatestRelease() {
|
||||||
//todo clean up
|
|
||||||
for _, release := range v.availableVersions {
|
for _, release := range v.availableVersions {
|
||||||
if release.majorVersion > v.Version.majorVersion &&
|
if release.majorVersion > v.Version.majorVersion &&
|
||||||
(release.isStable || !needsStable) {
|
(release.isStable || !needsStable) {
|
||||||
@ -82,60 +82,68 @@ func (v *Version) getLatestRelease() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//InstallTerraformVersion installs the defined terraform Version in the application
|
// InstallTerraformVersion installs the defined terraform Version in the application
|
||||||
//configuration directory
|
// configuration directory
|
||||||
func (v *Version) InstallTerraformVersion() error {
|
func (v *Version) InstallTerraformVersion() error {
|
||||||
homeDir, _ := os.UserHomeDir()
|
homeDir, _ := os.UserHomeDir()
|
||||||
resp, err := http.Get(hashicorpUrl +
|
suffix := fileSuffix
|
||||||
|
minV := NewSemVersion(minVersion)
|
||||||
|
if v.Version.IsLessThan(*minV) {
|
||||||
|
suffix = alternateSuffix
|
||||||
|
}
|
||||||
|
url := hashicorpUrl +
|
||||||
v.Version.ToString() +
|
v.Version.ToString() +
|
||||||
"/" + terraformPrefix +
|
"/" + terraformPrefix +
|
||||||
v.Version.ToString() +
|
v.Version.ToString() +
|
||||||
fileSuffix)
|
suffix
|
||||||
|
|
||||||
|
resp, err := http.Get(url)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("failed to download Terraform: %v", err)
|
||||||
}
|
}
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
|
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := ioutil.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("failed to read response body: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
zipReader, err := zip.NewReader(bytes.NewReader(body), int64(len(body)))
|
zipReader, err := zip.NewReader(bytes.NewReader(body), int64(len(body)))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("failed to create zip reader: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
versionedFileName := homeDir + versionedTerraformFolder + "/" + terraformPrefix + v.Version.ToString()
|
versionedFileName := homeDir + versionedTerraformFolder + "/" + terraformPrefix + v.Version.ToString()
|
||||||
versionedFile, err := os.OpenFile(versionedFileName, os.O_WRONLY, 0755)
|
versionedFile, err := os.OpenFile(versionedFileName, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0755)
|
||||||
if os.IsNotExist(err) {
|
|
||||||
versionedFile, err = os.OpenFile(versionedFileName, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0755)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("failed to create output file: %v", err)
|
||||||
}
|
}
|
||||||
defer versionedFile.Close()
|
defer versionedFile.Close()
|
||||||
|
|
||||||
for _, zipFIle := range zipReader.File {
|
for _, zipFile := range zipReader.File {
|
||||||
zr, err := zipFIle.Open()
|
if zipFile.Name != "terraform" {
|
||||||
if err != nil {
|
continue
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
unzippedFileBytes, _ := ioutil.ReadAll(zr)
|
|
||||||
|
|
||||||
_, err = versionedFile.Write(unzippedFileBytes)
|
zr, err := zipFile.Open()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("failed to open zip file: %v", err)
|
||||||
}
|
}
|
||||||
zr.Close()
|
defer zr.Close()
|
||||||
|
|
||||||
|
_, err = io.Copy(versionedFile, zr)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to write terraform binary: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
//NewVersion creates a new Version using sem versioning for determining the
|
// NewVersion creates a new Version using sem versioning for determining the
|
||||||
//latest release
|
// latest release
|
||||||
func NewVersion(_version string, _vList []string) *Version {
|
func NewVersion(_version string, _vList []string) *Version {
|
||||||
v := new(Version)
|
v := new(Version)
|
||||||
v.Version = *NewSemVersion(_version)
|
v.Version = *NewSemVersion(_version)
|
||||||
@ -198,7 +206,7 @@ func NewVersion(_version string, _vList []string) *Version {
|
|||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
|
|
||||||
//GetVersionList returns a list of available versions from hashicorp's release page
|
// GetVersionList returns a list of available versions from hashicorp's release page
|
||||||
func GetVersionList() ([]string, error) {
|
func GetVersionList() ([]string, error) {
|
||||||
var versionList []string
|
var versionList []string
|
||||||
resp, err := http.Get(hashicorpUrl)
|
resp, err := http.Get(hashicorpUrl)
|
||||||
@ -230,7 +238,7 @@ func GetVersionList() ([]string, error) {
|
|||||||
return versionList, nil
|
return versionList, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
//removeSpacesVersion removes spaces from Version string for parsing
|
// removeSpacesVersion removes spaces from Version string for parsing
|
||||||
func removeSpacesVersion(v string) string {
|
func removeSpacesVersion(v string) string {
|
||||||
splitV := strings.Split(v, " ")
|
splitV := strings.Split(v, " ")
|
||||||
var returnString string
|
var returnString string
|
||||||
@ -241,12 +249,12 @@ func removeSpacesVersion(v string) string {
|
|||||||
return strings.TrimSpace(returnString)
|
return strings.TrimSpace(returnString)
|
||||||
}
|
}
|
||||||
|
|
||||||
//VersionToString returns string of a Version
|
// VersionToString returns string of a Version
|
||||||
func (v *Version) VersionToString() string {
|
func (v *Version) VersionToString() string {
|
||||||
return v.Version.ToString()
|
return v.Version.ToString()
|
||||||
}
|
}
|
||||||
|
|
||||||
//isVersionGreater returns true if v1 is greater than v2
|
// isVersionGreater returns true if v1 is greater than v2
|
||||||
func isVersionGreater(v1 Version, v2 Version) bool {
|
func isVersionGreater(v1 Version, v2 Version) bool {
|
||||||
if v1.Version.majorVersion != v2.Version.majorVersion {
|
if v1.Version.majorVersion != v2.Version.majorVersion {
|
||||||
if v1.Version.majorVersion > v2.Version.majorVersion {
|
if v1.Version.majorVersion > v2.Version.majorVersion {
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_windows_386.zip"
|
fileSuffix = "_windows_386.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
@ -4,5 +4,7 @@
|
|||||||
package versionedTerraform
|
package versionedTerraform
|
||||||
|
|
||||||
const (
|
const (
|
||||||
fileSuffix = "_windows_amd64.zip"
|
fileSuffix = "_windows_amd64.zip"
|
||||||
|
minVersion = "0.0.0"
|
||||||
|
alternateSuffix = ""
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user