snapshots: separate implementations into packages

Signed-off-by: Stephen J Day <stephen.day@docker.com>
This commit is contained in:
Stephen J Day 2017-01-13 15:31:21 -08:00
parent c7f77f475a
commit e3f83fd53d
8 changed files with 22 additions and 16 deletions

View file

@ -1,6 +1,7 @@
package snapshot package btrfs
import ( import (
"crypto/sha256"
"fmt" "fmt"
"os" "os"
"path/filepath" "path/filepath"
@ -26,7 +27,6 @@ func (lm *Btrfs) Prepare(key, parent string) ([]containerd.Mount, error) {
dir := filepath.Join(active, hash(key)) dir := filepath.Join(active, hash(key))
fmt.Println("dir", dir)
if parent == "" { if parent == "" {
// create new subvolume // create new subvolume
// btrfs subvolume create /dir // btrfs subvolume create /dir
@ -69,3 +69,7 @@ func (lm *Btrfs) Commit(name, key string) error {
return btrfs.SubvolDelete(dir) return btrfs.SubvolDelete(dir)
} }
func hash(k string) string {
return fmt.Sprintf("%x", sha256.Sum224([]byte(k)))
}

View file

@ -1,4 +1,4 @@
package snapshot package btrfs
import ( import (
"bytes" "bytes"
@ -10,6 +10,7 @@ import (
"testing" "testing"
"github.com/docker/containerd" "github.com/docker/containerd"
"github.com/docker/containerd/snapshot/testutil"
btrfs "github.com/stevvooe/go-btrfs" btrfs "github.com/stevvooe/go-btrfs"
) )
@ -53,7 +54,7 @@ func TestBtrfs(t *testing.T) {
if err := containerd.MountAll(mounts...); err != nil { if err := containerd.MountAll(mounts...); err != nil {
t.Fatal(err) t.Fatal(err)
} }
defer unmountAll(t, mounts) defer testutil.UnmountAll(t, mounts)
// write in some data // write in some data
if err := ioutil.WriteFile(filepath.Join(mounts[0].Target, "foo"), []byte("content"), 0777); err != nil { if err := ioutil.WriteFile(filepath.Join(mounts[0].Target, "foo"), []byte("content"), 0777); err != nil {
@ -89,7 +90,7 @@ func TestBtrfs(t *testing.T) {
if err := containerd.MountAll(mounts...); err != nil { if err := containerd.MountAll(mounts...); err != nil {
t.Fatal(err) t.Fatal(err)
} }
defer unmountAll(t, mounts) defer testutil.UnmountAll(t, mounts)
// TODO(stevvooe): Verify contents of "foo" // TODO(stevvooe): Verify contents of "foo"
if err := ioutil.WriteFile(filepath.Join(mounts[0].Target, "bar"), []byte("content"), 0777); err != nil { if err := ioutil.WriteFile(filepath.Join(mounts[0].Target, "bar"), []byte("content"), 0777); err != nil {
@ -182,7 +183,7 @@ func setupBtrfsLoopbackDevice(t *testing.T) *testDevice {
// file holding the disk image. // file holding the disk image.
func removeBtrfsLoopbackDevice(t *testing.T, device *testDevice) { func removeBtrfsLoopbackDevice(t *testing.T, device *testDevice) {
// unmount // unmount
unmount(t, device.mountPoint) testutil.Unmount(t, device.mountPoint)
// detach device // detach device
t.Log("Removing loop device") t.Log("Removing loop device")

View file

@ -8,6 +8,7 @@ import (
"testing" "testing"
"github.com/docker/containerd" "github.com/docker/containerd"
"github.com/docker/containerd/snapshot/testutil"
) )
// TestSnapshotManagerBasic implements something similar to the conceptual // TestSnapshotManagerBasic implements something similar to the conceptual
@ -58,7 +59,7 @@ func TestSnapshotManagerBasic(t *testing.T) {
if err := containerd.MountAll(mounts...); err != nil { if err := containerd.MountAll(mounts...); err != nil {
t.Fatal(err) t.Fatal(err)
} }
defer unmountAll(t, mounts) defer testutil.UnmountAll(t, mounts)
if err := ioutil.WriteFile(filepath.Join(preparing, "foo"), []byte("foo\n"), 0777); err != nil { if err := ioutil.WriteFile(filepath.Join(preparing, "foo"), []byte("foo\n"), 0777); err != nil {
t.Fatal(err) t.Fatal(err)
@ -88,7 +89,7 @@ func TestSnapshotManagerBasic(t *testing.T) {
if err := containerd.MountAll(mounts...); err != nil { if err := containerd.MountAll(mounts...); err != nil {
t.Fatal(err) t.Fatal(err)
} }
defer unmountAll(t, mounts) defer testutil.UnmountAll(t, mounts)
for _, mount := range mounts { for _, mount := range mounts {
if !strings.HasPrefix(mount.Target, next) { if !strings.HasPrefix(mount.Target, next) {

View file

@ -1,4 +1,4 @@
package snapshot package naive
import ( import (
"fmt" "fmt"

View file

@ -1,4 +1,4 @@
package snapshot package naive
import ( import (
"io/ioutil" "io/ioutil"

View file

@ -1,4 +1,4 @@
package snapshot package overlay
import ( import (
"crypto/md5" "crypto/md5"

View file

@ -1,4 +1,4 @@
package snapshot package overlay
import ( import (
"io/ioutil" "io/ioutil"

View file

@ -1,4 +1,4 @@
package snapshot package testutil
import ( import (
"os/exec" "os/exec"
@ -7,13 +7,13 @@ import (
"github.com/docker/containerd" "github.com/docker/containerd"
) )
func unmountAll(t *testing.T, mounts []containerd.Mount) { func UnmountAll(t *testing.T, mounts []containerd.Mount) {
for _, mount := range mounts { for _, mount := range mounts {
unmount(t, mount.Target) Unmount(t, mount.Target)
} }
} }
func unmount(t *testing.T, mountPoint string) { func Unmount(t *testing.T, mountPoint string) {
t.Log("unmount", mountPoint) t.Log("unmount", mountPoint)
umount := exec.Command("umount", mountPoint) umount := exec.Command("umount", mountPoint)
err := umount.Run() err := umount.Run()