feat: Add tests to NewFileInfo
This commit is contained in:
136
pkg/fs/fileinfo_test.go
Normal file
136
pkg/fs/fileinfo_test.go
Normal file
@@ -0,0 +1,136 @@
|
||||
package fs
|
||||
|
||||
import (
|
||||
"io/fs"
|
||||
"os"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"github.com/pojntfx/stfs/examples"
|
||||
)
|
||||
|
||||
var (
|
||||
now = time.Now()
|
||||
)
|
||||
|
||||
type newFileInfoArgs struct {
|
||||
name string
|
||||
size int64
|
||||
mode fs.FileMode
|
||||
modTime time.Time
|
||||
accessTime time.Time
|
||||
changeTime time.Time
|
||||
gid int
|
||||
uid int
|
||||
isDir bool
|
||||
}
|
||||
|
||||
var newFileInfoTests = []struct {
|
||||
name string
|
||||
args newFileInfoArgs
|
||||
want *FileInfo
|
||||
}{
|
||||
{
|
||||
"Can set file info attributes",
|
||||
newFileInfoArgs{
|
||||
"test.txt",
|
||||
100,
|
||||
os.ModePerm,
|
||||
now,
|
||||
now,
|
||||
now,
|
||||
1000,
|
||||
1000,
|
||||
false,
|
||||
},
|
||||
&FileInfo{
|
||||
name: "test.txt",
|
||||
size: 100,
|
||||
mode: os.ModePerm,
|
||||
modTime: now,
|
||||
accessTime: now,
|
||||
changeTime: now,
|
||||
gid: 1000,
|
||||
uid: 1000,
|
||||
isDir: false,
|
||||
},
|
||||
},
|
||||
{
|
||||
"Can set directory info attributes",
|
||||
newFileInfoArgs{
|
||||
"test.txt",
|
||||
1024,
|
||||
os.ModePerm,
|
||||
now,
|
||||
now,
|
||||
now,
|
||||
100,
|
||||
100,
|
||||
true,
|
||||
},
|
||||
&FileInfo{
|
||||
name: "test.txt",
|
||||
size: 1024,
|
||||
mode: os.ModePerm,
|
||||
modTime: now,
|
||||
accessTime: now,
|
||||
changeTime: now,
|
||||
gid: 100,
|
||||
uid: 100,
|
||||
isDir: true,
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
func TestNewFileInfo(t *testing.T) {
|
||||
jsonLogger := &examples.Logger{
|
||||
Verbose: verbose,
|
||||
}
|
||||
|
||||
for _, tt := range newFileInfoTests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
got := NewFileInfo(tt.args.name, tt.args.size, tt.args.mode, tt.args.modTime, tt.args.accessTime, tt.args.changeTime, tt.args.gid, tt.args.uid, tt.args.isDir, jsonLogger)
|
||||
|
||||
if got.Name() != tt.want.name {
|
||||
t.Errorf("FileInfo.Name() = %v, want %v", got.Name(), tt.want.Name())
|
||||
}
|
||||
|
||||
if got.Size() != tt.want.size {
|
||||
t.Errorf("FileInfo.Size() = %v, want %v", got.Size(), tt.want.Size())
|
||||
}
|
||||
|
||||
if got.Mode() != tt.want.mode {
|
||||
t.Errorf("FileInfo.Mode() = %v, want %v", got.Mode(), tt.want.Mode())
|
||||
}
|
||||
|
||||
if got.ModTime() != tt.want.modTime {
|
||||
t.Errorf("FileInfo.ModTime() = %v, want %v", got.ModTime(), tt.want.modTime)
|
||||
}
|
||||
|
||||
if got.IsDir() != tt.want.isDir {
|
||||
t.Errorf("FileInfo.IsDir() = %v, want %v", got.IsDir(), tt.want.isDir)
|
||||
}
|
||||
|
||||
gotSys, ok := got.Sys().(*Stat)
|
||||
if !ok {
|
||||
t.Errorf("FileInfo.Sys() !ok")
|
||||
}
|
||||
|
||||
if gotSys.Atim.Nano() != tt.want.accessTime.UnixNano() {
|
||||
t.Errorf("FileInfo.Atim.Nano() = %v, want %v", gotSys.Atim.Nano(), tt.want.accessTime.UnixNano())
|
||||
}
|
||||
|
||||
if gotSys.Ctim.Nano() != tt.want.changeTime.UnixNano() {
|
||||
t.Errorf("FileInfo.Ctim.Nano() = %v, want %v", gotSys.Ctim.Nano(), tt.want.changeTime.UnixNano())
|
||||
}
|
||||
|
||||
if gotSys.Gid != uint32(tt.want.gid) {
|
||||
t.Errorf("FileInfo.Gid = %v, want %v", gotSys.Gid, tt.want.gid)
|
||||
}
|
||||
|
||||
if gotSys.Uid != uint32(tt.want.uid) {
|
||||
t.Errorf("FileInfo.Uid = %v, want %v", gotSys.Uid, tt.want.uid)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user