mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
553b0edb4c
These seemed to prevent cleaning up directories; On arm64: === RUN TestSysctlOverride testing.go:1090: TempDir RemoveAll cleanup: unlinkat /tmp/TestSysctlOverride2860094781/001/mounts/shm: device or resource busy --- FAIL: TestSysctlOverride (0.00s) On Windows: === Failed === FAIL: github.com/docker/docker/daemon TestLoadOrCreateTrustKeyInvalidKeyFile (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestLoadOrCreateTrustKeyInvalidKeyFile2014634395\001\keyfile4156691647: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/daemon/graphdriver TestIsEmptyDir (0.01s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestIsEmptyDir1962964337\001\dir-with-empty-file\file2523853824: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/pkg/directory TestSizeEmptyFile (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestSizeEmptyFile1562416712\001\file16507846: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/pkg/directory TestSizeNonemptyFile (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestSizeNonemptyFile1240832785\001\file3265662846: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/pkg/directory TestSizeFileAndNestedDirectoryEmpty (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestSizeFileAndNestedDirectoryEmpty2163416550\001\file3715413181: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/pkg/directory TestSizeFileAndNestedDirectoryNonempty (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestSizeFileAndNestedDirectoryNonempty878205470\001\file3280422273: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/volume/service TestSetGetMeta (0.01s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestSetGetMeta3332268057\001\db: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/volume/service TestList (0.03s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestList2846947953\001\volumes\metadata.db: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/volume/service TestRestore (0.02s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestRestore3368254142\001\volumes\metadata.db: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/daemon/graphdriver TestIsEmptyDir (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestIsEmptyDir2823795693\001\dir-with-empty-file\file2625561089: The process cannot access the file because it is being used by another process. === FAIL: github.com/docker/docker/pkg/directory TestSizeFileAndNestedDirectoryNonempty (0.00s) testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\CONTAI~1\AppData\Local\Temp\TestSizeFileAndNestedDirectoryNonempty4246252950\001\nested3442260313\file21164327: The process cannot access the file because it is being used by another process. Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
197 lines
5.6 KiB
Go
197 lines
5.6 KiB
Go
package directory // import "github.com/docker/docker/pkg/directory"
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
"path/filepath"
|
|
"reflect"
|
|
"sort"
|
|
"testing"
|
|
)
|
|
|
|
// Size of an empty directory should be 0
|
|
func TestSizeEmpty(t *testing.T) {
|
|
var dir string
|
|
var err error
|
|
if dir, err = os.MkdirTemp(os.TempDir(), "testSizeEmptyDirectory"); err != nil {
|
|
t.Fatalf("failed to create directory: %s", err)
|
|
}
|
|
|
|
var size int64
|
|
if size, _ = Size(context.Background(), dir); size != 0 {
|
|
t.Fatalf("empty directory has size: %d", size)
|
|
}
|
|
}
|
|
|
|
// Size of a directory with one empty file should be 0
|
|
func TestSizeEmptyFile(t *testing.T) {
|
|
var dir string
|
|
var err error
|
|
if dir, err = os.MkdirTemp(os.TempDir(), "testSizeEmptyFile"); err != nil {
|
|
t.Fatalf("failed to create directory: %s", err)
|
|
}
|
|
|
|
var file *os.File
|
|
if file, err = os.CreateTemp(dir, "file"); err != nil {
|
|
t.Fatalf("failed to create file: %s", err)
|
|
}
|
|
defer file.Close()
|
|
|
|
var size int64
|
|
if size, _ = Size(context.Background(), file.Name()); size != 0 {
|
|
t.Fatalf("directory with one file has size: %d", size)
|
|
}
|
|
}
|
|
|
|
// Size of a directory with one 5-byte file should be 5
|
|
func TestSizeNonemptyFile(t *testing.T) {
|
|
var dir string
|
|
var err error
|
|
if dir, err = os.MkdirTemp(os.TempDir(), "testSizeNonemptyFile"); err != nil {
|
|
t.Fatalf("failed to create directory: %s", err)
|
|
}
|
|
|
|
var file *os.File
|
|
if file, err = os.CreateTemp(dir, "file"); err != nil {
|
|
t.Fatalf("failed to create file: %s", err)
|
|
}
|
|
defer file.Close()
|
|
|
|
d := []byte{97, 98, 99, 100, 101}
|
|
file.Write(d)
|
|
|
|
var size int64
|
|
if size, _ = Size(context.Background(), file.Name()); size != 5 {
|
|
t.Fatalf("directory with one 5-byte file has size: %d", size)
|
|
}
|
|
}
|
|
|
|
// Size of a directory with one empty directory should be 0
|
|
func TestSizeNestedDirectoryEmpty(t *testing.T) {
|
|
var dir string
|
|
var err error
|
|
if dir, err = os.MkdirTemp(os.TempDir(), "testSizeNestedDirectoryEmpty"); err != nil {
|
|
t.Fatalf("failed to create directory: %s", err)
|
|
}
|
|
if dir, err = os.MkdirTemp(dir, "nested"); err != nil {
|
|
t.Fatalf("failed to create nested directory: %s", err)
|
|
}
|
|
|
|
var size int64
|
|
if size, _ = Size(context.Background(), dir); size != 0 {
|
|
t.Fatalf("directory with one empty directory has size: %d", size)
|
|
}
|
|
}
|
|
|
|
// Test directory with 1 file and 1 empty directory
|
|
func TestSizeFileAndNestedDirectoryEmpty(t *testing.T) {
|
|
var dir string
|
|
var err error
|
|
if dir, err = os.MkdirTemp(os.TempDir(), "testSizeFileAndNestedDirectoryEmpty"); err != nil {
|
|
t.Fatalf("failed to create directory: %s", err)
|
|
}
|
|
if dir, err = os.MkdirTemp(dir, "nested"); err != nil {
|
|
t.Fatalf("failed to create nested directory: %s", err)
|
|
}
|
|
|
|
var file *os.File
|
|
if file, err = os.CreateTemp(dir, "file"); err != nil {
|
|
t.Fatalf("failed to create file: %s", err)
|
|
}
|
|
defer file.Close()
|
|
|
|
d := []byte{100, 111, 99, 107, 101, 114}
|
|
file.Write(d)
|
|
|
|
var size int64
|
|
if size, _ = Size(context.Background(), dir); size != 6 {
|
|
t.Fatalf("directory with 6-byte file and empty directory has size: %d", size)
|
|
}
|
|
}
|
|
|
|
// Test directory with 1 file and 1 non-empty directory
|
|
func TestSizeFileAndNestedDirectoryNonempty(t *testing.T) {
|
|
var dir, dirNested string
|
|
var err error
|
|
if dir, err = os.MkdirTemp(os.TempDir(), "TestSizeFileAndNestedDirectoryNonempty"); err != nil {
|
|
t.Fatalf("failed to create directory: %s", err)
|
|
}
|
|
if dirNested, err = os.MkdirTemp(dir, "nested"); err != nil {
|
|
t.Fatalf("failed to create nested directory: %s", err)
|
|
}
|
|
|
|
var file *os.File
|
|
if file, err = os.CreateTemp(dir, "file"); err != nil {
|
|
t.Fatalf("failed to create file: %s", err)
|
|
}
|
|
defer file.Close()
|
|
|
|
data := []byte{100, 111, 99, 107, 101, 114}
|
|
file.Write(data)
|
|
|
|
var nestedFile *os.File
|
|
if nestedFile, err = os.CreateTemp(dirNested, "file"); err != nil {
|
|
t.Fatalf("failed to create file in nested directory: %s", err)
|
|
}
|
|
defer nestedFile.Close()
|
|
|
|
nestedData := []byte{100, 111, 99, 107, 101, 114}
|
|
nestedFile.Write(nestedData)
|
|
|
|
var size int64
|
|
if size, _ = Size(context.Background(), dir); size != 12 {
|
|
t.Fatalf("directory with 6-byte file and nested directory with 6-byte file has size: %d", size)
|
|
}
|
|
}
|
|
|
|
// Test migration of directory to a subdir underneath itself
|
|
func TestMoveToSubdir(t *testing.T) {
|
|
var outerDir, subDir string
|
|
var err error
|
|
|
|
if outerDir, err = os.MkdirTemp(os.TempDir(), "TestMoveToSubdir"); err != nil {
|
|
t.Fatalf("failed to create directory: %v", err)
|
|
}
|
|
|
|
if subDir, err = os.MkdirTemp(outerDir, "testSub"); err != nil {
|
|
t.Fatalf("failed to create subdirectory: %v", err)
|
|
}
|
|
|
|
// write 4 temp files in the outer dir to get moved
|
|
filesList := []string{"a", "b", "c", "d"}
|
|
for _, fName := range filesList {
|
|
if file, err := os.Create(filepath.Join(outerDir, fName)); err != nil {
|
|
t.Fatalf("couldn't create temp file %q: %v", fName, err)
|
|
} else {
|
|
file.WriteString(fName)
|
|
file.Close()
|
|
}
|
|
}
|
|
|
|
if err = MoveToSubdir(outerDir, filepath.Base(subDir)); err != nil {
|
|
t.Fatalf("Error during migration of content to subdirectory: %v", err)
|
|
}
|
|
// validate that the files were moved to the subdirectory
|
|
infos, err := os.ReadDir(subDir)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if len(infos) != 4 {
|
|
t.Fatalf("Should be four files in the subdir after the migration: actual length: %d", len(infos))
|
|
}
|
|
var results []string
|
|
for _, info := range infos {
|
|
results = append(results, info.Name())
|
|
}
|
|
sort.Strings(results)
|
|
if !reflect.DeepEqual(filesList, results) {
|
|
t.Fatalf("Results after migration do not equal list of files: expected: %v, got: %v", filesList, results)
|
|
}
|
|
}
|
|
|
|
// Test a non-existing directory
|
|
func TestSizeNonExistingDirectory(t *testing.T) {
|
|
if _, err := Size(context.Background(), "/thisdirectoryshouldnotexist/TestSizeNonExistingDirectory"); err == nil {
|
|
t.Fatalf("error is expected")
|
|
}
|
|
}
|