modified unsupported envoy version error (#16518)

- When an envoy version is out of a supported range, we now return the envoy version being used as `major.minor.x` to indicate that it is the minor version at most that is incompatible
- When an envoy version is in the list of unsupported envoy versions we return back the envoy version in the error message as `major.minor.patch` as now the exact version matters.
This commit is contained in:
Michael Wilkerson 2023-03-03 10:29:34 -08:00 committed by GitHub
parent 5f81662066
commit c517f07eca
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 78 additions and 24 deletions

View File

@ -503,15 +503,15 @@ func (c *cmd) run(args []string) int {
return 1 return 1
} }
ok, err := checkEnvoyVersionCompatibility(v, xdscommon.UnsupportedEnvoyVersions) ec, err := checkEnvoyVersionCompatibility(v, xdscommon.UnsupportedEnvoyVersions)
if err != nil { if err != nil {
c.UI.Warn("There was an error checking the compatibility of the envoy version: " + err.Error()) c.UI.Warn("There was an error checking the compatibility of the envoy version: " + err.Error())
} else if !ok { } else if !ec.isCompatible {
c.UI.Error(fmt.Sprintf("Envoy version %s is not supported. If there is a reason you need to use "+ c.UI.Error(fmt.Sprintf("Envoy version %s is not supported. If there is a reason you need to use "+
"this version of envoy use the ignore-envoy-compatibility flag. Using an unsupported version of Envoy "+ "this version of envoy use the ignore-envoy-compatibility flag. Using an unsupported version of Envoy "+
"is not recommended and your experience may vary. For more information on compatibility "+ "is not recommended and your experience may vary. For more information on compatibility "+
"see https://developer.hashicorp.com/consul/docs/connect/proxies/envoy#envoy-and-consul-client-agent", v)) "see https://developer.hashicorp.com/consul/docs/connect/proxies/envoy#envoy-and-consul-client-agent", ec.versionIncompatible))
return 1 return 1
} }
} }
@ -976,34 +976,73 @@ Usage: consul connect envoy [options] [-- pass-through options]
` `
) )
func checkEnvoyVersionCompatibility(envoyVersion string, unsupportedList []string) (bool, error) { type envoyCompat struct {
// Now compare the versions to the list of supported versions isCompatible bool
versionIncompatible string
}
func checkEnvoyVersionCompatibility(envoyVersion string, unsupportedList []string) (envoyCompat, error) {
v, err := version.NewVersion(envoyVersion) v, err := version.NewVersion(envoyVersion)
if err != nil { if err != nil {
return false, err return envoyCompat{}, err
} }
var cs strings.Builder var cs strings.Builder
// Add one to the max minor version so that we accept all patches // If there is a list of unsupported versions, build the constraint string,
// this will detect exactly unsupported versions
if len(unsupportedList) > 0 {
for i, s := range unsupportedList {
if i == 0 {
cs.WriteString(fmt.Sprintf("!= %s", s))
} else {
cs.WriteString(fmt.Sprintf(", != %s", s))
}
}
constraints, err := version.NewConstraint(cs.String())
if err != nil {
return envoyCompat{}, err
}
if c := constraints.Check(v); !c {
return envoyCompat{
isCompatible: c,
versionIncompatible: envoyVersion,
}, nil
}
}
// Next build the constraint string using the bounds, make sure that we are less than but not equal to
// maxSupported since we will add 1. Need to add one to the max minor version so that we accept all patches
splitS := strings.Split(xdscommon.GetMaxEnvoyMinorVersion(), ".") splitS := strings.Split(xdscommon.GetMaxEnvoyMinorVersion(), ".")
minor, err := strconv.Atoi(splitS[1]) minor, err := strconv.Atoi(splitS[1])
if err != nil { if err != nil {
return false, err return envoyCompat{}, err
} }
minor++ minor++
maxSupported := fmt.Sprintf("%s.%d", splitS[0], minor) maxSupported := fmt.Sprintf("%s.%d", splitS[0], minor)
// Build the constraint string, make sure that we are less than but not equal to maxSupported since we added 1 cs.Reset()
cs.WriteString(fmt.Sprintf(">= %s, < %s", xdscommon.GetMinEnvoyMinorVersion(), maxSupported)) cs.WriteString(fmt.Sprintf(">= %s, < %s", xdscommon.GetMinEnvoyMinorVersion(), maxSupported))
for _, s := range unsupportedList {
cs.WriteString(fmt.Sprintf(", != %s", s))
}
constraints, err := version.NewConstraint(cs.String()) constraints, err := version.NewConstraint(cs.String())
if err != nil { if err != nil {
return false, err return envoyCompat{}, err
} }
return constraints.Check(v), nil if c := constraints.Check(v); !c {
return envoyCompat{
isCompatible: c,
versionIncompatible: replacePatchVersionWithX(envoyVersion),
}, nil
}
return envoyCompat{isCompatible: true}, nil
}
func replacePatchVersionWithX(version string) string {
// Strip off the patch and append x to convey that the constraint is on the minor version and not the patch
// itself
a := strings.Split(version, ".")
return fmt.Sprintf("%s.%s.x", a[0], a[1])
} }

