terraform-provider-docker/internal/provider/validators_test.go
Manuel Vogel ad3e56da2b
feat: migrate to terraform-sdk v2 (#102)
* chore: runs v2 upgrade cmd
* chore: moves all files into the internal provider dir
* feat: migrates main and provider
* fix: migrates tests to provider factories
* fix: replace import state passthrough ctx func
* chore: bump tf-sdk to v2.4.4
* fix: acc test by adding stop grace period
* fix: move to validate diag functions
* test: switch from ctx TODO to Background
* feat: add state upgrade for restart_policy and auth

Co-authored-by: Shunsuke Suzuki <suzuki-shunsuke@users.noreply.github.com>
2021-03-18 08:30:54 +01:00

121 lines
3.7 KiB
Go

package provider
import (
"testing"
"github.com/hashicorp/go-cty/cty"
)
func TestValidateIntegerGeqThan0(t *testing.T) {
v := 1
if diags := validateIntegerGeqThan(0)(v, *new(cty.Path)); diags.HasError() {
t.Fatalf("%d should be an integer greater than 0", v)
}
v = -4
if diags := validateIntegerGeqThan(0)(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%d should be an invalid integer smaller than 0", v)
}
}
func TestValidateStringIsFloatRatio(t *testing.T) {
v := "0.9"
if diags := validateStringIsFloatRatio()(v, *new(cty.Path)); diags.HasError() {
t.Fatalf("%v should be a float between 0.0 and 1.0", v)
}
v = "-4.5"
if diags := validateStringIsFloatRatio()(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%v should be an invalid float smaller than 0.0", v)
}
v = "1.1"
if diags := validateStringIsFloatRatio()(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%v should be an invalid float greater than 1.0", v)
}
v = "false"
if diags := validateStringIsFloatRatio()(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%v should be an invalid float because it is a bool in a string", v)
}
w := false
if diags := validateStringIsFloatRatio()(w, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%v should be an invalid float because it is a bool", v)
}
i := 0
if diags := validateStringIsFloatRatio()(i, *new(cty.Path)); diags.HasError() {
t.Fatalf("%v should be a valid float because int can be casted", v)
}
i = 1
if diags := validateStringIsFloatRatio()(i, *new(cty.Path)); diags.HasError() {
t.Fatalf("%v should be a valid float because int can be casted", v)
}
i = 4
if diags := validateStringIsFloatRatio()(i, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%v should be an invalid float because it is an int out of range", v)
}
}
func TestValidateDurationGeq0(t *testing.T) {
v := "1ms"
if diags := validateDurationGeq0()(v, *new(cty.Path)); diags.HasError() {
t.Fatalf("%v should be a valid durarion", v)
}
v = "-2h"
if diags := validateDurationGeq0()(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%v should be an invalid duration smaller than 0", v)
}
}
func TestValidateStringMatchesPattern(t *testing.T) {
pattern := `^(pause|continue-mate|break)$`
v := "pause"
if diags := validateStringMatchesPattern(pattern)(v, *new(cty.Path)); diags.HasError() {
t.Fatalf("%q should match the pattern", v)
}
v = "doesnotmatch"
if diags := validateStringMatchesPattern(pattern)(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%q should not match the pattern", v)
}
v = "continue-mate"
if diags := validateStringMatchesPattern(pattern)(v, *new(cty.Path)); diags.HasError() {
t.Fatalf("%q should match the pattern", v)
}
}
func TestValidateStringShouldBeBase64Encoded(t *testing.T) {
v := `YmtzbGRrc2xka3NkMjM4MQ==`
if diags := validateStringIsBase64Encoded()(v, *new(cty.Path)); diags.HasError() {
t.Fatalf("%q should be base64 decodeable", v)
}
v = `%&df#3NkMjM4MQ==`
if diags := validateStringIsBase64Encoded()(v, *new(cty.Path)); !diags.HasError() {
t.Fatalf("%q should NOT be base64 decodeable", v)
}
}
func TestValidateStringShouldBeAValidDockerContainerPath(t *testing.T) {
cases := []struct {
Value string
ErrCount int
}{
{Value: "/abc", ErrCount: 0},
{Value: "/var/log", ErrCount: 0},
{Value: "/tmp", ErrCount: 0},
{Value: "C:\\Windows\\System32", ErrCount: 0},
{Value: "C:\\Program Files\\MSBuild", ErrCount: 0},
{Value: "test", ErrCount: 1},
{Value: "C:Test", ErrCount: 1},
{Value: "", ErrCount: 1},
{Value: "~/kinda-relative-path", ErrCount: 1},
}
for _, tc := range cases {
diags := validateDockerContainerPath()(tc.Value, *new(cty.Path))
if len(diags) != tc.ErrCount {
t.Fatalf("Expected the Docker Container Path '%s' to trigger a validation error", tc.Value)
}
}
}