|
@@ -10,7 +10,7 @@ import (
|
|
|
"testing"
|
|
|
|
|
|
"github.com/docker/docker/volume"
|
|
|
- "github.com/docker/docker/volume/drivers"
|
|
|
+ volumedrivers "github.com/docker/docker/volume/drivers"
|
|
|
volumetestutils "github.com/docker/docker/volume/testutils"
|
|
|
"github.com/google/go-cmp/cmp"
|
|
|
"github.com/gotestyourself/gotestyourself/assert"
|
|
@@ -18,18 +18,12 @@ import (
|
|
|
)
|
|
|
|
|
|
func TestCreate(t *testing.T) {
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
- defer volumedrivers.Unregister("fake")
|
|
|
- dir, err := ioutil.TempDir("", "test-create")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
- defer os.RemoveAll(dir)
|
|
|
+ t.Parallel()
|
|
|
+
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
v, err := s.Create("fake1", "fake", nil, nil)
|
|
|
if err != nil {
|
|
|
t.Fatal(err)
|
|
@@ -53,19 +47,13 @@ func TestCreate(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestRemove(t *testing.T) {
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("noop"), "noop")
|
|
|
- defer volumedrivers.Unregister("fake")
|
|
|
- defer volumedrivers.Unregister("noop")
|
|
|
- dir, err := ioutil.TempDir("", "test-remove")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
- defer os.RemoveAll(dir)
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ t.Parallel()
|
|
|
+
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("noop"), "noop")
|
|
|
|
|
|
// doing string compare here since this error comes directly from the driver
|
|
|
expected := "no such volume"
|
|
@@ -91,20 +79,19 @@ func TestRemove(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestList(t *testing.T) {
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake2"), "fake2")
|
|
|
- defer volumedrivers.Unregister("fake")
|
|
|
- defer volumedrivers.Unregister("fake2")
|
|
|
+ t.Parallel()
|
|
|
+
|
|
|
dir, err := ioutil.TempDir("", "test-list")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ assert.NilError(t, err)
|
|
|
defer os.RemoveAll(dir)
|
|
|
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ drivers := volumedrivers.NewStore(nil)
|
|
|
+ drivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
+ drivers.Register(volumetestutils.NewFakeDriver("fake2"), "fake2")
|
|
|
+
|
|
|
+ s, err := New(dir, drivers)
|
|
|
+ assert.NilError(t, err)
|
|
|
+
|
|
|
if _, err := s.Create("test", "fake", nil, nil); err != nil {
|
|
|
t.Fatal(err)
|
|
|
}
|
|
@@ -124,7 +111,7 @@ func TestList(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
// and again with a new store
|
|
|
- s, err = New(dir)
|
|
|
+ s, err = New(dir, drivers)
|
|
|
if err != nil {
|
|
|
t.Fatal(err)
|
|
|
}
|
|
@@ -138,18 +125,12 @@ func TestList(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestFilterByDriver(t *testing.T) {
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("noop"), "noop")
|
|
|
- defer volumedrivers.Unregister("fake")
|
|
|
- defer volumedrivers.Unregister("noop")
|
|
|
- dir, err := ioutil.TempDir("", "test-filter-driver")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ t.Parallel()
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("noop"), "noop")
|
|
|
|
|
|
if _, err := s.Create("fake1", "fake", nil, nil); err != nil {
|
|
|
t.Fatal(err)
|
|
@@ -171,17 +152,12 @@ func TestFilterByDriver(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestFilterByUsed(t *testing.T) {
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("noop"), "noop")
|
|
|
- dir, err := ioutil.TempDir("", "test-filter-used")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ t.Parallel()
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("noop"), "noop")
|
|
|
|
|
|
if _, err := s.CreateWithRef("fake1", "fake", "volReference", nil, nil); err != nil {
|
|
|
t.Fatal(err)
|
|
@@ -213,16 +189,10 @@ func TestFilterByUsed(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestDerefMultipleOfSameRef(t *testing.T) {
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
- dir, err := ioutil.TempDir("", "test-same-deref")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
- defer os.RemoveAll(dir)
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ t.Parallel()
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver("fake"), "fake")
|
|
|
|
|
|
v, err := s.CreateWithRef("fake1", "fake", "volReference", nil, nil)
|
|
|
if err != nil {
|
|
@@ -240,17 +210,12 @@ func TestDerefMultipleOfSameRef(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestCreateKeepOptsLabelsWhenExistsRemotely(t *testing.T) {
|
|
|
+ t.Parallel()
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+
|
|
|
vd := volumetestutils.NewFakeDriver("fake")
|
|
|
- volumedrivers.Register(vd, "fake")
|
|
|
- dir, err := ioutil.TempDir("", "test-same-deref")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
- defer os.RemoveAll(dir)
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ s.drivers.Register(vd, "fake")
|
|
|
|
|
|
// Create a volume in the driver directly
|
|
|
if _, err := vd.Create("foo", nil); err != nil {
|
|
@@ -273,6 +238,8 @@ func TestCreateKeepOptsLabelsWhenExistsRemotely(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
func TestDefererencePluginOnCreateError(t *testing.T) {
|
|
|
+ t.Parallel()
|
|
|
+
|
|
|
var (
|
|
|
l net.Listener
|
|
|
err error
|
|
@@ -286,6 +253,9 @@ func TestDefererencePluginOnCreateError(t *testing.T) {
|
|
|
}
|
|
|
defer l.Close()
|
|
|
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+
|
|
|
d := volumetestutils.NewFakeDriver("TestDefererencePluginOnCreateError")
|
|
|
p, err := volumetestutils.MakeFakePlugin(d, l)
|
|
|
if err != nil {
|
|
@@ -293,19 +263,7 @@ func TestDefererencePluginOnCreateError(t *testing.T) {
|
|
|
}
|
|
|
|
|
|
pg := volumetestutils.NewFakePluginGetter(p)
|
|
|
- volumedrivers.RegisterPluginGetter(pg)
|
|
|
- defer volumedrivers.RegisterPluginGetter(nil)
|
|
|
-
|
|
|
- dir, err := ioutil.TempDir("", "test-plugin-deref-err")
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
- defer os.RemoveAll(dir)
|
|
|
-
|
|
|
- s, err := New(dir)
|
|
|
- if err != nil {
|
|
|
- t.Fatal(err)
|
|
|
- }
|
|
|
+ s.drivers = volumedrivers.NewStore(pg)
|
|
|
|
|
|
// create a good volume so we have a plugin reference
|
|
|
_, err = s.Create("fake1", d.Name(), nil, nil)
|
|
@@ -329,8 +287,9 @@ func TestRefDerefRemove(t *testing.T) {
|
|
|
t.Parallel()
|
|
|
|
|
|
driverName := "test-ref-deref-remove"
|
|
|
- s, cleanup := setupTest(t, driverName)
|
|
|
- defer cleanup(t)
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver(driverName), driverName)
|
|
|
|
|
|
v, err := s.CreateWithRef("test", driverName, "test-ref", nil, nil)
|
|
|
assert.NilError(t, err)
|
|
@@ -348,8 +307,9 @@ func TestGet(t *testing.T) {
|
|
|
t.Parallel()
|
|
|
|
|
|
driverName := "test-get"
|
|
|
- s, cleanup := setupTest(t, driverName)
|
|
|
- defer cleanup(t)
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver(driverName), driverName)
|
|
|
|
|
|
_, err := s.Get("not-exist")
|
|
|
assert.Assert(t, is.ErrorContains(err, ""))
|
|
@@ -373,8 +333,9 @@ func TestGetWithRef(t *testing.T) {
|
|
|
t.Parallel()
|
|
|
|
|
|
driverName := "test-get-with-ref"
|
|
|
- s, cleanup := setupTest(t, driverName)
|
|
|
- defer cleanup(t)
|
|
|
+ s, cleanup := setupTest(t)
|
|
|
+ defer cleanup()
|
|
|
+ s.drivers.Register(volumetestutils.NewFakeDriver(driverName), driverName)
|
|
|
|
|
|
_, err := s.GetWithRef("not-exist", driverName, "test-ref")
|
|
|
assert.Assert(t, is.ErrorContains(err, ""))
|
|
@@ -397,32 +358,22 @@ func TestGetWithRef(t *testing.T) {
|
|
|
|
|
|
var cmpVolume = cmp.AllowUnexported(volumetestutils.FakeVolume{}, volumeWrapper{})
|
|
|
|
|
|
-func setupTest(t *testing.T, name string) (*VolumeStore, func(*testing.T)) {
|
|
|
- t.Helper()
|
|
|
- s, cleanup := newTestStore(t)
|
|
|
-
|
|
|
- volumedrivers.Register(volumetestutils.NewFakeDriver(name), name)
|
|
|
- return s, func(t *testing.T) {
|
|
|
- cleanup(t)
|
|
|
- volumedrivers.Unregister(name)
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-func newTestStore(t *testing.T) (*VolumeStore, func(*testing.T)) {
|
|
|
+func setupTest(t *testing.T) (*VolumeStore, func()) {
|
|
|
t.Helper()
|
|
|
|
|
|
- dir, err := ioutil.TempDir("", "store-root")
|
|
|
+ dirName := strings.Replace(t.Name(), string(os.PathSeparator), "_", -1)
|
|
|
+ dir, err := ioutil.TempDir("", dirName)
|
|
|
assert.NilError(t, err)
|
|
|
|
|
|
- cleanup := func(t *testing.T) {
|
|
|
+ cleanup := func() {
|
|
|
err := os.RemoveAll(dir)
|
|
|
assert.Check(t, err)
|
|
|
}
|
|
|
|
|
|
- s, err := New(dir)
|
|
|
+ s, err := New(dir, volumedrivers.NewStore(nil))
|
|
|
assert.Check(t, err)
|
|
|
- return s, func(t *testing.T) {
|
|
|
+ return s, func() {
|
|
|
s.Shutdown()
|
|
|
- cleanup(t)
|
|
|
+ cleanup()
|
|
|
}
|
|
|
}
|