View File

@ -1696,50 +1696,65 @@ func TestCheckEnvoyVersionCompatibility(t *testing.T) {
name string name string
envoyVersion string envoyVersion string
unsupportedList []string unsupportedList []string
expectedSupport bool expectedCompat envoyCompat
isErrorExpected bool isErrorExpected bool
}{ }{
{ {
name: "supported-using-proxy-support-defined", name: "supported-using-proxy-support-defined",
envoyVersion: xdscommon.EnvoyVersions[1], envoyVersion: xdscommon.EnvoyVersions[1],
unsupportedList: xdscommon.UnsupportedEnvoyVersions, unsupportedList: xdscommon.UnsupportedEnvoyVersions,
expectedSupport: true, expectedCompat: envoyCompat{
isCompatible: true,
},
}, },
{ {
name: "supported-at-max", name: "supported-at-max",
envoyVersion: xdscommon.GetMaxEnvoyMinorVersion(), envoyVersion: xdscommon.GetMaxEnvoyMinorVersion(),
unsupportedList: xdscommon.UnsupportedEnvoyVersions, unsupportedList: xdscommon.UnsupportedEnvoyVersions,
expectedSupport: true, expectedCompat: envoyCompat{
isCompatible: true,
},
}, },
{ {
name: "supported-patch-higher", name: "supported-patch-higher",
envoyVersion: addNPatchVersion(xdscommon.EnvoyVersions[0], 1), envoyVersion: addNPatchVersion(xdscommon.EnvoyVersions[0], 1),
unsupportedList: xdscommon.UnsupportedEnvoyVersions, unsupportedList: xdscommon.UnsupportedEnvoyVersions,
expectedSupport: true, expectedCompat: envoyCompat{
isCompatible: true,
},
}, },
{ {
name: "not-supported-minor-higher", name: "not-supported-minor-higher",
envoyVersion: addNMinorVersion(xdscommon.EnvoyVersions[0], 1), envoyVersion: addNMinorVersion(xdscommon.EnvoyVersions[0], 1),
unsupportedList: xdscommon.UnsupportedEnvoyVersions, unsupportedList: xdscommon.UnsupportedEnvoyVersions,
expectedSupport: false, expectedCompat: envoyCompat{
isCompatible: false,
versionIncompatible: replacePatchVersionWithX(addNMinorVersion(xdscommon.EnvoyVersions[0], 1)),
},
}, },
{ {
name: "not-supported-minor-lower", name: "not-supported-minor-lower",
envoyVersion: addNMinorVersion(xdscommon.EnvoyVersions[len(xdscommon.EnvoyVersions)-1], -1), envoyVersion: addNMinorVersion(xdscommon.EnvoyVersions[len(xdscommon.EnvoyVersions)-1], -1),
unsupportedList: xdscommon.UnsupportedEnvoyVersions, unsupportedList: xdscommon.UnsupportedEnvoyVersions,
expectedSupport: false, expectedCompat: envoyCompat{
isCompatible: false,
versionIncompatible: replacePatchVersionWithX(addNMinorVersion(xdscommon.EnvoyVersions[len(xdscommon.EnvoyVersions)-1], -1)),
},
}, },
{ {
name: "not-supported-explicitly-unsupported-version", name: "not-supported-explicitly-unsupported-version",
envoyVersion: addNPatchVersion(xdscommon.EnvoyVersions[0], 1), envoyVersion: addNPatchVersion(xdscommon.EnvoyVersions[0], 1),
unsupportedList: []string{"1.23.1", addNPatchVersion(xdscommon.EnvoyVersions[0], 1)}, unsupportedList: []string{"1.23.1", addNPatchVersion(xdscommon.EnvoyVersions[0], 1)},
expectedSupport: false, expectedCompat: envoyCompat{
isCompatible: false,
versionIncompatible: addNPatchVersion(xdscommon.EnvoyVersions[0], 1),
},
}, },
{ {
name: "error-bad-input", name: "error-bad-input",
envoyVersion: "1.abc.3", envoyVersion: "1.abc.3",
unsupportedList: xdscommon.UnsupportedEnvoyVersions, unsupportedList: xdscommon.UnsupportedEnvoyVersions,
expectedSupport: false, expectedCompat: envoyCompat{},
isErrorExpected: true, isErrorExpected: true,
}, },
} }
@ -1752,7 +1767,7 @@ func TestCheckEnvoyVersionCompatibility(t *testing.T) {
} else { } else {
assert.NoError(t, err) assert.NoError(t, err)
} }
assert.Equal(t, tc.expectedSupport, actual) assert.Equal(t, tc.expectedCompat, actual)
}) })
} }
} }