test: use T.TempDir to create temporary test directory
The directory created by `T.TempDir` is automatically removed when the test and all its subtests complete. Reference: https://pkg.go.dev/testing#T.TempDir Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
This commit is contained in:
@@ -122,10 +122,7 @@ func TestCompressDecompressUncompressed(t *testing.T) {
|
||||
|
||||
func TestDetectPigz(t *testing.T) {
|
||||
// Create fake PATH with unpigz executable, make sure detectPigz can find it
|
||||
tempPath, err := os.MkdirTemp("", "containerd_temp_")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
tempPath := t.TempDir()
|
||||
|
||||
filename := "unpigz"
|
||||
if runtime.GOOS == "windows" {
|
||||
@@ -138,8 +135,6 @@ func TestDetectPigz(t *testing.T) {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
defer os.RemoveAll(tempPath)
|
||||
|
||||
oldPath := os.Getenv("PATH")
|
||||
os.Setenv("PATH", tempPath)
|
||||
defer os.Setenv("PATH", oldPath)
|
||||
|
||||
@@ -36,11 +36,7 @@ func TestPrefixHeaderReadable(t *testing.T) {
|
||||
// https://gist.github.com/stevvooe/e2a790ad4e97425896206c0816e1a882#file-out-go
|
||||
var testFile = []byte("\x1f\x8b\x08\x08\x44\x21\x68\x59\x00\x03\x74\x2e\x74\x61\x72\x00\x4b\xcb\xcf\x67\xa0\x35\x30\x80\x00\x86\x06\x10\x47\x01\xc1\x37\x40\x00\x54\xb6\xb1\xa1\xa9\x99\x09\x48\x25\x1d\x40\x69\x71\x49\x62\x91\x02\xe5\x76\xa1\x79\x84\x21\x91\xd6\x80\x72\xaf\x8f\x82\x51\x30\x0a\x46\x36\x00\x00\xf0\x1c\x1e\x95\x00\x06\x00\x00")
|
||||
|
||||
tmpDir, err := os.MkdirTemp("", "prefix-test")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
defer os.RemoveAll(tmpDir)
|
||||
tmpDir := t.TempDir()
|
||||
|
||||
r, err := compression.DecompressStream(bytes.NewReader(testFile))
|
||||
if err != nil {
|
||||
|
||||
@@ -36,11 +36,7 @@ import (
|
||||
func TestOverlayApply(t *testing.T) {
|
||||
testutil.RequiresRoot(t)
|
||||
|
||||
base, err := os.MkdirTemp("", "test-ovl-diff-apply-")
|
||||
if err != nil {
|
||||
t.Fatalf("unable to create temp dir: %+v", err)
|
||||
}
|
||||
defer os.RemoveAll(base)
|
||||
base := t.TempDir()
|
||||
|
||||
if err := overlayutils.Supported(base); err != nil {
|
||||
t.Skipf("skipping because overlay is not supported %v", err)
|
||||
@@ -55,11 +51,7 @@ func TestOverlayApply(t *testing.T) {
|
||||
func TestOverlayApplyNoParents(t *testing.T) {
|
||||
testutil.RequiresRoot(t)
|
||||
|
||||
base, err := os.MkdirTemp("", "test-ovl-diff-apply-")
|
||||
if err != nil {
|
||||
t.Fatalf("unable to create temp dir: %+v", err)
|
||||
}
|
||||
defer os.RemoveAll(base)
|
||||
base := t.TempDir()
|
||||
|
||||
if err := overlayutils.Supported(base); err != nil {
|
||||
t.Skipf("skipping because overlay is not supported %v", err)
|
||||
|
||||
@@ -23,6 +23,7 @@ import (
|
||||
"archive/tar"
|
||||
"bytes"
|
||||
"context"
|
||||
_ "crypto/sha256"
|
||||
"errors"
|
||||
"fmt"
|
||||
"io"
|
||||
@@ -31,8 +32,6 @@ import (
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
_ "crypto/sha256"
|
||||
|
||||
"github.com/containerd/containerd/archive/tartest"
|
||||
"github.com/containerd/containerd/pkg/testutil"
|
||||
"github.com/containerd/continuity/fs"
|
||||
@@ -58,7 +57,7 @@ var baseApplier = fstest.Apply(
|
||||
func TestUnpack(t *testing.T) {
|
||||
requireTar(t)
|
||||
|
||||
if err := testApply(baseApplier); err != nil {
|
||||
if err := testApply(t, baseApplier); err != nil {
|
||||
t.Fatalf("Test apply failed: %+v", err)
|
||||
}
|
||||
}
|
||||
@@ -66,7 +65,7 @@ func TestUnpack(t *testing.T) {
|
||||
func TestBaseDiff(t *testing.T) {
|
||||
requireTar(t)
|
||||
|
||||
if err := testBaseDiff(baseApplier); err != nil {
|
||||
if err := testBaseDiff(t, baseApplier); err != nil {
|
||||
t.Fatalf("Test base diff failed: %+v", err)
|
||||
}
|
||||
}
|
||||
@@ -102,7 +101,7 @@ func TestRelativeSymlinks(t *testing.T) {
|
||||
}
|
||||
|
||||
for _, bo := range breakoutLinks {
|
||||
if err := testDiffApply(bo); err != nil {
|
||||
if err := testDiffApply(t, bo); err != nil {
|
||||
t.Fatalf("Test apply failed: %+v", err)
|
||||
}
|
||||
}
|
||||
@@ -179,7 +178,7 @@ func TestSymlinks(t *testing.T) {
|
||||
}
|
||||
|
||||
for i, l := range links {
|
||||
if err := testDiffApply(l[0], l[1]); err != nil {
|
||||
if err := testDiffApply(t, l[0], l[1]); err != nil {
|
||||
t.Fatalf("Test[%d] apply failed: %+v", i+1, err)
|
||||
}
|
||||
}
|
||||
@@ -243,11 +242,7 @@ func TestBreakouts(t *testing.T) {
|
||||
return nil
|
||||
}
|
||||
errFileDiff := errors.New("files differ")
|
||||
td, err := os.MkdirTemp("", "test-breakouts-")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
defer os.RemoveAll(td)
|
||||
td := t.TempDir()
|
||||
|
||||
isSymlinkFile := func(f string) func(string) error {
|
||||
return func(root string) error {
|
||||
@@ -841,17 +836,9 @@ func TestApplyTar(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func testApply(a fstest.Applier) error {
|
||||
td, err := os.MkdirTemp("", "test-apply-")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create temp dir: %w", err)
|
||||
}
|
||||
defer os.RemoveAll(td)
|
||||
dest, err := os.MkdirTemp("", "test-apply-dest-")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create temp dir: %w", err)
|
||||
}
|
||||
defer os.RemoveAll(dest)
|
||||
func testApply(t *testing.T, a fstest.Applier) error {
|
||||
td := t.TempDir()
|
||||
dest := t.TempDir()
|
||||
|
||||
if err := a.Apply(td); err != nil {
|
||||
return fmt.Errorf("failed to apply filesystem changes: %w", err)
|
||||
@@ -882,17 +869,9 @@ func testApply(a fstest.Applier) error {
|
||||
return fstest.CheckDirectoryEqual(td, dest)
|
||||
}
|
||||
|
||||
func testBaseDiff(a fstest.Applier) error {
|
||||
td, err := os.MkdirTemp("", "test-base-diff-")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create temp dir: %w", err)
|
||||
}
|
||||
defer os.RemoveAll(td)
|
||||
dest, err := os.MkdirTemp("", "test-base-diff-dest-")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create temp dir: %w", err)
|
||||
}
|
||||
defer os.RemoveAll(dest)
|
||||
func testBaseDiff(t *testing.T, a fstest.Applier) error {
|
||||
td := t.TempDir()
|
||||
dest := t.TempDir()
|
||||
|
||||
if err := a.Apply(td); err != nil {
|
||||
return fmt.Errorf("failed to apply filesystem changes: %w", err)
|
||||
@@ -909,17 +888,9 @@ func testBaseDiff(a fstest.Applier) error {
|
||||
return fstest.CheckDirectoryEqual(td, dest)
|
||||
}
|
||||
|
||||
func testDiffApply(appliers ...fstest.Applier) error {
|
||||
td, err := os.MkdirTemp("", "test-diff-apply-")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create temp dir: %w", err)
|
||||
}
|
||||
defer os.RemoveAll(td)
|
||||
dest, err := os.MkdirTemp("", "test-diff-apply-dest-")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create temp dir: %w", err)
|
||||
}
|
||||
defer os.RemoveAll(dest)
|
||||
func testDiffApply(t *testing.T, appliers ...fstest.Applier) error {
|
||||
td := t.TempDir()
|
||||
dest := t.TempDir()
|
||||
|
||||
for _, a := range appliers {
|
||||
if err := a.Apply(td); err != nil {
|
||||
@@ -950,11 +921,7 @@ func testDiffApply(appliers ...fstest.Applier) error {
|
||||
|
||||
func makeWriterToTarTest(wt tartest.WriterToTar, a fstest.Applier, validate func(string) error, applyErr error) func(*testing.T) {
|
||||
return func(t *testing.T) {
|
||||
td, err := os.MkdirTemp("", "test-writer-to-tar-")
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to create temp dir: %v", err)
|
||||
}
|
||||
defer os.RemoveAll(td)
|
||||
td := t.TempDir()
|
||||
|
||||
if a != nil {
|
||||
if err := a.Apply(td); err != nil {
|
||||
@@ -1254,20 +1221,12 @@ func whiteoutEntry(name string) tarEntryValidator {
|
||||
|
||||
func makeDiffTarTest(validators []tarEntryValidator, a, b fstest.Applier) func(*testing.T) {
|
||||
return func(t *testing.T) {
|
||||
ad, err := os.MkdirTemp("", "test-make-diff-tar-")
|
||||
if err != nil {
|
||||
t.Fatalf("failed to create temp dir: %v", err)
|
||||
}
|
||||
defer os.RemoveAll(ad)
|
||||
ad := t.TempDir()
|
||||
if err := a.Apply(ad); err != nil {
|
||||
t.Fatalf("failed to apply a: %v", err)
|
||||
}
|
||||
|
||||
bd, err := os.MkdirTemp("", "test-make-diff-tar-")
|
||||
if err != nil {
|
||||
t.Fatalf("failed to create temp dir: %v", err)
|
||||
}
|
||||
defer os.RemoveAll(bd)
|
||||
bd := t.TempDir()
|
||||
if err := fs.CopyDir(bd, ad); err != nil {
|
||||
t.Fatalf("failed to copy dir: %v", err)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user