mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
df6af282b9
Changes Details: -------------- Fixes: #36395 Refactoring the code to do the following: 1. Add the method `errBindSourceDoesNotExist` inside `validate.go` to be in-line with the rest of error message 2. Utilised the new method inside `linux_parser.go`, `windows_parser.go` and `validate_test.go` 3. Change the format from `bind mount source path: '%s' does not exist` to `bind mount source path does not exist: %s` 4. Reflected the format change into the 2 unit tests, namely: `volume_test.go` and `validate_test.go` 5. Reflected the format change into `docker_api_containers_test.go` integration test Signed-off-by: Amr Gawish <amr.gawish@gmail.com>
73 lines
2.8 KiB
Go
73 lines
2.8 KiB
Go
package volume // import "github.com/docker/docker/volume"
|
|
|
|
import (
|
|
"errors"
|
|
"io/ioutil"
|
|
"os"
|
|
"runtime"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/docker/docker/api/types/mount"
|
|
)
|
|
|
|
func TestValidateMount(t *testing.T) {
|
|
testDir, err := ioutil.TempDir("", "test-validate-mount")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer os.RemoveAll(testDir)
|
|
|
|
cases := []struct {
|
|
input mount.Mount
|
|
expected error
|
|
}{
|
|
{mount.Mount{Type: mount.TypeVolume}, errMissingField("Target")},
|
|
{mount.Mount{Type: mount.TypeVolume, Target: testDestinationPath, Source: "hello"}, nil},
|
|
{mount.Mount{Type: mount.TypeVolume, Target: testDestinationPath}, nil},
|
|
{mount.Mount{Type: mount.TypeBind}, errMissingField("Target")},
|
|
{mount.Mount{Type: mount.TypeBind, Target: testDestinationPath}, errMissingField("Source")},
|
|
{mount.Mount{Type: mount.TypeBind, Target: testDestinationPath, Source: testSourcePath, VolumeOptions: &mount.VolumeOptions{}}, errExtraField("VolumeOptions")},
|
|
|
|
{mount.Mount{Type: mount.TypeBind, Source: testDir, Target: testDestinationPath}, nil},
|
|
{mount.Mount{Type: "invalid", Target: testDestinationPath}, errors.New("mount type unknown")},
|
|
{mount.Mount{Type: mount.TypeBind, Source: testSourcePath, Target: testDestinationPath}, errBindSourceDoesNotExist(testSourcePath)},
|
|
}
|
|
|
|
lcowCases := []struct {
|
|
input mount.Mount
|
|
expected error
|
|
}{
|
|
{mount.Mount{Type: mount.TypeVolume}, errMissingField("Target")},
|
|
{mount.Mount{Type: mount.TypeVolume, Target: "/foo", Source: "hello"}, nil},
|
|
{mount.Mount{Type: mount.TypeVolume, Target: "/foo"}, nil},
|
|
{mount.Mount{Type: mount.TypeBind}, errMissingField("Target")},
|
|
{mount.Mount{Type: mount.TypeBind, Target: "/foo"}, errMissingField("Source")},
|
|
{mount.Mount{Type: mount.TypeBind, Target: "/foo", Source: "c:\\foo", VolumeOptions: &mount.VolumeOptions{}}, errExtraField("VolumeOptions")},
|
|
{mount.Mount{Type: mount.TypeBind, Source: "c:\\foo", Target: "/foo"}, errBindSourceDoesNotExist("c:\\foo")},
|
|
{mount.Mount{Type: mount.TypeBind, Source: testDir, Target: "/foo"}, nil},
|
|
{mount.Mount{Type: "invalid", Target: "/foo"}, errors.New("mount type unknown")},
|
|
}
|
|
parser := NewParser(runtime.GOOS)
|
|
for i, x := range cases {
|
|
err := parser.ValidateMountConfig(&x.input)
|
|
if err == nil && x.expected == nil {
|
|
continue
|
|
}
|
|
if (err == nil && x.expected != nil) || (x.expected == nil && err != nil) || !strings.Contains(err.Error(), x.expected.Error()) {
|
|
t.Errorf("expected %q, got %q, case: %d", x.expected, err, i)
|
|
}
|
|
}
|
|
if runtime.GOOS == "windows" {
|
|
parser = &lcowParser{}
|
|
for i, x := range lcowCases {
|
|
err := parser.ValidateMountConfig(&x.input)
|
|
if err == nil && x.expected == nil {
|
|
continue
|
|
}
|
|
if (err == nil && x.expected != nil) || (x.expected == nil && err != nil) || !strings.Contains(err.Error(), x.expected.Error()) {
|
|
t.Errorf("expected %q, got %q, case: %d", x.expected, err, i)
|
|
}
|
|
}
|
|
}
|
|
}
|