mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-07 14:44:11 -06:00
e3401947a6
As well as constraining plugins by version number, we also want to be able to pin plugins to use specific executables so that we can detect drift in available plugins between commands. This commit allows such requirements to be specified, but doesn't yet specify any such requirements, nor validate them.
94 lines
1.8 KiB
Go
94 lines
1.8 KiB
Go
package discovery
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
)
|
|
|
|
func TestPluginConstraintsAllows(t *testing.T) {
|
|
tests := []struct {
|
|
Constraints *PluginConstraints
|
|
Version string
|
|
Want bool
|
|
}{
|
|
{
|
|
&PluginConstraints{
|
|
Versions: AllVersions,
|
|
},
|
|
"1.0.0",
|
|
true,
|
|
},
|
|
{
|
|
&PluginConstraints{
|
|
Versions: ConstraintStr(">1.0.0").MustParse(),
|
|
},
|
|
"1.0.0",
|
|
false,
|
|
},
|
|
// This is not an exhaustive test because the callees
|
|
// already have plentiful tests of their own.
|
|
}
|
|
|
|
for i, test := range tests {
|
|
t.Run(fmt.Sprintf("%02d", i), func(t *testing.T) {
|
|
version := VersionStr(test.Version).MustParse()
|
|
got := test.Constraints.Allows(version)
|
|
if got != test.Want {
|
|
t.Logf("looking for %s in %#v", test.Version, test.Constraints)
|
|
t.Errorf("wrong result %#v; want %#v", got, test.Want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestPluginConstraintsAcceptsSHA256(t *testing.T) {
|
|
mustUnhex := func(hex string) (ret []byte) {
|
|
_, err := fmt.Sscanf(hex, "%x", &ret)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return ret
|
|
}
|
|
|
|
tests := []struct {
|
|
Constraints *PluginConstraints
|
|
Digest []byte
|
|
Want bool
|
|
}{
|
|
{
|
|
&PluginConstraints{
|
|
Versions: AllVersions,
|
|
SHA256: mustUnhex("0123456789abcdef"),
|
|
},
|
|
mustUnhex("0123456789abcdef"),
|
|
true,
|
|
},
|
|
{
|
|
&PluginConstraints{
|
|
Versions: AllVersions,
|
|
SHA256: mustUnhex("0123456789abcdef"),
|
|
},
|
|
mustUnhex("f00dface"),
|
|
false,
|
|
},
|
|
{
|
|
&PluginConstraints{
|
|
Versions: AllVersions,
|
|
SHA256: nil,
|
|
},
|
|
mustUnhex("f00dface"),
|
|
true,
|
|
},
|
|
}
|
|
|
|
for i, test := range tests {
|
|
t.Run(fmt.Sprintf("%02d", i), func(t *testing.T) {
|
|
got := test.Constraints.AcceptsSHA256(test.Digest)
|
|
if got != test.Want {
|
|
t.Logf("%#v.AcceptsSHA256(%#v)", test.Constraints, test.Digest)
|
|
t.Errorf("wrong result %#v; want %#v", got, test.Want)
|
|
}
|
|
})
|
|
}
|
|
}
|