github.com/lovishpuri/go-40569/src@v0.0.0-20230519171745-f8623e7c56cf/os/error_test.go (about)

     1  // Copyright 2012 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  package os_test
     6  
     7  import (
     8  	"errors"
     9  	"fmt"
    10  	"io/fs"
    11  	"os"
    12  	"path/filepath"
    13  	"testing"
    14  )
    15  
    16  func TestErrIsExist(t *testing.T) {
    17  	t.Parallel()
    18  
    19  	f, err := os.CreateTemp("", "_Go_ErrIsExist")
    20  	if err != nil {
    21  		t.Fatalf("open ErrIsExist tempfile: %s", err)
    22  		return
    23  	}
    24  	defer os.Remove(f.Name())
    25  	defer f.Close()
    26  	f2, err := os.OpenFile(f.Name(), os.O_RDWR|os.O_CREATE|os.O_EXCL, 0600)
    27  	if err == nil {
    28  		f2.Close()
    29  		t.Fatal("Open should have failed")
    30  	}
    31  	if s := checkErrorPredicate("os.IsExist", os.IsExist, err, fs.ErrExist); s != "" {
    32  		t.Fatal(s)
    33  	}
    34  }
    35  
    36  func testErrNotExist(t *testing.T, name string) string {
    37  	originalWD, err := os.Getwd()
    38  	if err != nil {
    39  		t.Fatal(err)
    40  	}
    41  
    42  	f, err := os.Open(name)
    43  	if err == nil {
    44  		f.Close()
    45  		return "Open should have failed"
    46  	}
    47  	if s := checkErrorPredicate("os.IsNotExist", os.IsNotExist, err, fs.ErrNotExist); s != "" {
    48  		return s
    49  	}
    50  
    51  	err = os.Chdir(name)
    52  	if err == nil {
    53  		if err := os.Chdir(originalWD); err != nil {
    54  			t.Fatalf("Chdir should have failed, failed to restore original working directory: %v", err)
    55  		}
    56  		return "Chdir should have failed, restored original working directory"
    57  	}
    58  	if s := checkErrorPredicate("os.IsNotExist", os.IsNotExist, err, fs.ErrNotExist); s != "" {
    59  		return s
    60  	}
    61  	return ""
    62  }
    63  
    64  func TestErrIsNotExist(t *testing.T) {
    65  	tmpDir := t.TempDir()
    66  	name := filepath.Join(tmpDir, "NotExists")
    67  	if s := testErrNotExist(t, name); s != "" {
    68  		t.Fatal(s)
    69  	}
    70  
    71  	name = filepath.Join(name, "NotExists2")
    72  	if s := testErrNotExist(t, name); s != "" {
    73  		t.Fatal(s)
    74  	}
    75  }
    76  
    77  func checkErrorPredicate(predName string, pred func(error) bool, err, target error) string {
    78  	if !pred(err) {
    79  		return fmt.Sprintf("%s does not work as expected for %#v", predName, err)
    80  	}
    81  	if !errors.Is(err, target) {
    82  		return fmt.Sprintf("errors.Is(%#v, %#v) = false, want true", err, target)
    83  	}
    84  	return ""
    85  }
    86  
    87  type isExistTest struct {
    88  	err   error
    89  	is    bool
    90  	isnot bool
    91  }
    92  
    93  var isExistTests = []isExistTest{
    94  	{&fs.PathError{Err: fs.ErrInvalid}, false, false},
    95  	{&fs.PathError{Err: fs.ErrPermission}, false, false},
    96  	{&fs.PathError{Err: fs.ErrExist}, true, false},
    97  	{&fs.PathError{Err: fs.ErrNotExist}, false, true},
    98  	{&fs.PathError{Err: fs.ErrClosed}, false, false},
    99  	{&os.LinkError{Err: fs.ErrInvalid}, false, false},
   100  	{&os.LinkError{Err: fs.ErrPermission}, false, false},
   101  	{&os.LinkError{Err: fs.ErrExist}, true, false},
   102  	{&os.LinkError{Err: fs.ErrNotExist}, false, true},
   103  	{&os.LinkError{Err: fs.ErrClosed}, false, false},
   104  	{&os.SyscallError{Err: fs.ErrNotExist}, false, true},
   105  	{&os.SyscallError{Err: fs.ErrExist}, true, false},
   106  	{nil, false, false},
   107  }
   108  
   109  func TestIsExist(t *testing.T) {
   110  	for _, tt := range isExistTests {
   111  		if is := os.IsExist(tt.err); is != tt.is {
   112  			t.Errorf("os.IsExist(%T %v) = %v, want %v", tt.err, tt.err, is, tt.is)
   113  		}
   114  		if is := errors.Is(tt.err, fs.ErrExist); is != tt.is {
   115  			t.Errorf("errors.Is(%T %v, fs.ErrExist) = %v, want %v", tt.err, tt.err, is, tt.is)
   116  		}
   117  		if isnot := os.IsNotExist(tt.err); isnot != tt.isnot {
   118  			t.Errorf("os.IsNotExist(%T %v) = %v, want %v", tt.err, tt.err, isnot, tt.isnot)
   119  		}
   120  		if isnot := errors.Is(tt.err, fs.ErrNotExist); isnot != tt.isnot {
   121  			t.Errorf("errors.Is(%T %v, fs.ErrNotExist) = %v, want %v", tt.err, tt.err, isnot, tt.isnot)
   122  		}
   123  	}
   124  }
   125  
   126  type isPermissionTest struct {
   127  	err  error
   128  	want bool
   129  }
   130  
   131  var isPermissionTests = []isPermissionTest{
   132  	{nil, false},
   133  	{&fs.PathError{Err: fs.ErrPermission}, true},
   134  	{&os.SyscallError{Err: fs.ErrPermission}, true},
   135  }
   136  
   137  func TestIsPermission(t *testing.T) {
   138  	for _, tt := range isPermissionTests {
   139  		if got := os.IsPermission(tt.err); got != tt.want {
   140  			t.Errorf("os.IsPermission(%#v) = %v; want %v", tt.err, got, tt.want)
   141  		}
   142  		if got := errors.Is(tt.err, fs.ErrPermission); got != tt.want {
   143  			t.Errorf("errors.Is(%#v, fs.ErrPermission) = %v; want %v", tt.err, got, tt.want)
   144  		}
   145  	}
   146  }
   147  
   148  func TestErrPathNUL(t *testing.T) {
   149  	t.Parallel()
   150  
   151  	f, err := os.CreateTemp("", "_Go_ErrPathNUL\x00")
   152  	if err == nil {
   153  		f.Close()
   154  		t.Fatal("TempFile should have failed")
   155  	}
   156  	f, err = os.CreateTemp("", "_Go_ErrPathNUL")
   157  	if err != nil {
   158  		t.Fatalf("open ErrPathNUL tempfile: %s", err)
   159  	}
   160  	defer os.Remove(f.Name())
   161  	defer f.Close()
   162  	f2, err := os.OpenFile(f.Name(), os.O_RDWR, 0600)
   163  	if err != nil {
   164  		t.Fatalf("open ErrPathNUL: %s", err)
   165  	}
   166  	f2.Close()
   167  	f2, err = os.OpenFile(f.Name()+"\x00", os.O_RDWR, 0600)
   168  	if err == nil {
   169  		f2.Close()
   170  		t.Fatal("Open should have failed")
   171  	}
   172  }
   173  
   174  func TestPathErrorUnwrap(t *testing.T) {
   175  	pe := &fs.PathError{Err: fs.ErrInvalid}
   176  	if !errors.Is(pe, fs.ErrInvalid) {
   177  		t.Error("errors.Is failed, wanted success")
   178  	}
   179  }
   180  
   181  type myErrorIs struct{ error }
   182  
   183  func (e myErrorIs) Is(target error) bool { return target == e.error }
   184  
   185  func TestErrorIsMethods(t *testing.T) {
   186  	if os.IsPermission(myErrorIs{fs.ErrPermission}) {
   187  		t.Error("os.IsPermission(err) = true when err.Is(fs.ErrPermission), wanted false")
   188  	}
   189  }